mirror of
https://github.com/clap-rs/clap
synced 2025-03-04 23:37:32 +00:00
This better models what users should be doing and makes it so all comments are more clear. In a prior commit, when a changed an `exit` to `unwrap`, I disliked the fact that I was mixing an unwrap explanatory comment in with another comment. This makes them stand apart.
36 lines
1.2 KiB
Rust
36 lines
1.2 KiB
Rust
use clap::{App, Arg};
|
|
|
|
fn main() {
|
|
// There are two ways in which to get a default value, one is to use clap's Arg::default_value
|
|
// method, and the other is to use Rust's built in Option::unwrap_or method.
|
|
//
|
|
// I'll demo both here.
|
|
//
|
|
// First, we'll use clap's Arg::default_value with an "INPUT" file.
|
|
let matches = App::new("myapp")
|
|
.about("does awesome things")
|
|
.arg(
|
|
Arg::new("INPUT")
|
|
.about("The input file to use")
|
|
.default_value("input.txt")
|
|
.index(1),
|
|
)
|
|
// Next we'll use the Option::unwrap_or method on this "CONFIG" option
|
|
.arg(
|
|
Arg::new("CONFIG")
|
|
.about("The config file to use")
|
|
.short('c')
|
|
.takes_value(true),
|
|
)
|
|
.get_matches();
|
|
|
|
let input = matches
|
|
.value_of("INPUT")
|
|
.expect("'INPUT' is default and parsing will ensure there always is a value");
|
|
|
|
// Using Option::unwrap_or we get the same effect, but without the added help text injection
|
|
let config_file = matches.value_of("CONFIG").unwrap_or("config.json");
|
|
|
|
println!("The input file is: {}", input);
|
|
println!("The config file is: {}", config_file);
|
|
}
|