mirror of
https://github.com/fish-shell/fish-shell.git
synced 2024-12-04 00:53:41 +08:00
9f48fc6285
It looks like the last status already contains the signal that cancelled execution. Also make `fish -c something` always return the last exit status of "something", instead of hardcoded 127 if exited or signalled. Fixes #6444
60 lines
1.3 KiB
Fish
60 lines
1.3 KiB
Fish
# RUN: %fish -C 'set -l fish %fish' %s
|
|
|
|
$fish -c 'function main; exit 4; true; end; main'; echo $status
|
|
#CHECK: 4
|
|
|
|
$fish -c 'begin; exit 5; true; end'; echo $status
|
|
#CHECK: 5
|
|
|
|
$fish -c 'kill -SIGHUP %self'; echo $status
|
|
#CHECK: 129
|
|
|
|
$fish -c 'function main; kill -SIGTERM %self; true; end; main'; echo $status
|
|
#CHECK: 143
|
|
|
|
function alarm --on-signal ALRM
|
|
echo ALRM received
|
|
end
|
|
|
|
kill -s ALRM $fish_pid
|
|
# CHECK: ALRM received
|
|
|
|
function anychild --on-process-exit 0
|
|
# Type and exit status
|
|
echo $argv[1] $argv[3]
|
|
end
|
|
|
|
echo "command false:"
|
|
command false
|
|
# CHECK: command false:
|
|
# CHECK: PROCESS_EXIT 1
|
|
# CHECK: JOB_EXIT 0
|
|
|
|
echo "command true:"
|
|
command true
|
|
# CHECK: command true:
|
|
# CHECK: PROCESS_EXIT 0
|
|
# CHECK: JOB_EXIT 0
|
|
|
|
echo "command false | true:"
|
|
command false | command true
|
|
# CHECK: command false | true:
|
|
# CHECK: PROCESS_EXIT 1
|
|
# CHECK: PROCESS_EXIT 0
|
|
# CHECK: JOB_EXIT 0
|
|
|
|
function test_blocks
|
|
block -l
|
|
command echo "This is the process whose exit event shuld be blocked"
|
|
echo "This should come before the event handler"
|
|
end
|
|
test_blocks
|
|
# CHECK: This is the process whose exit event shuld be blocked
|
|
# CHECK: This should come before the event handler
|
|
|
|
echo "Now event handler should have run"
|
|
# CHECK: PROCESS_EXIT 0
|
|
# CHECK: JOB_EXIT 0
|
|
# CHECK: Now event handler should have run
|
|
# CHECK: PROCESS_EXIT 0
|