2022-03-07 20:43:51 +00:00
|
|
|
use clap::error::{Error, ErrorKind};
|
|
|
|
use clap::{ArgMatches, Args as _, Command, FromArgMatches, Parser, Subcommand};
|
|
|
|
|
|
|
|
#[derive(Parser, Debug)]
|
|
|
|
struct AddArgs {
|
2022-05-21 00:52:04 +00:00
|
|
|
#[clap(value_parser)]
|
2022-03-07 20:43:51 +00:00
|
|
|
name: Vec<String>,
|
|
|
|
}
|
|
|
|
#[derive(Parser, Debug)]
|
|
|
|
struct RemoveArgs {
|
2022-06-01 15:31:23 +00:00
|
|
|
#[clap(short, long, action)]
|
2022-03-07 20:43:51 +00:00
|
|
|
force: bool,
|
2022-05-21 00:52:04 +00:00
|
|
|
#[clap(value_parser)]
|
2022-03-07 20:43:51 +00:00
|
|
|
name: Vec<String>,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
enum CliSub {
|
|
|
|
Add(AddArgs),
|
|
|
|
Remove(RemoveArgs),
|
|
|
|
}
|
|
|
|
|
|
|
|
impl FromArgMatches for CliSub {
|
|
|
|
fn from_arg_matches(matches: &ArgMatches) -> Result<Self, Error> {
|
|
|
|
match matches.subcommand() {
|
|
|
|
Some(("add", args)) => Ok(Self::Add(AddArgs::from_arg_matches(args)?)),
|
|
|
|
Some(("remove", args)) => Ok(Self::Remove(RemoveArgs::from_arg_matches(args)?)),
|
|
|
|
Some((_, _)) => Err(Error::raw(
|
|
|
|
ErrorKind::UnrecognizedSubcommand,
|
|
|
|
"Valid subcommands are `add` and `remove`",
|
|
|
|
)),
|
|
|
|
None => Err(Error::raw(
|
|
|
|
ErrorKind::MissingSubcommand,
|
|
|
|
"Valid subcommands are `add` and `remove`",
|
|
|
|
)),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
fn update_from_arg_matches(&mut self, matches: &ArgMatches) -> Result<(), Error> {
|
|
|
|
match matches.subcommand() {
|
|
|
|
Some(("add", args)) => *self = Self::Add(AddArgs::from_arg_matches(args)?),
|
|
|
|
Some(("remove", args)) => *self = Self::Remove(RemoveArgs::from_arg_matches(args)?),
|
|
|
|
Some((_, _)) => {
|
|
|
|
return Err(Error::raw(
|
|
|
|
ErrorKind::UnrecognizedSubcommand,
|
|
|
|
"Valid subcommands are `add` and `remove`",
|
|
|
|
))
|
|
|
|
}
|
|
|
|
None => (),
|
|
|
|
};
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Subcommand for CliSub {
|
|
|
|
fn augment_subcommands(cmd: Command<'_>) -> Command<'_> {
|
|
|
|
cmd.subcommand(AddArgs::augment_args(Command::new("add")))
|
|
|
|
.subcommand(RemoveArgs::augment_args(Command::new("remove")))
|
|
|
|
.subcommand_required(true)
|
|
|
|
}
|
|
|
|
fn augment_subcommands_for_update(cmd: Command<'_>) -> Command<'_> {
|
|
|
|
cmd.subcommand(AddArgs::augment_args(Command::new("add")))
|
|
|
|
.subcommand(RemoveArgs::augment_args(Command::new("remove")))
|
|
|
|
.subcommand_required(true)
|
|
|
|
}
|
|
|
|
fn has_subcommand(name: &str) -> bool {
|
|
|
|
matches!(name, "add" | "remove")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Parser, Debug)]
|
|
|
|
struct Cli {
|
2022-06-01 15:31:23 +00:00
|
|
|
#[clap(short, long, action)]
|
2022-03-07 20:43:51 +00:00
|
|
|
top_level: bool,
|
|
|
|
#[clap(subcommand)]
|
|
|
|
subcommand: CliSub,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let args = Cli::parse();
|
|
|
|
println!("{:#?}", args);
|
|
|
|
}
|