clap/examples/15_custom_validator.rs

42 lines
1.3 KiB
Rust
Raw Normal View History

2015-08-27 15:35:00 +00:00
use clap::{App, Arg};
fn main() {
// You can define a function (or a closure) to use as a validator to argument values. The
// function must accept a `&str` and return `Result<(), String>` where `Err(String)` is the
// message displayed to the user.
2015-08-27 15:35:00 +00:00
let matches = App::new("myapp")
2018-11-14 17:05:06 +00:00
// Application logic goes here...
.arg(
Arg::new("input")
.help("the input file to use")
2018-11-14 17:05:06 +00:00
.index(1)
.required(true)
// You can pass in a closure, or a function
.validator(is_png),
)
.get_matches();
2015-08-27 15:35:00 +00:00
println!(
"The .PNG file is: {}",
matches
.value_of("input")
.expect("'input' is required and parsing will fail if its missing")
);
2015-08-27 15:35:00 +00:00
}
fn is_png(val: &str) -> Result<(), String> {
// val is the argument value passed in by the user
// val has type of String.
if val.ends_with(".png") {
Ok(())
} else {
// clap automatically adds "error: " to the beginning
// of the message.
Err(String::from("the file format must be png."))
}
// Of course, you can do more complicated validation as
// well, but for the simplicity, this example only checks
// if the value passed in ends with ".png" or not.
}