mirror of
https://github.com/clap-rs/clap
synced 2024-12-15 15:22:30 +00:00
57 lines
No EOL
1.6 KiB
Rust
57 lines
No EOL
1.6 KiB
Rust
// If you require more complex configuration than simple_enum! provides, you can implement the
|
|
// trait manually, as in the following example.
|
|
//
|
|
// In the following example we will create an enum with 4 values, assign a positional argument
|
|
// that accepts only one of those values, and use clap to parse the argument.
|
|
//
|
|
// Start with bringing the trait into scope.
|
|
use std::str::FromStr;
|
|
|
|
// Add clap like normal
|
|
#[macro_use]
|
|
extern crate clap;
|
|
|
|
use clap::{App, Arg};
|
|
|
|
// Define your enum
|
|
enum Vals {
|
|
Foo,
|
|
Bar,
|
|
Baz,
|
|
Qux
|
|
}
|
|
|
|
// Implement the trait
|
|
impl<'a> FromStr for Vals {
|
|
type Err = &'a str;
|
|
|
|
fn from_str(s: &str) -> Result<Self, <Self as FromStr>::Err> {
|
|
match s {
|
|
"Foo" => Ok(Vals::Foo),
|
|
"Bar" => Ok(Vals::Bar),
|
|
"Baz" => Ok(Vals::Baz),
|
|
"Qux" => Ok(Vals::Qux),
|
|
_ => Err("no match")
|
|
}
|
|
}
|
|
}
|
|
|
|
fn main() {
|
|
// Create the application like normal
|
|
let m = App::new("myapp")
|
|
// Use a single positional argument that is required
|
|
.arg(Arg::from_usage("<type> 'The type to use'")
|
|
// Define the list of possible values
|
|
.possible_values(vec!["Foo", "Bar", "Baz", "Qux"]))
|
|
.get_matches();
|
|
|
|
let t = value_t_or_exit!(m.value_of("type"), Vals);
|
|
|
|
// Now we can use our enum like normal.
|
|
match t {
|
|
Vals::Foo => println!("Found a Foo"),
|
|
Vals::Bar => println!("Found a Bar"),
|
|
Vals::Baz => println!("Found a Baz"),
|
|
Vals::Qux => println!("Found a Qux")
|
|
}
|
|
} |