2020-05-23 15:20:17 +08:00
|
|
|
function ls --description "List contents of directory"
|
|
|
|
# Make ls use colors and show indicators if we are on a system that supports that feature and writing to stdout.
|
|
|
|
#
|
2006-02-20 21:02:03 +08:00
|
|
|
|
2020-05-23 15:20:17 +08:00
|
|
|
# BSD, macOS and others support colors with ls -G.
|
|
|
|
# GNU ls and FreeBSD ls takes --color=auto. Order of this test is important because ls also takes -G but it has a different meaning.
|
|
|
|
# Solaris 11's ls command takes a --color flag.
|
2021-06-02 01:46:13 +08:00
|
|
|
# OpenBSD requires the separate colorls program for color support.
|
2020-05-23 15:20:17 +08:00
|
|
|
# Also test -F because we'll want to define this function even with an ls that can't do colors (like NetBSD).
|
2023-11-02 20:00:58 +08:00
|
|
|
if not set -q __fish_ls_command
|
2021-06-03 15:52:57 +08:00
|
|
|
set -g __fish_ls_command ls
|
2023-11-02 20:00:58 +08:00
|
|
|
set -g __fish_ls_color_opt
|
|
|
|
set -g __fish_ls_indicators_opt
|
2021-06-03 15:52:57 +08:00
|
|
|
# OpenBSD ships a command called "colorls" that takes "-G" and "-F",
|
|
|
|
# but there's also a ruby implementation that doesn't understand "-F".
|
|
|
|
# Since that one's quite different, don't use it.
|
|
|
|
if command -sq colorls
|
|
|
|
and command colorls -GF >/dev/null 2>/dev/null
|
|
|
|
set -g __fish_ls_command colorls
|
2023-11-02 20:00:58 +08:00
|
|
|
set -g __fish_ls_color_opt -G
|
|
|
|
set -g __fish_ls_indicators_opt -F
|
2021-06-03 15:52:57 +08:00
|
|
|
else
|
2023-11-02 19:50:02 +08:00
|
|
|
for opt in --color=auto -G --color
|
2021-06-03 15:52:57 +08:00
|
|
|
if command ls $opt / >/dev/null 2>/dev/null
|
|
|
|
set -g __fish_ls_color_opt $opt
|
|
|
|
break
|
|
|
|
end
|
2020-05-23 15:20:17 +08:00
|
|
|
end
|
2023-11-02 20:00:58 +08:00
|
|
|
|
|
|
|
if command ls -F / >/dev/null 2>/dev/null
|
|
|
|
set -g __fish_ls_indicators_opt -F
|
|
|
|
end
|
2019-01-21 22:18:17 +08:00
|
|
|
end
|
2017-09-26 21:55:28 +08:00
|
|
|
end
|
2020-05-23 15:20:17 +08:00
|
|
|
|
2023-11-02 20:00:58 +08:00
|
|
|
set -l indicators_opt
|
2020-05-23 15:20:17 +08:00
|
|
|
isatty stdout
|
2023-11-02 20:00:58 +08:00
|
|
|
and set -a indicators_opt $__fish_ls_indicators_opt
|
2021-06-02 01:46:13 +08:00
|
|
|
|
2021-09-25 00:14:57 +08:00
|
|
|
# Terminal.app doesn't set $COLORTERM or $CLICOLOR,
|
|
|
|
# but the new FreeBSD ls requires either to be set,
|
|
|
|
# before it will enable color.
|
|
|
|
# See #8309.
|
|
|
|
# We don't set $COLORTERM because that should be set to
|
|
|
|
# "truecolor" or similar and we don't want to specify that here.
|
|
|
|
test "$TERM_PROGRAM" = Apple_Terminal
|
2021-09-25 00:17:49 +08:00
|
|
|
and set -lx CLICOLOR 1
|
2021-09-25 00:14:57 +08:00
|
|
|
|
2024-05-24 09:40:10 +08:00
|
|
|
# If CLICOLOR_FORCE is set, don't colorize `ls` (if piped) because the results
|
|
|
|
# might not be what we want; i.e. `ls --color=auto | cat` might still emit color
|
|
|
|
# output (e.g. under BSD and macOS).
|
|
|
|
# We don't just unset CLICOLOR_FORCE because the user might theoretically *want*
|
|
|
|
# this behavior by explicitly including `--color=auto` in $argv themselves.
|
|
|
|
set -qx CLICOLOR_FORCE && not isatty stdout; and set __fish_ls_color_opt
|
|
|
|
|
2023-11-02 20:00:58 +08:00
|
|
|
command $__fish_ls_command $__fish_ls_color_opt $indicators_opt $argv
|
2006-02-08 17:20:05 +08:00
|
|
|
end
|