mirror of
https://github.com/clap-rs/clap
synced 2025-01-21 00:53:52 +00:00
fix(assert): Provide next steps for '-h' conflicts
For now, we are going to provide a better debug assert in this case. Resolving #3405 is the better long term route. Fixes #3403
This commit is contained in:
parent
df1d50c367
commit
6c60b79d21
2 changed files with 23 additions and 4 deletions
|
@ -2940,17 +2940,36 @@ impl<'help> App<'help> {
|
||||||
self.args.remove(index);
|
self.args.remove(index);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let other_arg_has_short = self.args.args().any(|x| x.short == Some('h'));
|
let help = self
|
||||||
|
.args
|
||||||
|
.args()
|
||||||
|
.find(|x| x.id == Id::help_hash())
|
||||||
|
.expect(INTERNAL_ERROR_MSG);
|
||||||
|
assert_ne!(help.provider, ArgProvider::User);
|
||||||
|
|
||||||
|
if help.short.is_some() {
|
||||||
|
if help.short == Some('h') {
|
||||||
|
if let Some(other_arg) = self
|
||||||
|
.args
|
||||||
|
.args()
|
||||||
|
.find(|x| x.id != Id::help_hash() && x.short == Some('h'))
|
||||||
|
{
|
||||||
|
panic!(
|
||||||
|
"`help`s `-h` conflicts with `{}`.
|
||||||
|
|
||||||
|
To change `help`s short, call `app.arg(Arg::new(\"help\")...)`.",
|
||||||
|
other_arg.name
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if !(self.args.args().any(|x| x.short == Some('h'))
|
||||||
|
|| self.subcommands.iter().any(|sc| sc.short_flag == Some('h')))
|
||||||
|
{
|
||||||
let help = self
|
let help = self
|
||||||
.args
|
.args
|
||||||
.args_mut()
|
.args_mut()
|
||||||
.find(|x| x.id == Id::help_hash())
|
.find(|x| x.id == Id::help_hash())
|
||||||
.expect(INTERNAL_ERROR_MSG);
|
.expect(INTERNAL_ERROR_MSG);
|
||||||
|
|
||||||
if help.short.is_some() {
|
|
||||||
} else if !(other_arg_has_short
|
|
||||||
|| self.subcommands.iter().any(|sc| sc.short_flag == Some('h')))
|
|
||||||
{
|
|
||||||
help.short = Some('h');
|
help.short = Some('h');
|
||||||
} else {
|
} else {
|
||||||
debug!("App::_check_help_and_version: Removing `-h` from help");
|
debug!("App::_check_help_and_version: Removing `-h` from help");
|
||||||
|
|
|
@ -1557,7 +1557,7 @@ fn arg_short_conflict_with_help() {
|
||||||
|
|
||||||
#[cfg(debug_assertions)]
|
#[cfg(debug_assertions)]
|
||||||
#[test]
|
#[test]
|
||||||
#[should_panic = "Short option names must be unique for each argument, but '-h' is in use by both 'home' and 'help'"]
|
#[should_panic = "`help`s `-h` conflicts with `home`."]
|
||||||
fn arg_short_conflict_with_help_mut_arg() {
|
fn arg_short_conflict_with_help_mut_arg() {
|
||||||
let _ = App::new("conflict")
|
let _ = App::new("conflict")
|
||||||
.arg(Arg::new("home").short('h'))
|
.arg(Arg::new("home").short('h'))
|
||||||
|
|
Loading…
Reference in a new issue