clap/examples/10_default_values.rs
Ed Page 3be8bcf756 docs(examples): Move unwrap comments to expect statements
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.
2021-11-17 15:23:31 -06:00

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);
}