2022-02-22 23:40:28 +00:00
|
|
|
use clap::{Args, Parser, Subcommand};
|
2022-02-22 14:23:58 +00:00
|
|
|
|
|
|
|
#[derive(Parser)]
|
|
|
|
#[clap(author, version, about, long_about = None)]
|
|
|
|
#[clap(propagate_version = true)]
|
|
|
|
struct Cli {
|
|
|
|
#[clap(subcommand)]
|
|
|
|
command: Commands,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Subcommand)]
|
|
|
|
enum Commands {
|
|
|
|
/// Adds files to myapp
|
|
|
|
Add(Add),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Args)]
|
|
|
|
struct Add {
|
2022-05-21 00:52:04 +00:00
|
|
|
#[clap(value_parser)]
|
2022-02-22 23:40:28 +00:00
|
|
|
name: Option<String>,
|
2022-02-22 14:23:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let cli = Cli::parse();
|
|
|
|
|
|
|
|
// You can check for the existence of subcommands, and if found use their
|
|
|
|
// matches just as you would the top level cmd
|
|
|
|
match &cli.command {
|
2022-02-22 23:40:28 +00:00
|
|
|
Commands::Add(name) => {
|
|
|
|
println!("'myapp add' was used, name is: {:?}", name.name)
|
2022-02-22 14:23:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|