mirror of
https://github.com/clap-rs/clap
synced 2024-12-14 06:42:33 +00:00
fix: fixes a bug that prevented number_of_values and default_values to be used together
Closes #1050 Closes #1056
This commit is contained in:
parent
f7a6955238
commit
5eb342a99d
1 changed files with 14 additions and 0 deletions
|
@ -1723,28 +1723,38 @@ impl<'a, 'b> Parser<'a, 'b>
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn add_defaults(&mut self, matcher: &mut ArgMatcher<'a>) -> ClapResult<()> {
|
pub fn add_defaults(&mut self, matcher: &mut ArgMatcher<'a>) -> ClapResult<()> {
|
||||||
|
debugln!("Parser::add_defaults;");
|
||||||
macro_rules! add_val {
|
macro_rules! add_val {
|
||||||
(@default $_self:ident, $a:ident, $m:ident) => {
|
(@default $_self:ident, $a:ident, $m:ident) => {
|
||||||
if let Some(ref val) = $a.v.default_val {
|
if let Some(ref val) = $a.v.default_val {
|
||||||
|
debugln!("Parser::add_defaults:iter:{}: has default vals", $a.b.name);
|
||||||
if $m.get($a.b.name).map(|ma| ma.vals.len()).map(|len| len == 0).unwrap_or(false) {
|
if $m.get($a.b.name).map(|ma| ma.vals.len()).map(|len| len == 0).unwrap_or(false) {
|
||||||
|
debugln!("Parser::add_defaults:iter:{}: has no user defined vals", $a.b.name);
|
||||||
$_self.add_val_to_arg($a, OsStr::new(val), $m)?;
|
$_self.add_val_to_arg($a, OsStr::new(val), $m)?;
|
||||||
|
|
||||||
if $_self.cache.map_or(true, |name| name != $a.name()) {
|
if $_self.cache.map_or(true, |name| name != $a.name()) {
|
||||||
arg_post_processing!($_self, $a, $m);
|
arg_post_processing!($_self, $a, $m);
|
||||||
$_self.cache = Some($a.name());
|
$_self.cache = Some($a.name());
|
||||||
}
|
}
|
||||||
|
} else if $m.get($a.b.name).is_some() {
|
||||||
|
debugln!("Parser::add_defaults:iter:{}: has user defined vals", $a.b.name);
|
||||||
|
} else {
|
||||||
|
debugln!("Parser::add_defaults:iter:{}: wasn't used", $a.b.name);
|
||||||
|
|
||||||
|
$_self.add_val_to_arg($a, OsStr::new(val), $m)?;
|
||||||
|
|
||||||
|
if $_self.cache.map_or(true, |name| name != $a.name()) {
|
||||||
|
arg_post_processing!($_self, $a, $m);
|
||||||
|
$_self.cache = Some($a.name());
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
$_self.add_val_to_arg($a, OsStr::new(val), $m)?;
|
debugln!("Parser::add_defaults:iter:{}: doesn't have default vals", $a.b.name);
|
||||||
|
|
||||||
if $_self.cache.map_or(true, |name| name != $a.name()) {
|
|
||||||
arg_post_processing!($_self, $a, $m);
|
|
||||||
$_self.cache = Some($a.name());
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
($_self:ident, $a:ident, $m:ident) => {
|
($_self:ident, $a:ident, $m:ident) => {
|
||||||
if let Some(ref vm) = $a.v.default_vals_ifs {
|
if let Some(ref vm) = $a.v.default_vals_ifs {
|
||||||
|
sdebugln!(" has conditional defaults");
|
||||||
let mut done = false;
|
let mut done = false;
|
||||||
if $m.get($a.b.name).is_none() {
|
if $m.get($a.b.name).is_none() {
|
||||||
for &(arg, val, default) in vm.values() {
|
for &(arg, val, default) in vm.values() {
|
||||||
|
@ -1772,15 +1782,19 @@ impl<'a, 'b> Parser<'a, 'b>
|
||||||
if done {
|
if done {
|
||||||
continue; // outer loop (outside macro)
|
continue; // outer loop (outside macro)
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
sdebugln!(" doesn't have conditional defaults");
|
||||||
}
|
}
|
||||||
add_val!(@default $_self, $a, $m)
|
add_val!(@default $_self, $a, $m)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
for o in &self.opts {
|
for o in &self.opts {
|
||||||
|
debug!("Parser::add_defaults:iter:{}:", o.b.name);
|
||||||
add_val!(self, o, matcher);
|
add_val!(self, o, matcher);
|
||||||
}
|
}
|
||||||
for p in self.positionals.values() {
|
for p in self.positionals.values() {
|
||||||
|
debug!("Parser::add_defaults:iter:{}:", p.b.name);
|
||||||
add_val!(self, p, matcher);
|
add_val!(self, p, matcher);
|
||||||
}
|
}
|
||||||
Ok(())
|
Ok(())
|
||||||
|
|
Loading…
Reference in a new issue