Skip to content

Commit

Permalink
Add unsupported short suggestion for --out-dir flag
Browse files Browse the repository at this point in the history
  • Loading branch information
Rustin170506 committed Sep 30, 2023
1 parent ec05156 commit d37a19d
Show file tree
Hide file tree
Showing 3 changed files with 24 additions and 9 deletions.
9 changes: 1 addition & 8 deletions src/bin/cargo/commands/build.rs
Original file line number Diff line number Diff line change
Expand Up @@ -35,14 +35,7 @@ pub fn cli() -> Command {
.arg_parallel()
.arg_target_triple("Build for the target triple")
.arg_target_dir()
.arg(
opt(
"out-dir",
"Copy final artifacts to this directory (unstable)",
)
.value_name("PATH")
.help_heading(heading::COMPILATION_OPTIONS),
)
.arg_out_dir()
.arg_build_plan()
.arg_unit_graph()
.arg_timings()
Expand Down
20 changes: 20 additions & 0 deletions src/cargo/util/command_prelude.rs
Original file line number Diff line number Diff line change
Expand Up @@ -357,6 +357,26 @@ pub trait CommandExt: Sized {
.help_heading(heading::COMPILATION_OPTIONS),
)
}

fn arg_out_dir(self) -> Self {
let unsupported_short_arg = {
let msg = format!("no short alias is defined for '--out-dir'");
let value_parser = UnknownArgumentValueParser::suggest(msg);
flag("unsupported-short-out-dir-flag", "")
.short('O')
.value_parser(value_parser)
.hide(true)
};
self._arg(
opt(
"out-dir",
"Copy final artifacts to this directory (unstable)",
)
.value_name("PATH")
.help_heading(heading::COMPILATION_OPTIONS),
)
._arg(unsupported_short_arg)
}
}

impl CommandExt for Command {
Expand Down
4 changes: 3 additions & 1 deletion tests/testsuite/out_dir.rs
Original file line number Diff line number Diff line change
Expand Up @@ -291,7 +291,9 @@ fn unsupported_short_out_dir_flag() {
.masquerade_as_nightly_cargo(&["out-dir"])
.with_stderr(
"\
error: unexpected argument '-O' found
error: unexpected argument '--unsupported-short-out-dir-flag' found
tip: no short alias is defined for '--out-dir'
Usage: cargo[EXE] build [OPTIONS]
Expand Down

0 comments on commit d37a19d

Please sign in to comment.