mirror of
https://github.com/clap-rs/clap
synced 2025-01-18 15:43:54 +00:00
d840d5650e
Before #2005, `Clap` was a special trait that derived all clap traits it detected were relevant (including an enum getting both `ArgEnum`, `Clap`, and `Subcommand`). Now, we have elevated `Clap`, `Args`, `Subcommand`, and `ArgEnum` to be user facing but the name `Clap` isn't very descriptive. This also helps further clarify the relationships so a crate providing an item to be `#[clap(flatten)]` or `#[clap(subcommand)]` is more likely to choose the needed trait to derive. Also, my proposed fix fo #2785 includes making `App` attributes almost exclusively for `Clap`. Clarifying the names/roles will help communicate this. For prior discussion, see #2583
31 lines
663 B
Rust
31 lines
663 B
Rust
//! How to use `clap::Arg::group`
|
|
|
|
use clap::{ArgGroup, Parser};
|
|
|
|
#[derive(Parser, Debug)]
|
|
#[clap(group = ArgGroup::new("verb").required(true))]
|
|
struct Opt {
|
|
/// Set a custom HTTP verb
|
|
#[clap(long, group = "verb")]
|
|
method: Option<String>,
|
|
/// HTTP GET
|
|
#[clap(long, group = "verb")]
|
|
get: bool,
|
|
/// HTTP HEAD
|
|
#[clap(long, group = "verb")]
|
|
head: bool,
|
|
/// HTTP POST
|
|
#[clap(long, group = "verb")]
|
|
post: bool,
|
|
/// HTTP PUT
|
|
#[clap(long, group = "verb")]
|
|
put: bool,
|
|
/// HTTP DELETE
|
|
#[clap(long, group = "verb")]
|
|
delete: bool,
|
|
}
|
|
|
|
fn main() {
|
|
let opt = Opt::parse();
|
|
println!("{:?}", opt);
|
|
}
|