set -q: Return 255 if no variable name was passed

Previously this strictly returned the number of unset variables. So if
no variable was given, it would return *true*, which is highly
suspect.
This commit is contained in:
Fabian Homborg 2021-08-09 18:01:44 +02:00
parent 35c53a94b5
commit eee38836cf
3 changed files with 13 additions and 1 deletions

View file

@ -59,7 +59,7 @@ The following other options are available:
- ``-e`` or ``--erase`` causes the specified shell variables to be erased - ``-e`` or ``--erase`` causes the specified shell variables to be erased
- ``-q`` or ``--query`` test if the specified variable names are defined. Does not output anything, but the builtins exit status is the number of variables specified that were not defined, or 255 if more than 255 variables are not defined. - ``-q`` or ``--query`` test if the specified variable names are defined. Does not output anything, but the builtins exit status is the number of variables specified that were not defined, up to a maximum of 255. If no variable was given, it also returns 255.
- ``-n`` or ``--names``: List only the names of all defined variables, not their value. The names are guaranteed to be sorted. - ``-n`` or ``--names``: List only the names of all defined variables, not their value. The names are guaranteed to be sorted.

View file

@ -466,6 +466,10 @@ static int builtin_set_query(const wchar_t *cmd, set_cmd_opts_t &opts, int argc,
int retval = 0; int retval = 0;
env_mode_flags_t scope = compute_scope(opts); env_mode_flags_t scope = compute_scope(opts);
// No variables given, this is an error.
// 255 is the maximum return code we allow.
if (argc == 0) return 255;
for (int i = 0; i < argc; i++) { for (int i = 0; i < argc; i++) {
auto split = split_var_and_indexes(argv[i], scope, parser.vars(), streams); auto split = split_var_and_indexes(argv[i], scope, parser.vars(), streams);
if (!split) { if (!split) {

View file

@ -820,3 +820,11 @@ function erase-funcvar
end end
erase-funcvar erase-funcvar
set --query $this_is_not_set
echo $status
# CHECK: 255
set --query
echo $status
# CHECK: 255