1 unstable release
0.1.0 | Jan 3, 2025 |
---|
#1427 in Development tools
117 downloads per month
13KB
88 lines
CLI hooks for Rust
⚠️ Warning: This project is experimental and under active development. The API and functionality may undergo significant changes. Use with caution in production environments.
A procedural macro that enables dynamic execution of Rust code before and after function calls. Unlike typical procedural macros that are limited to compile-time code generation, this crate allows you to:
- Execute arbitrary Rust code from external files at runtime
- Load different hook implementations without recompiling the CLI application
This is particularly useful for CLI applications where users need to customize command behavior by injecting their own code before or after execution. Common use cases include:
- Adding environment-specific logging
- Performing custom validation before commands
- Running cleanup operations after command execution
- Measuring performance metrics
Setup
To build and test the project:
cargo build
cargo test -- --nocaption # this allows to see println in tests
Installation
Add this to your Cargo.toml
:
[dependencies]
cli_hooks_rs = "0.1.0"
Usage
Usage with custom hooks:
// .hooks/pre.rs (end user injected code)
{
println!("Starting execution");
}
// .hooks/post.rs (end user injected code)
{
println!("Execution completed");
}
// main.rs (CLI app)
use cli_hooks_rs::with_hooks;
#[with_hooks]
fn some_function() -> i32 {
std::thread::sleep(std::time::Duration::from_secs(1));
42
}
Dependencies
~205–640KB
~15K SLoC