mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-14 22:14:53 +00:00
set: Add special error for set foo=bar
Fixes #8694 Only for setting, erasing with a value makes no sense.
This commit is contained in:
parent
31e2476fc8
commit
b0c2d083d6
2 changed files with 13 additions and 0 deletions
|
@ -720,6 +720,12 @@ static int builtin_set_set(const wchar_t *cmd, set_cmd_opts_t &opts, int argc, c
|
||||||
// Is the variable valid?
|
// Is the variable valid?
|
||||||
if (!valid_var_name(split->varname)) {
|
if (!valid_var_name(split->varname)) {
|
||||||
streams.err.append_format(BUILTIN_ERR_VARNAME, cmd, split->varname.c_str());
|
streams.err.append_format(BUILTIN_ERR_VARNAME, cmd, split->varname.c_str());
|
||||||
|
auto pos = split->varname.find(L'=');
|
||||||
|
if (pos != wcstring::npos) {
|
||||||
|
streams.err.append_format(L"%ls: Did you mean `set %ls %ls`?", cmd,
|
||||||
|
escape_string(split->varname.substr(0, pos), ESCAPE_ALL, STRING_STYLE_SCRIPT).c_str(),
|
||||||
|
escape_string(split->varname.substr(pos + 1), ESCAPE_ALL, STRING_STYLE_SCRIPT).c_str());
|
||||||
|
}
|
||||||
builtin_print_error_trailer(parser, streams.err, cmd);
|
builtin_print_error_trailer(parser, streams.err, cmd);
|
||||||
return STATUS_INVALID_ARGS;
|
return STATUS_INVALID_ARGS;
|
||||||
}
|
}
|
||||||
|
|
|
@ -770,6 +770,13 @@ set --show ""
|
||||||
#CHECKERR: ^
|
#CHECKERR: ^
|
||||||
#CHECKERR: (Type 'help set' for related documentation)
|
#CHECKERR: (Type 'help set' for related documentation)
|
||||||
|
|
||||||
|
set foo="ba nana"
|
||||||
|
#CHECKERR: set: foo=ba nana: invalid variable name. See `help identifiers`
|
||||||
|
#CHECKERR: set: Did you mean `set foo 'ba nana'`?
|
||||||
|
#CHECKERR: {{.*}}set.fish (line {{\d+}}):
|
||||||
|
#CHECKERR: set foo="ba nana"
|
||||||
|
#CHECKERR: ^
|
||||||
|
#CHECKERR: (Type 'help set' for related documentation)
|
||||||
# Test path splitting
|
# Test path splitting
|
||||||
begin
|
begin
|
||||||
set -l PATH /usr/local/bin:/usr/bin
|
set -l PATH /usr/local/bin:/usr/bin
|
||||||
|
|
Loading…
Reference in a new issue