mirror of
https://github.com/fish-shell/fish-shell.git
synced 2024-11-25 03:16:00 +08:00
38f4330683
Prior to this fix, fish was rather inconsistent in when $status gets set in response to an error. For example, a failed expansion like "$foo[" would not modify $status. This makes the following inter-related changes: 1. String expansion now directly returns the value to set for $status on error. The value is always used. 2. parser_t::eval() now directly returns the proc_status_t, which cleans up a lot of call sites. 3. We expose a new function exec_subshell_for_expand() which ignores $status but returns errors specifically related to subshell expansion. 4. We reify the notion of "expansion breaking" errors. These include command-not-found, expand syntax errors, and others. The upshot is we are more consistent about always setting $status on errors.
65 lines
2.0 KiB
Fish
65 lines
2.0 KiB
Fish
# RUN: %fish %s
|
|
|
|
# This tests various corner cases involving command substitution. Most
|
|
# importantly the limits on the amount of data we'll substitute.
|
|
|
|
set fish_read_limit 512
|
|
|
|
function subme
|
|
set -l x (string repeat -n $argv x)
|
|
echo $x
|
|
end
|
|
|
|
# Command sub just under the limit should succeed
|
|
set a (subme 511)
|
|
set --show a
|
|
#CHECK: $a: not set in local scope
|
|
#CHECK: $a: set in global scope, unexported, with 1 elements
|
|
#CHECK: $a[1]: length=511 value=|{{x{510}x}}|
|
|
#CHECK: $a: not set in universal scope
|
|
|
|
# Command sub at the limit should fail
|
|
set b (string repeat -n 512 x)
|
|
set saved_status $status
|
|
test $saved_status -eq 122
|
|
or echo expected status 122, saw $saved_status >&2
|
|
set --show b
|
|
|
|
#CHECK: $b: not set in local scope
|
|
#CHECK: $b: not set in global scope
|
|
#CHECK: $b: not set in universal scope
|
|
#CHECKERR: {{.*}}: Too much data emitted by command substitution so it was discarded
|
|
#CHECKERR: set b (string repeat -n 512 x)
|
|
#CHECKERR: ^
|
|
|
|
|
|
# Command sub over the limit should fail
|
|
set c (subme 513)
|
|
set --show c
|
|
|
|
#CHECK: $c: not set in local scope
|
|
#CHECK: $c: set in global scope, unexported, with 1 elements
|
|
#CHECK: $c[1]: length=0 value=||
|
|
#CHECK: $c: not set in universal scope
|
|
#CHECKERR: {{.*}}: Too much data emitted by command substitution so it was discarded
|
|
#CHECKERR: set -l x (string repeat -n $argv x)
|
|
#CHECKERR: ^
|
|
#CHECKERR: in function 'subme' with arguments '513'
|
|
#CHECKERR: called on line {{.*}}
|
|
#CHECKERR: in command substitution
|
|
#CHECKERR: called on line {{.*}}
|
|
|
|
# Make sure output from builtins outside of command substitution is not affected
|
|
string repeat --max 513 a
|
|
#CHECK: {{a{512}a}}
|
|
|
|
# Same builtin in a command substitution is affected
|
|
echo this will fail (string repeat --max 513 b) to output anything
|
|
set saved_status $status
|
|
test $saved_status -eq 122
|
|
or echo expected status 122, saw $saved_status >&2
|
|
|
|
#CHECKERR: {{.*}}: Too much data emitted by command substitution so it was discarded
|
|
#CHECKERR: echo this will fail (string repeat --max 513 b) to output anything
|
|
#CHECKERR: ^
|