2022-02-22 23:40:28 +00:00
|
|
|
use clap::{Args, Parser, Subcommand};
|
2022-02-22 14:23:58 +00:00
|
|
|
|
|
|
|
#[derive(Parser)]
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(author, version, about, long_about = None)]
|
|
|
|
#[command(propagate_version = true)]
|
2022-02-22 14:23:58 +00:00
|
|
|
struct Cli {
|
2022-09-02 20:37:23 +00:00
|
|
|
#[command(subcommand)]
|
2022-02-22 14:23:58 +00:00
|
|
|
command: Commands,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Subcommand)]
|
|
|
|
enum Commands {
|
|
|
|
/// Adds files to myapp
|
2023-02-06 16:25:14 +00:00
|
|
|
Add(AddArgs),
|
2022-02-22 14:23:58 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Args)]
|
2023-02-06 16:25:14 +00:00
|
|
|
struct AddArgs {
|
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
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|