clap-handler
A command handler works with clap-derive to generating subcommand handlers.
Example
use clap::{Parser, AppSettings};
use clap_handler::{Handler, handler, Context};
#[derive(Parser, Handler, Debug, Clone)]
#[clap(name = "Your program", author)]
pub struct Arguments {
#[clap(subcommand)]
subcommand: Subcommand,
}
#[derive(Parser, Handler, Debug, Clone)]
#[handler_inject(add_something)]
pub enum Subcommand {
First(FirstSubcommand),
}
impl Subcommand {
fn add_something(&self, ctx: &mut Context) -> anyhow::Result<()> {
Ok(())
}
}
#[derive(Args, Debug, Clone)]
pub struct FirstSubcommand {
arg: String,
}
#[handler(FirstSubcommand)]
fn handle_first(me: FirstSubcommand) -> anyhow::Result<()> {
Ok(())
}
fn main() {
let args = Arguments::parse();
log::debug!("{:#?}", args);
args.run().await
}
For more complex examples, see the anni and sswa.
License
Licensed under either of
at your option.