mirror of
https://github.com/clap-rs/clap
synced 2025-01-08 18:58:53 +00:00
befee6667b
This creates distinct tutorial examples from complex feature examples (more how-tos). Both sets are getting builder / derive versions (at least the critical ones).
29 lines
759 B
Rust
29 lines
759 B
Rust
use clap::{AppSettings, Parser, Subcommand};
|
|
|
|
#[derive(Parser)]
|
|
#[clap(author, version, about)]
|
|
#[clap(global_setting(AppSettings::PropagateVersion))]
|
|
#[clap(global_setting(AppSettings::UseLongFormatForHelpSubcommand))]
|
|
#[clap(setting(AppSettings::SubcommandRequiredElseHelp))]
|
|
struct Cli {
|
|
#[clap(subcommand)]
|
|
command: Commands,
|
|
}
|
|
|
|
#[derive(Subcommand)]
|
|
enum Commands {
|
|
/// Adds files to myapp
|
|
Add { name: Option<String> },
|
|
}
|
|
|
|
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 app
|
|
match &cli.command {
|
|
Commands::Add { name } => {
|
|
println!("'myapp add' was used, name is: {:?}", name)
|
|
}
|
|
}
|
|
}
|