fix(parser): Be less confusing with args/subcommand conflicts

The new error message still isn't great but its better than the old one.

Reported at https://hachyderm.io/@eminence/109548978776785113
This commit is contained in:
Ed Page 2022-12-20 20:27:55 -06:00
parent 2a374db639
commit 453ac0bfb9
2 changed files with 28 additions and 30 deletions

View file

@ -502,6 +502,7 @@ impl<'cmd> Parser<'cmd> {
}
}
if !(self.cmd.is_args_conflicts_with_subcommands_set() && valid_arg_found) {
let candidates = suggestions::did_you_mean(
&arg_os.display().to_string(),
self.cmd.all_subcommand_names(),
@ -530,6 +531,7 @@ impl<'cmd> Parser<'cmd> {
Usage::new(self.cmd).create_usage_with_title(&[]),
);
}
}
let suggested_trailing_arg = !trailing_values
&& self.cmd.has_positionals()

View file

@ -705,11 +705,7 @@ fn args_negate_subcommands_two_levels() {
#[cfg(feature = "error-context")]
fn subcommand_conflict_error_message() {
static CONFLICT_ERR: &str = "\
error: The subcommand 'sub1' wasn't recognized
Did you mean 'sub1'?
If you believe you received this message in error, try re-running with 'test -- sub1'
error: Found argument 'sub1' which wasn't expected, or isn't valid in this context
Usage: test [OPTIONS]
test <COMMAND>