fix(usage)!: Switch positionals... from multi-val to mulit-occur

I noticed this while investigating #2692.  Since we are making
multiple-occurrences a thing for positional arguments, this allows us to
remove a special case.

Another way to look at this is that we should make the default whatever
we do for dervies (#1772).  I'm going to propose we make the derive
always turn `Vec<i32>` into multiple occurences and not multiple values
(with users being able to change it through attributes), but that is an
in-work proposal and not decided yet.

BREAKING CHANGE: `Arg::from(...)` will now use `multiple_occurrences`
for a positional `...`, rather than `multiple_values`.
This commit is contained in:
Ed Page 2021-10-30 13:40:52 -05:00
parent acaa3645c3
commit dd2c4c6346

View file

@ -64,12 +64,6 @@ impl<'help> UsageParser<'help> {
} }
} }
if arg.is_positional() && arg.is_set(ArgSettings::MultipleOccurrences) {
// We had a positional and need to set mult vals too
arg.settings.set(ArgSettings::MultipleValues);
arg.settings.unset(ArgSettings::MultipleOccurrences);
}
debug!("UsageParser::parse: vals...{:?}", arg.val_names); debug!("UsageParser::parse: vals...{:?}", arg.val_names);
arg arg
} }
@ -1109,8 +1103,8 @@ mod test {
let a = Arg::from("[pos]... 'some help info'"); let a = Arg::from("[pos]... 'some help info'");
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some help info"); assert_eq!(a.about.unwrap(), "some help info");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(!a.is_set(ArgSettings::Required)); assert!(!a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1120,8 +1114,8 @@ mod test {
let a = Arg::from("[pos]... 'some help\' info'"); let a = Arg::from("[pos]... 'some help\' info'");
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some help' info"); assert_eq!(a.about.unwrap(), "some help' info");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(!a.is_set(ArgSettings::Required)); assert!(!a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1131,8 +1125,8 @@ mod test {
let a = Arg::from("[pos]... 'some \'help\' info'"); let a = Arg::from("[pos]... 'some \'help\' info'");
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some 'help' info"); assert_eq!(a.about.unwrap(), "some 'help' info");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(!a.is_set(ArgSettings::Required)); assert!(!a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1145,8 +1139,8 @@ mod test {
); );
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some help\ninfo"); assert_eq!(a.about.unwrap(), "some help\ninfo");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(!a.is_set(ArgSettings::Required)); assert!(!a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1159,8 +1153,8 @@ mod test {
); );
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some help' stuff\ninfo"); assert_eq!(a.about.unwrap(), "some help' stuff\ninfo");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(!a.is_set(ArgSettings::Required)); assert!(!a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1170,8 +1164,8 @@ mod test {
let a = Arg::from("<pos>... 'some help info'"); let a = Arg::from("<pos>... 'some help info'");
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some help info"); assert_eq!(a.about.unwrap(), "some help info");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(a.is_set(ArgSettings::Required)); assert!(a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1190,8 +1184,8 @@ mod test {
fn pos_mult() { fn pos_mult() {
let a = Arg::from("[pos]..."); let a = Arg::from("[pos]...");
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(!a.is_set(ArgSettings::Required)); assert!(!a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
} }
@ -1201,8 +1195,8 @@ mod test {
let a = Arg::from("<pos>... @a 'some help info'"); let a = Arg::from("<pos>... @a 'some help info'");
assert_eq!(a.name, "pos"); assert_eq!(a.name, "pos");
assert_eq!(a.about.unwrap(), "some help info"); assert_eq!(a.about.unwrap(), "some help info");
assert!(!a.is_set(ArgSettings::MultipleOccurrences)); assert!(a.is_set(ArgSettings::MultipleOccurrences));
assert!(a.is_set(ArgSettings::MultipleValues)); assert!(!a.is_set(ArgSettings::MultipleValues));
assert!(a.is_set(ArgSettings::Required)); assert!(a.is_set(ArgSettings::Required));
assert!(a.val_names.is_empty()); assert!(a.val_names.is_empty());
assert_eq!(a.default_vals, vec![std::ffi::OsStr::new("a")]); assert_eq!(a.default_vals, vec![std::ffi::OsStr::new("a")]);