mirror of
https://github.com/clap-rs/clap
synced 2024-12-29 22:13:06 +00:00
e874a0d5e0
Closes #269
154 lines
5.2 KiB
Rust
154 lines
5.2 KiB
Rust
macro_rules! remove_overriden {
|
|
($me:ident, $name:expr) => ({
|
|
debugln!("macro=remove_overriden!;");
|
|
if let Some(ref o) = $me.opts.iter().filter(|o| o.name == *$name).next() {
|
|
if let Some(ref ora) = o.requires {
|
|
for a in ora {
|
|
vec_remove!($me.required, a);
|
|
}
|
|
}
|
|
if let Some(ref ora) = o.blacklist {
|
|
for a in ora {
|
|
vec_remove!($me.blacklist, a);
|
|
}
|
|
}
|
|
if let Some(ref ora) = o.overrides {
|
|
for a in ora {
|
|
vec_remove!($me.overrides, a);
|
|
}
|
|
}
|
|
} else if let Some(ref o) = $me.flags.iter().filter(|f| f.name == *$name).next() {
|
|
if let Some(ref ora) = o.requires {
|
|
for a in ora {
|
|
vec_remove!($me.required, a);
|
|
}
|
|
}
|
|
if let Some(ref ora) = o.blacklist {
|
|
for a in ora {
|
|
vec_remove!($me.blacklist, a);
|
|
}
|
|
}
|
|
if let Some(ref ora) = o.overrides {
|
|
for a in ora {
|
|
vec_remove!($me.overrides, a);
|
|
}
|
|
}
|
|
} else if let Some(p) = $me.positionals.values().filter(|p| p.name == *$name).next() {
|
|
if let Some(ref ora) = p.requires {
|
|
for a in ora {
|
|
vec_remove!($me.required, a);
|
|
}
|
|
}
|
|
if let Some(ref ora) = p.blacklist {
|
|
for a in ora {
|
|
vec_remove!($me.blacklist, a);
|
|
}
|
|
}
|
|
if let Some(ref ora) = p.overrides {
|
|
for a in ora {
|
|
vec_remove!($me.overrides, a);
|
|
}
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
macro_rules! arg_post_processing(
|
|
($me:ident, $arg:ident, $matcher:ident) => ({
|
|
use args::AnyArg;
|
|
debugln!("macro=arg_post_processing!;");
|
|
// Handle POSIX overrides
|
|
debug!("Is '{}' in overrides...", $arg.to_string());
|
|
if $me.overrides.contains(&$arg.name()) {
|
|
if let Some(ref name) = $me.overriden_from($arg.name(), $matcher) {
|
|
sdebugln!("Yes by {}", name);
|
|
$matcher.remove(name);
|
|
remove_overriden!($me, name);
|
|
}
|
|
} else { sdebugln!("No"); }
|
|
|
|
// Add overrides
|
|
debug!("Does '{}' have overrides...", $arg.to_string());
|
|
if let Some(or) = $arg.overrides() {
|
|
for pa in or {
|
|
sdebugln!("\tYes '{}'", pa);
|
|
$matcher.remove(&*pa);
|
|
remove_overriden!($me, pa);
|
|
$me.overrides.push(pa);
|
|
vec_remove!($me.required, pa);
|
|
}
|
|
} else { sdebugln!("No"); }
|
|
|
|
// Handle conflicts
|
|
debug!("Does '{}' have conflicts...", $arg.to_string());
|
|
if let Some(bl) = $arg.blacklist() {
|
|
for name in bl {
|
|
sdebugln!("\n\tYes '{}'", name);
|
|
$me.blacklist.push(name);
|
|
vec_remove!($me.overrides, name);
|
|
vec_remove!($me.required, name);
|
|
}
|
|
} else { sdebugln!("No"); }
|
|
|
|
// Add all required args which aren't already found in matcher to the master
|
|
// list
|
|
debug!("Does '{}' have requirements...", $arg.to_string());
|
|
if let Some(reqs) = $arg.requires() {
|
|
for n in reqs {
|
|
if $matcher.contains(&n) {
|
|
sdebugln!("\tYes '{}' but it's already met", n);
|
|
continue;
|
|
} else { sdebugln!("\tYes '{}'", n); }
|
|
|
|
$me.required.push(n);
|
|
}
|
|
} else { sdebugln!("No"); }
|
|
|
|
_handle_group_reqs!($me, $arg);
|
|
})
|
|
);
|
|
|
|
macro_rules! _handle_group_reqs{
|
|
($me:ident, $arg:ident) => ({
|
|
use args::AnyArg;
|
|
debugln!("macro=_handle_group_reqs!;");
|
|
for grp in $me.groups.values() {
|
|
let mut found = false;
|
|
for name in grp.args.iter() {
|
|
if name == &$arg.name() {
|
|
vec_remove!($me.required, name);
|
|
if let Some(ref reqs) = grp.requires {
|
|
for r in reqs {
|
|
$me.required.push(r);
|
|
}
|
|
}
|
|
if let Some(ref bl) = grp.conflicts {
|
|
for &b in bl {
|
|
$me.blacklist.push(b);
|
|
}
|
|
}
|
|
found = true;
|
|
break;
|
|
}
|
|
}
|
|
if found {
|
|
for name in &grp.args {
|
|
if name == &$arg.name() { continue }
|
|
vec_remove!($me.required, name);
|
|
|
|
$me.blacklist.push(name);
|
|
}
|
|
}
|
|
}
|
|
})
|
|
}
|
|
|
|
macro_rules! validate_multiples {
|
|
($_self:ident, $a:ident, $m:ident) => {
|
|
debugln!("macro=validate_multiples!;");
|
|
if $m.contains(&$a.name) && !$a.settings.is_set(ArgSettings::Multiple) {
|
|
// Not the first time, and we don't allow multiples
|
|
return Err(Error::unexpected_multiple_usage($a, &*$_self.create_current_usage($m)))
|
|
}
|
|
};
|
|
}
|