2022-08-23 18:38:57 +00:00
|
|
|
use clap::builder::PossibleValue;
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn basic_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
clap::Command::new(name)
|
2022-07-26 00:17:01 +00:00
|
|
|
.arg(
|
|
|
|
clap::Arg::new("config")
|
|
|
|
.short('c')
|
|
|
|
.global(true)
|
|
|
|
.action(clap::ArgAction::SetTrue),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("v")
|
|
|
|
.short('v')
|
|
|
|
.conflicts_with("config")
|
|
|
|
.action(clap::ArgAction::SetTrue),
|
|
|
|
)
|
2022-03-07 20:12:59 +00:00
|
|
|
.subcommand(
|
2022-07-26 00:17:01 +00:00
|
|
|
clap::Command::new("test").about("Subcommand").arg(
|
|
|
|
clap::Arg::new("debug")
|
|
|
|
.short('d')
|
|
|
|
.action(clap::ArgAction::Count),
|
|
|
|
),
|
2022-03-07 20:12:59 +00:00
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn feature_sample_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
clap::Command::new(name)
|
|
|
|
.version("3.0")
|
|
|
|
.propagate_version(true)
|
|
|
|
.about("Tests completions")
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("file")
|
|
|
|
.value_hint(clap::ValueHint::FilePath)
|
|
|
|
.help("some input file"),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("config")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Count)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("some config file")
|
|
|
|
.short('c')
|
|
|
|
.visible_short_alias('C')
|
|
|
|
.long("config")
|
|
|
|
.visible_alias("conf"),
|
|
|
|
)
|
2022-05-24 01:16:02 +00:00
|
|
|
.arg(clap::Arg::new("choice").value_parser(["first", "second"]))
|
2022-03-07 20:12:59 +00:00
|
|
|
.subcommand(
|
|
|
|
clap::Command::new("test").about("tests things").arg(
|
|
|
|
clap::Arg::new("case")
|
|
|
|
.long("case")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("the case to test"),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn special_commands_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
feature_sample_command(name)
|
|
|
|
.subcommand(
|
|
|
|
clap::Command::new("some_cmd")
|
|
|
|
.about("tests other things")
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("config")
|
2022-05-04 20:38:06 +00:00
|
|
|
.long("config")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("the other case to test"),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
.subcommand(clap::Command::new("some-cmd-with-hyphens").alias("hyphen"))
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn quoting_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
clap::Command::new(name)
|
|
|
|
.version("3.0")
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("single-quotes")
|
|
|
|
.long("single-quotes")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("Can be 'always', 'auto', or 'never'"),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("double-quotes")
|
|
|
|
.long("double-quotes")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("Can be \"always\", \"auto\", or \"never\""),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("backticks")
|
|
|
|
.long("backticks")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("For more information see `echo test`"),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("backslash")
|
|
|
|
.long("backslash")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("Avoid '\\n'"),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("brackets")
|
|
|
|
.long("brackets")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("List packages [filter]"),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("expansions")
|
|
|
|
.long("expansions")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("Execute the shell command with $SHELL"),
|
|
|
|
)
|
|
|
|
.subcommands([
|
|
|
|
clap::Command::new("cmd-single-quotes").about("Can be 'always', 'auto', or 'never'"),
|
|
|
|
clap::Command::new("cmd-double-quotes")
|
|
|
|
.about("Can be \"always\", \"auto\", or \"never\""),
|
|
|
|
clap::Command::new("cmd-backticks").about("For more information see `echo test`"),
|
|
|
|
clap::Command::new("cmd-backslash").about("Avoid '\\n'"),
|
|
|
|
clap::Command::new("cmd-brackets").about("List packages [filter]"),
|
|
|
|
clap::Command::new("cmd-expansions").about("Execute the shell command with $SHELL"),
|
|
|
|
])
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn aliases_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
clap::Command::new(name)
|
|
|
|
.version("3.0")
|
|
|
|
.about("testing bash completions")
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("flag")
|
|
|
|
.short('f')
|
|
|
|
.visible_short_alias('F')
|
|
|
|
.long("flag")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::SetTrue)
|
2022-03-07 20:12:59 +00:00
|
|
|
.visible_alias("flg")
|
|
|
|
.help("cmd flag"),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("option")
|
|
|
|
.short('o')
|
|
|
|
.visible_short_alias('O')
|
|
|
|
.long("option")
|
|
|
|
.visible_alias("opt")
|
|
|
|
.help("cmd option")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set),
|
2022-03-07 20:12:59 +00:00
|
|
|
)
|
|
|
|
.arg(clap::Arg::new("positional"))
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn sub_subcommands_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
feature_sample_command(name).subcommand(
|
|
|
|
clap::Command::new("some_cmd")
|
|
|
|
.about("top level subcommand")
|
|
|
|
.subcommand(
|
|
|
|
clap::Command::new("sub_cmd").about("sub-subcommand").arg(
|
|
|
|
clap::Arg::new("config")
|
2022-05-04 20:38:06 +00:00
|
|
|
.long("config")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set)
|
2022-08-01 14:02:52 +00:00
|
|
|
.value_parser([clap::builder::PossibleValue::new(
|
|
|
|
"Lest quotes aren't escaped.",
|
|
|
|
)])
|
2022-03-07 20:12:59 +00:00
|
|
|
.help("the other case to test"),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn value_hint_command(name: &'static str) -> clap::Command {
|
2022-03-07 20:12:59 +00:00
|
|
|
clap::Command::new(name)
|
|
|
|
.trailing_var_arg(true)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("choice")
|
|
|
|
.long("choice")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set)
|
2022-05-24 01:16:02 +00:00
|
|
|
.value_parser(["bash", "fish", "zsh"]),
|
2022-03-07 20:12:59 +00:00
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("unknown")
|
|
|
|
.long("unknown")
|
|
|
|
.value_hint(clap::ValueHint::Unknown),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("other")
|
|
|
|
.long("other")
|
|
|
|
.value_hint(clap::ValueHint::Other),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("path")
|
|
|
|
.long("path")
|
|
|
|
.short('p')
|
|
|
|
.value_hint(clap::ValueHint::AnyPath),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("file")
|
|
|
|
.long("file")
|
|
|
|
.short('f')
|
|
|
|
.value_hint(clap::ValueHint::FilePath),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("dir")
|
|
|
|
.long("dir")
|
|
|
|
.short('d')
|
|
|
|
.value_hint(clap::ValueHint::DirPath),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("exe")
|
|
|
|
.long("exe")
|
|
|
|
.short('e')
|
|
|
|
.value_hint(clap::ValueHint::ExecutablePath),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("cmd_name")
|
|
|
|
.long("cmd-name")
|
|
|
|
.value_hint(clap::ValueHint::CommandName),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("cmd")
|
|
|
|
.long("cmd")
|
|
|
|
.short('c')
|
|
|
|
.value_hint(clap::ValueHint::CommandString),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("command_with_args")
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set)
|
2022-08-03 16:20:07 +00:00
|
|
|
.num_args(1..)
|
2022-03-07 20:12:59 +00:00
|
|
|
.value_hint(clap::ValueHint::CommandWithArguments),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("user")
|
|
|
|
.short('u')
|
|
|
|
.long("user")
|
|
|
|
.value_hint(clap::ValueHint::Username),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("host")
|
2022-08-08 21:08:47 +00:00
|
|
|
.short('H')
|
2022-03-07 20:12:59 +00:00
|
|
|
.long("host")
|
|
|
|
.value_hint(clap::ValueHint::Hostname),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("url")
|
|
|
|
.long("url")
|
|
|
|
.value_hint(clap::ValueHint::Url),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("email")
|
|
|
|
.long("email")
|
|
|
|
.value_hint(clap::ValueHint::EmailAddress),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn hidden_option_command(name: &'static str) -> clap::Command {
|
2022-04-02 23:28:19 +00:00
|
|
|
clap::Command::new(name)
|
2022-07-26 00:17:01 +00:00
|
|
|
.arg(
|
|
|
|
clap::Arg::new("config")
|
|
|
|
.long("config")
|
|
|
|
.action(clap::ArgAction::Set),
|
|
|
|
)
|
2022-04-02 23:28:19 +00:00
|
|
|
.arg(
|
|
|
|
clap::Arg::new("no-config")
|
2022-05-04 20:38:06 +00:00
|
|
|
.long("no-config")
|
2022-04-02 23:28:19 +00:00
|
|
|
.hide(true)
|
|
|
|
.overrides_with("config"),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-08-15 19:29:46 +00:00
|
|
|
pub fn env_value_command(name: &'static str) -> clap::Command {
|
2022-04-20 13:50:11 +00:00
|
|
|
clap::Command::new(name).arg(
|
|
|
|
clap::Arg::new("config")
|
|
|
|
.short('c')
|
|
|
|
.long_help("Set configuration file path")
|
|
|
|
.required(false)
|
2022-07-26 00:17:01 +00:00
|
|
|
.action(clap::ArgAction::Set)
|
2022-04-20 13:50:11 +00:00
|
|
|
.default_value("config.toml")
|
|
|
|
.env("CONFIG_FILE"),
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2022-03-07 20:12:59 +00:00
|
|
|
pub fn assert_matches_path(expected_path: impl AsRef<std::path::Path>, cmd: clap::Command) {
|
|
|
|
let mut buf = vec![];
|
|
|
|
clap_mangen::Man::new(cmd).render(&mut buf).unwrap();
|
|
|
|
|
|
|
|
snapbox::Assert::new()
|
|
|
|
.action_env("SNAPSHOTS")
|
|
|
|
.matches_path(expected_path, buf);
|
|
|
|
}
|
2022-08-23 18:38:57 +00:00
|
|
|
|
|
|
|
pub fn possible_values_command(name: &'static str) -> clap::Command<'static> {
|
|
|
|
clap::Command::new(name)
|
|
|
|
.trailing_var_arg(true)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("choice")
|
|
|
|
.long("choice")
|
|
|
|
.action(clap::ArgAction::Set)
|
|
|
|
.value_parser(["bash", "fish", "zsh"]),
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
clap::Arg::new("method")
|
|
|
|
.long("method")
|
|
|
|
.action(clap::ArgAction::Set)
|
|
|
|
.value_parser([
|
|
|
|
PossibleValue::new("fast").help("use the Fast method"),
|
|
|
|
PossibleValue::new("slow").help("use the slow method"),
|
|
|
|
PossibleValue::new("normal").help("use normal mode").hide(true)
|
|
|
|
])
|
|
|
|
)
|
|
|
|
}
|