mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-12 21:18:53 +00:00
e697add5b5
If I run "sleep 3", type a command and hit enter, then there is no obvious way to cancel or edit the imminent command other than ctrl-c but that also cancels sleep, and doesn't allow editing. (ctrl-z sort of works, but also doesn't allow editing). Let's try to limit ourselves to inserting the buffered command (translating enter to a newline), and only execute once the user actually presses enter after the previous command is done. Hide it behind a new feature flag for now. By making things less scary, this might be more user-friendly, at the risk of breaking expectations in some cases. This also fixes a class of security issues where a command like `cat malicious-file.txt` might output escape sequences, causing the terminal to echo back a malicious command; such files can still insert into the command line but at least not execute it directly. (Since it's only fixed partially I'm not really sure if the security issue is a good enough motivation for this particular change.) Note that bracketed paste probably has similar motivation as this feature. Part of #10987 Closes #10991
131 lines
3.8 KiB
Fish
131 lines
3.8 KiB
Fish
#RUN: %fish %s
|
|
status -b
|
|
and echo '"status -b" unexpectedly returned true at top level'
|
|
|
|
begin
|
|
status -b
|
|
or echo '"status -b" unexpectedly returned false inside a begin block'
|
|
end
|
|
|
|
status -l
|
|
and echo '"status -l" unexpectedly returned true for a non-login shell'
|
|
|
|
status -i
|
|
and echo '"status -i" unexpectedly returned true for a non-interactive shell'
|
|
|
|
status is-login
|
|
and echo '"status is-login" unexpectedly returned true for a non-login shell'
|
|
|
|
status is-interactive
|
|
and echo '"status is-interactive" unexpectedly returned true for a non-interactive shell'
|
|
|
|
# We should get an error message about an invalid combination of flags.
|
|
status --is-interactive --is-login
|
|
#CHECKERR: status: is-interactive is-login: options cannot be used together
|
|
|
|
# We should get an error message about an unexpected arg for `status
|
|
# is-block`.
|
|
status -b is-interactive
|
|
#CHECKERR: status: is-block is-interactive: options cannot be used together
|
|
# XXX this would be better if it referred to -b rather than what it is
|
|
|
|
# Try to set the job control to an invalid mode.
|
|
status job-control full1
|
|
#CHECKERR: status: Invalid job control mode 'full1'
|
|
status --job-control=1none
|
|
#CHECKERR: status: Invalid job control mode '1none'
|
|
|
|
# Now set it to a valid mode.
|
|
status job-control none
|
|
|
|
# Check status -u outside functions
|
|
status current-function
|
|
#CHECK: Not a function
|
|
|
|
function test_function
|
|
status current-function
|
|
end
|
|
|
|
test_function
|
|
#CHECK: test_function
|
|
eval test_function
|
|
#CHECK: test_function
|
|
|
|
# Future Feature Flags
|
|
status features
|
|
#CHECK: stderr-nocaret on 3.0 ^ no longer redirects stderr (historical, can no longer be changed)
|
|
#CHECK: qmark-noglob on 3.0 ? no longer globs
|
|
#CHECK: regex-easyesc on 3.1 string replace -r needs fewer \'s
|
|
#CHECK: ampersand-nobg-in-token on 3.4 & only backgrounds if followed by a separator
|
|
#CHECK: remove-percent-self off 3.8 %self is no longer expanded (use $fish_pid)
|
|
#CHECK: test-require-arg off 3.8 builtin test requires an argument
|
|
#CHECK: buffered-enter-noexec off 4.1 enter typed while executing will not execute
|
|
status test-feature stderr-nocaret
|
|
echo $status
|
|
#CHECK: 0
|
|
status test-feature not-a-feature
|
|
echo $status
|
|
#CHECK: 2
|
|
|
|
# Ensure $status isn't reset before a function is executed
|
|
function echo_last
|
|
echo $status
|
|
end
|
|
|
|
false
|
|
echo_last
|
|
echo $status #1
|
|
#CHECK: 1
|
|
#CHECK: 0
|
|
|
|
# Verify that if swallows failure - see #1061
|
|
if false
|
|
end
|
|
echo $status
|
|
#CHECK: 0
|
|
|
|
# Verify errors from writes - see #7857.
|
|
if test -e /dev/full
|
|
# Failed writes to stdout produce 1.
|
|
echo foo > /dev/full
|
|
if test $status -ne 1
|
|
echo "Wrong status when writing to /dev/full"
|
|
end
|
|
|
|
# Here the builtin should fail with status 2,
|
|
# and also the write should fail with status 1.
|
|
# The builtin has precedence.
|
|
builtin string --not-a-valid-option 2> /dev/full
|
|
if test $status -ne 2
|
|
echo "Wrong status for failing builtin"
|
|
end
|
|
echo "Failed write tests finished"
|
|
else
|
|
echo "Failed write tests skipped"
|
|
echo "write: skipped" 1>&2
|
|
echo "write: skipped" 1>&2
|
|
end
|
|
# CHECK: Failed write tests {{finished|skipped}}
|
|
# CHECKERR: write: {{.*}}
|
|
# CHECKERR: write: {{.*}}
|
|
|
|
function test-stack-trace-main
|
|
status stack-trace
|
|
end
|
|
|
|
function test-stack-trace-other
|
|
test-stack-trace-main
|
|
end
|
|
|
|
printf "%s\n" (test-stack-trace-other | string replace \t '<TAB>')[1..4]
|
|
# CHECK: in function 'test-stack-trace-main'
|
|
# CHECK: <TAB>called on line {{\d+}} of file {{.*}}/status.fish
|
|
# CHECK: in function 'test-stack-trace-other'
|
|
# CHECK: <TAB>called on line {{\d+}} of file {{.*}}/status.fish
|
|
|
|
functions -c test-stack-trace-other test-stack-trace-copy
|
|
printf "%s\n" (test-stack-trace-copy | string replace \t '<TAB>')[1..4]
|
|
# CHECK: in function 'test-stack-trace-main'
|
|
# CHECK: <TAB>called on line {{\d+}} of file {{.*}}/status.fish
|
|
# CHECK: in function 'test-stack-trace-copy'
|
|
# CHECK: <TAB>called on line {{\d+}} of file {{.*}}/status.fish
|