pub struct ArgGroup { /* private fields */ }Expand description
Specifies a logical group of arguments
You can use this for
- applying validation to an entire group, like
ArgGroup::multiple - validate relationships between an argument and a group, like conflicts or requirements
- check which argument in a group was specified on the command-line
For visually grouping arguments in help, see instead
Arg::help_heading.
§Examples
The following example demonstrates using an ArgGroup to ensure that one, and only one, of
the arguments from the specified group is present at runtime.
let result = Command::new("cmd")
.arg(arg!(--"set-ver" <ver> "set the version manually"))
.arg(arg!(--major "auto increase major"))
.arg(arg!(--minor "auto increase minor"))
.arg(arg!(--patch "auto increase patch"))
.group(ArgGroup::new("vers")
.args(["set-ver", "major", "minor", "patch"])
.required(true))
.try_get_matches_from(vec!["cmd", "--major", "--patch"]);
// Because we used two args in the group it's an error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::ArgumentConflict);This next example shows a passing parse of the same scenario
let result = Command::new("cmd")
.arg(arg!(--"set-ver" <ver> "set the version manually"))
.arg(arg!(--major "auto increase major"))
.arg(arg!(--minor "auto increase minor"))
.arg(arg!(--patch "auto increase patch"))
.group(ArgGroup::new("vers")
.args(["set-ver", "major", "minor","patch"])
.required(true))
.try_get_matches_from(vec!["cmd", "--major"]);
assert!(result.is_ok());
let matches = result.unwrap();
// We may not know which of the args was used, so we can test for the group...
assert!(matches.contains_id("vers"));
// We can also ask the group which arg was used
assert_eq!(matches
.get_one::<Id>("vers")
.expect("`vers` is required")
.as_str(),
"major"
);
// we could also alternatively check each arg individually (not shown here)Implementations§
Source§impl ArgGroup
§Builder
impl ArgGroup
§Builder
Sourcepub fn new(id: impl Into<Id>) -> Self
pub fn new(id: impl Into<Id>) -> Self
Create a ArgGroup using a unique name.
The name will be used to get values from the group or refer to the group inside of conflict and requirement rules.
§Examples
ArgGroup::new("config")Sourcepub fn arg(self, arg_id: impl IntoResettable<Id>) -> Self
pub fn arg(self, arg_id: impl IntoResettable<Id>) -> Self
Adds an argument to this group by name
§Examples
let m = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.arg("flag")
.arg("color"))
.get_matches_from(vec!["myprog", "-f"]);
// maybe we don't know which of the two flags was used...
assert!(m.contains_id("req_flags"));
// but we can also check individually if needed
assert!(m.contains_id("flag"));Sourcepub fn args(self, ns: impl IntoIterator<Item = impl Into<Id>>) -> Self
pub fn args(self, ns: impl IntoIterator<Item = impl Into<Id>>) -> Self
Adds multiple arguments to this group by name
§Examples
let m = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"]))
.get_matches_from(vec!["myprog", "-f"]);
// maybe we don't know which of the two flags was used...
assert!(m.contains_id("req_flags"));
// but we can also check individually if needed
assert!(m.contains_id("flag"));Sourcepub fn get_args(&self) -> impl Iterator<Item = &Id>
pub fn get_args(&self) -> impl Iterator<Item = &Id>
Getters for all args. It will return a vector of Id
§Example
let args: Vec<&str> = vec!["a1".into(), "a4".into()];
let grp = ArgGroup::new("program").args(&args);
for (pos, arg) in grp.get_args().enumerate() {
assert_eq!(*arg, args[pos]);
}Sourcepub fn multiple(self, yes: bool) -> Self
pub fn multiple(self, yes: bool) -> Self
Allows more than one of the Args in this group to be used. (Default: false)
§Examples
Notice in this example we use both the -f and -c flags which are both part of the
group
let m = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"])
.multiple(true))
.get_matches_from(vec!["myprog", "-f", "-c"]);
// maybe we don't know which of the two flags was used...
assert!(m.contains_id("req_flags"));In this next example, we show the default behavior (i.e. multiple(false)) which will throw
an error if more than one of the args in the group was used.
let result = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"]))
.try_get_matches_from(vec!["myprog", "-f", "-c"]);
// Because we used both args in the group it's an error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::ArgumentConflict);Sourcepub fn is_multiple(&mut self) -> bool
pub fn is_multiple(&mut self) -> bool
Return true if the group allows more than one of the arguments
in this group to be used. (Default: false)
§Example
let mut group = ArgGroup::new("myprog")
.args(["f", "c"])
.multiple(true);
assert!(group.is_multiple());Sourcepub fn required(self, yes: bool) -> Self
pub fn required(self, yes: bool) -> Self
Require an argument from the group to be present when parsing.
This is unless conflicting with another argument. A required group will be displayed in
the usage string of the application in the format <arg|arg2|arg3>.
NOTE: This setting only applies to the current Command / Subcommands, and not
globally.
NOTE: By default, ArgGroup::multiple is set to false which when combined with
ArgGroup::required(true) states, “One and only one arg must be used from this group.
Use of more than one arg is an error.” Vice setting ArgGroup::multiple(true) which
states, ’At least one arg from this group must be used. Using multiple is OK.“
§Examples
let result = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"])
.required(true))
.try_get_matches_from(vec!["myprog"]);
// Because we didn't use any of the args in the group, it's an error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::MissingRequiredArgument);Sourcepub fn requires(self, id: impl IntoResettable<Id>) -> Self
pub fn requires(self, id: impl IntoResettable<Id>) -> Self
Specify an argument or group that must be present when this group is.
This is not to be confused with a required group. Requirement rules function just like argument requirement rules, you can name other arguments or groups that must be present when any one of the arguments from this group is used.
NOTE: The name provided may be an argument or group name
§Examples
let result = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.arg(Arg::new("debug")
.short('d')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"])
.requires("debug"))
.try_get_matches_from(vec!["myprog", "-c"]);
// because we used an arg from the group, and the group requires "-d" to be used, it's an
// error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::MissingRequiredArgument);Sourcepub fn requires_all(self, ns: impl IntoIterator<Item = impl Into<Id>>) -> Self
pub fn requires_all(self, ns: impl IntoIterator<Item = impl Into<Id>>) -> Self
Specify arguments or groups that must be present when this group is.
This is not to be confused with a required group. Requirement rules function just like argument requirement rules, you can name other arguments or groups that must be present when one of the arguments from this group is used.
NOTE: The names provided may be an argument or group name
§Examples
let result = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.arg(Arg::new("debug")
.short('d')
.action(ArgAction::SetTrue))
.arg(Arg::new("verb")
.short('v')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"])
.requires_all(["debug", "verb"]))
.try_get_matches_from(vec!["myprog", "-c", "-d"]);
// because we used an arg from the group, and the group requires "-d" and "-v" to be used,
// yet we only used "-d" it's an error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::MissingRequiredArgument);Sourcepub fn conflicts_with(self, id: impl IntoResettable<Id>) -> Self
pub fn conflicts_with(self, id: impl IntoResettable<Id>) -> Self
Specify an argument or group that must not be present when this group is.
Exclusion (aka conflict) rules function just like argument exclusion rules, you can name other arguments or groups that must not be present when one of the arguments from this group are used.
NOTE: The name provided may be an argument, or group name
§Examples
let result = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.arg(Arg::new("debug")
.short('d')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"])
.conflicts_with("debug"))
.try_get_matches_from(vec!["myprog", "-c", "-d"]);
// because we used an arg from the group, and the group conflicts with "-d", it's an error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::ArgumentConflict);Sourcepub fn conflicts_with_all(
self,
ns: impl IntoIterator<Item = impl Into<Id>>,
) -> Self
pub fn conflicts_with_all( self, ns: impl IntoIterator<Item = impl Into<Id>>, ) -> Self
Specify arguments or groups that must not be present when this group is.
Exclusion rules function just like argument exclusion rules, you can name other arguments or groups that must not be present when one of the arguments from this group are used.
NOTE: The names provided may be an argument, or group name
§Examples
let result = Command::new("myprog")
.arg(Arg::new("flag")
.short('f')
.action(ArgAction::SetTrue))
.arg(Arg::new("color")
.short('c')
.action(ArgAction::SetTrue))
.arg(Arg::new("debug")
.short('d')
.action(ArgAction::SetTrue))
.arg(Arg::new("verb")
.short('v')
.action(ArgAction::SetTrue))
.group(ArgGroup::new("req_flags")
.args(["flag", "color"])
.conflicts_with_all(["debug", "verb"]))
.try_get_matches_from(vec!["myprog", "-c", "-v"]);
// because we used an arg from the group, and the group conflicts with either "-v" or "-d"
// it's an error
assert!(result.is_err());
let err = result.unwrap_err();
assert_eq!(err.kind(), ErrorKind::ArgumentConflict);