mirror of
https://github.com/clap-rs/clap
synced 2025-01-18 23:53:54 +00:00
api(Arg): adds Arg::raw as convenience method to indicate multiple, last, and allow_hyphen_values
This commit is contained in:
parent
d405cbf2e6
commit
a7b3a75cc4
1 changed files with 23 additions and 0 deletions
|
@ -3745,6 +3745,29 @@ impl<'a, 'b> Arg<'a, 'b> {
|
||||||
self.unset_setting(ArgSettings::MultipleOccurrences)
|
self.unset_setting(ArgSettings::MultipleOccurrences)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Indicates that all parameters passed after this should not be parsed
|
||||||
|
/// individually, but rather passed in their entirety. It is worth noting
|
||||||
|
/// that setting this requires all values to come after a `--` to indicate they
|
||||||
|
/// should all be captured. For example:
|
||||||
|
///
|
||||||
|
/// ```notrust
|
||||||
|
/// --foo something -- -v -v -v -b -b -b --baz -q -u -x
|
||||||
|
/// ```
|
||||||
|
/// Will result in everything after `--` to be considered one raw argument. This behavior
|
||||||
|
/// may not be exactly what you are expecting and using [`AppSettings::TrailingVarArg`]
|
||||||
|
/// may be more appropriate.
|
||||||
|
///
|
||||||
|
/// **NOTE:** Implicitly sets [`Arg::multiple(true)`], [`Arg::allow_hyphen_values(true)`], and
|
||||||
|
/// [`Arg::last(true)`] when set to `true`
|
||||||
|
///
|
||||||
|
/// [`Arg::multiple(true)`]: ./struct.Arg.html#method.multiple
|
||||||
|
/// [`Arg::allow_hyphen_values(true)`]: ./struct.Arg.html#method.allow_hyphen_values
|
||||||
|
/// [`Arg::last(true)`]: ./struct.Arg.html#method.last
|
||||||
|
/// [`AppSettings::TrailingVarArg`]: ./enum.AppSettings.html#variant.TrailingVarArg
|
||||||
|
pub fn raw(self, raw: bool) -> Self {
|
||||||
|
self.multiple(raw).allow_hyphen_values(raw).last(raw)
|
||||||
|
}
|
||||||
|
|
||||||
// @TODO @docs @v3-beta: write better docs as ArgSettings is now critical
|
// @TODO @docs @v3-beta: write better docs as ArgSettings is now critical
|
||||||
/// Checks if one of the [`ArgSettings`] is set for the argument
|
/// Checks if one of the [`ArgSettings`] is set for the argument
|
||||||
|
|
Loading…
Reference in a new issue