clap/examples/16_app_settings.rs

36 lines
1.5 KiB
Rust
Raw Normal View History

2018-11-14 17:05:06 +00:00
use clap::{App, AppSettings};
2015-08-28 04:24:00 +00:00
fn main() {
// You can use AppSettings to change the application level behavior of clap. .setting() function
// of App struct takes AppSettings enum as argument. There is also .settings() function which
// takes slice of AppSettings enum. You can learn more about AppSettings in the documentation,
// which also has examples on each setting.
//
// This example will only show usage of one AppSettings setting. See documentation for more
// information.
let matches = App::new("myapp")
2018-11-14 17:05:06 +00:00
.setting(AppSettings::SubcommandsNegateReqs)
// Negates requirement of parent command.
.arg("<input> 'input file to use'")
// Required positional argument called input. This
// will be only required if subcommand is not present.
.subcommand(App::new("test").about("does some testing"))
// if program is invoked with subcommand, you do not
// need to specify the <input> argument anymore due to
// the AppSettings::SubcommandsNegateReqs setting.
.get_matches();
2015-08-28 04:24:00 +00:00
// Calling unwrap() on "input" would not be advised here, because although it's required,
// if the user uses a subcommand, those requirements are no longer required. Hence, we should
// use some sort of 'if let' construct
if let Some(inp) = matches.value_of("input") {
println!("The input file is: {}", inp);
}
2020-08-05 12:36:02 +00:00
match matches.subcommand_name() {
Some("test") => println!("The 'test' subcommand was used"),
2018-01-25 04:05:05 +00:00
_ => unreachable!(),
}
2015-08-28 04:24:00 +00:00
}