mirror of
https://github.com/fish-shell/fish-shell
synced 2024-12-25 12:23:09 +00:00
Enhance/fix isatty
using command test
.
Presently, `isatty` only works on a handful of keywords. Here it is rewritten to be able to take any path, device or fd number as an argument, and eliminates errors printed to stdout. Per discussion in #1228, using `builtin test -c` within a pipe to test special file descriptors is not viable, so this implementation specifcially uses `command test`. Additionally, a note has been added to the documentation of `test` regarding this potential aberration from the expected output of the test utility under the 'Standards' section.
This commit is contained in:
parent
d5cb16aa1f
commit
60808a4820
3 changed files with 47 additions and 26 deletions
|
@ -1,14 +1,29 @@
|
|||
\section isatty isatty - test if the specified file descriptor is a tty
|
||||
\section isatty isatty - test if a file or file descriptor is a tty.
|
||||
|
||||
\subsection isatty-synopsis Synopsis
|
||||
<tt>isatty [FILE DESCRIPTOR]</tt>
|
||||
<tt>isatty [FILE | DEVICE | FILE DESCRIPTOR NUMBER]</tt>
|
||||
|
||||
\subsection isatty-description Description
|
||||
<tt>isatty</tt> tests if a file descriptor is a tty.
|
||||
<tt>isatty</tt> tests if a file or file descriptor is a tty.
|
||||
The argument may be in the form of a file path, device, or file descriptor
|
||||
number. Without an argument, <tt>standard input</tt> is implied.
|
||||
|
||||
<tt>FILE DESCRIPTOR</tt> may be either the number of a file descriptor, or one of the
|
||||
strings <tt>stdin</tt>, \c stdout and <tt>stderr</tt>.
|
||||
If the resolved file descriptor is a tty, the command returns zero. Otherwise, the command exits one. No messages are printed to standard error.
|
||||
|
||||
If the specified file descriptor is a tty, the exit status of the command is
|
||||
zero. Otherwise, it is non-zero.
|
||||
\subsection isatty-examples Examples
|
||||
|
||||
From an interactive shell, the commands below exit with a return value of zero:
|
||||
<pre>
|
||||
isatty
|
||||
isatty stdout
|
||||
isatty 2
|
||||
echo | isatty /dev/fd/1
|
||||
</pre>
|
||||
|
||||
And these will exit non-zero:
|
||||
<pre>
|
||||
echo | isatty
|
||||
isatty /dev/fd/9
|
||||
isatty stdout > file
|
||||
isatty 2 2> file
|
||||
</pre>
|
||||
|
|
|
@ -97,4 +97,11 @@ end.
|
|||
<a href="http://www.unix.com/man-page/POSIX/1/test/">IEEE Std 1003.1-2008
|
||||
(POSIX.1) standard</a>. The following exceptions apply:
|
||||
- The \c < and \c > operators for comparing strings are not implemented.
|
||||
- Because this test is a shell builtin and not a standalone utility, using
|
||||
the -c flag on a special file descriptors like standard input and output
|
||||
may not return the same result when invoked from within a pipe as one
|
||||
would expect when invoking the \c test utility in another shell.
|
||||
|
||||
In cases such as this, one can use \c command \c test to explicitly
|
||||
use the system's standalone \c test rather than this \c builtin \c test.
|
||||
|
||||
|
|
|
@ -1,28 +1,27 @@
|
|||
function isatty -d "Test if a file or file descriptor is a tty."
|
||||
|
||||
function isatty -d "Tests if a file descriptor is a tty"
|
||||
set -l fd 0
|
||||
if count $argv >/dev/null
|
||||
switch $argv[1]
|
||||
# Use `command test` because `builtin test` doesn't open the regular fd's.
|
||||
|
||||
case -h --h --he --hel --help
|
||||
__fish_print_help isatty
|
||||
return 0
|
||||
switch "$argv"
|
||||
|
||||
case stdin
|
||||
set fd 0
|
||||
case '-h*' '--h*'
|
||||
__fish_print_help isatty
|
||||
|
||||
case stdout
|
||||
set fd 1
|
||||
case ''
|
||||
command test -c /dev/stdin
|
||||
|
||||
case stderr
|
||||
set fd 2
|
||||
case '*'
|
||||
if test -e "$argv" # The eval here is needed for symlinks. Unsure why.
|
||||
command test -c "$argv"; and eval tty 0>"$argv" >/dev/null
|
||||
|
||||
case '*'
|
||||
set fd $argv[1]
|
||||
else if test -e /dev/"$argv"
|
||||
command test -c /dev/"$argv"; and tty 0>/dev/"$argv" >/dev/null
|
||||
|
||||
end
|
||||
end
|
||||
|
||||
eval "tty 0>&$fd >/dev/null"
|
||||
else if test -e /dev/fd/"$argv"
|
||||
command test -c /dev/fd/"$argv"; and tty 0>/dev/fd/"$argv" >/dev/null
|
||||
|
||||
else
|
||||
return 1
|
||||
end
|
||||
end
|
||||
end
|
||||
|
|
Loading…
Reference in a new issue