 |
|
| |
FISH-RELEASENOTES(1) |
fish-shell |
FISH-RELEASENOTES(1) |
This release of fish fixes a number of issues identified in fish
4.0.1:
- Completions are quoted, rather than backslash-escaped, only if the
completion is unambiguous. Continuing to edit the token is therefore
easier (#11271
<https://github.com/fish-shell/fish-shell/issues/11271>).
This changes the behavior introduced in 4.0.0 where all completions were
quoted.
- The warning when the terminfo database can't be found has been downgraded
to a log message. fish will act as if the terminal behaves like
xterm-256color, which is correct for the vast majority of cases
(#11277
<https://github.com/fish-shell/fish-shell/issues/11277>,
#11290
<https://github.com/fish-shell/fish-shell/issues/11290>).
- Key combinations using the super (Windows/command) key can now (actually)
be bound using the super- prefix (#11217
<https://github.com/fish-shell/fish-shell/issues/11217>).
This was listed in the release notes for 4.0.1 but did not work
correctly.
- function is stricter about argument parsing, rather than allowing
additional parameters to be silently ignored (#11295
<https://github.com/fish-shell/fish-shell/issues/11295>).
- Using parentheses in the test builtin works correctly, following a
regression in 4.0.0 where they were not recognized (#11387
<https://github.com/fish-shell/fish-shell/issues/11387>).
- delete in Vi mode when Num Lock is active will work correctly
(#11303
<https://github.com/fish-shell/fish-shell/issues/11303>).
- Abbreviations cannot alter the command-line contents, preventing a crash
(#11324
<https://github.com/fish-shell/fish-shell/issues/11324>).
- Improvements to various completions, including new completions for
wl-randr (#11301
<https://github.com/fish-shell/fish-shell/issues/11301>),
performance improvements for cargo completions by avoiding network
requests (#11347
<https://github.com/fish-shell/fish-shell/issues/11347>), and
other improvements for btrfs (#11320
<https://github.com/fish-shell/fish-shell/issues/11320>),
cryptsetup (#11315
<https://github.com/fish-shell/fish-shell/issues/11315>),
git (#11319
<https://github.com/fish-shell/fish-shell/issues/11319>,
#11322
<https://github.com/fish-shell/fish-shell/issues/11322>,
#11323
<https://github.com/fish-shell/fish-shell/issues/11323>),
jj (#11046
<https://github.com/fish-shell/fish-shell/issues/11046>), and
systemd-analyze (#11314
<https://github.com/fish-shell/fish-shell/issues/11314>).
- The Mercurial (hg) prompt can handle working directories that
contain an embedded newline, rather than producing errors (#11348
<https://github.com/fish-shell/fish-shell/issues/11348>).
- A number of crashes have been fixed. Triggers include prompts containing
backspace characters (#11280
<https://github.com/fish-shell/fish-shell/issues/11280>),
history pager search (#11355
<https://github.com/fish-shell/fish-shell/issues/11355>),
invalid UTF-8 in read (#11383
<https://github.com/fish-shell/fish-shell/issues/11383>), and
the kill-selection binding (#11367
<https://github.com/fish-shell/fish-shell/issues/11367>).
- A race condition in the test suite has been fixed (#11254
<https://github.com/fish-shell/fish-shell/issues/11254>), and
a test for fish versioning relaxed to support downstream distributors'
modifications (#11173
<https://github.com/fish-shell/fish-shell/issues/11173>).
- Small improvements to the documentation (#11264
<https://github.com/fish-shell/fish-shell/issues/11264>,
#11329
<https://github.com/fish-shell/fish-shell/issues/11329>,
#11361
<https://github.com/fish-shell/fish-shell/issues/11361>).
----
This release of fish includes the following improvements compared
to fish 4.0.0:
- Key combinations using the super (Windows/command) key can be bound using
the super- prefix (#11217
<https://github.com/fish-shell/fish-shell/issues/11217>).
- Konsole's menu shows the "Open folder with" option again
(#11198
<https://github.com/fish-shell/fish-shell/issues/11198>).
- $fish_color_search_match will now only be applied to the
foreground color if it has an explicit foreground. For example, this allows
setting::
- set -g fish_color_search_match --reverse
- Cursor shape commands (\e[2 q) are no longer sent in
non-interactive shells or in redirections (#11255
<https://github.com/fish-shell/fish-shell/issues/11255>).
- status gained a is-interactive-read subcommand, to check
whether the script is being called from an interactive read
invocation.
- fish's background tasks are now started in a way that avoids an error on
macOS Terminal.app (#11181
<https://github.com/fish-shell/fish-shell/issues/11181>).
- Using key combinations within qemu should work correctly.
- Prompts containing control characters no longer cause incorrect display of
command lines (#11252
<https://github.com/fish-shell/fish-shell/issues/11252>).
- Cancelling the command-line in Vi mode displays correctly again
(#11261
<https://github.com/fish-shell/fish-shell/issues/11261>).
- The acidhub prompt properly displays the git branch again (#11179
<https://github.com/fish-shell/fish-shell/issues/11179>).
- Completions for wine correctly include files again (#11202
<https://github.com/fish-shell/fish-shell/issues/11202>).
- On macOS, paths from /etc/paths and /etc/manpaths containing
colons are handled correctly (#10684
<https://github.com/fish-shell/fish-shell/issues/10684>).
This functionality was included in the 4.0.0 release notes but was missing
from the source code.
- The XTerm modifyOtherKeys keyboard encoding is no longer used under
WezTerm, as it does not work correctly in all layouts (#11204
<https://github.com/fish-shell/fish-shell/issues/11204>).
- kbd:option-left and other similar keys should now work in iTerm
versions before 3.5.12; the kitty keyboard protocol is now disabled on
these versions (#11192
<https://github.com/fish-shell/fish-shell/issues/11192>).
- The kitty keyboard protocol is no longer used under Midnight Commander, as
it does not work correctly (#10640
<https://github.com/fish-shell/fish-shell/issues/10640>).
- fish now sends the commandline along with the OSC 133 semantic prompt
command start sequence. This fixes a test in the kitty terminal
(#11203
<https://github.com/fish-shell/fish-shell/issues/11203>).
- Git completions for third-party commands like "git-absorb" are
completed correctly again (#11205
<https://github.com/fish-shell/fish-shell/issues/11205>).
- Completions for diskutil no longer produce an error (#11201
<https://github.com/fish-shell/fish-shell/issues/11201>).
- The output of certain error messages no longer prints newlines to standard
output (#11248
<https://github.com/fish-shell/fish-shell/issues/11248>).
- A number of crashes have been fixed, including file names longer than 255
bytes (#11221
<https://github.com/fish-shell/fish-shell/issues/11221>),
using fish on a btrfs filesystem (#11219
<https://github.com/fish-shell/fish-shell/issues/11219>),
history files that do not have the expected format (#11236
<https://github.com/fish-shell/fish-shell/issues/11236>), and
pasting into an empty command line (#11256
<https://github.com/fish-shell/fish-shell/issues/11256>).
----
fish's core code has been ported from C++ to Rust (#9512
<https://github.com/fish-shell/fish-shell/issues/9512>). This
means a large change in dependencies and how to build fish. However, there
should be no direct impact on users. Packagers should see the For
Distributors section at the end.
- As part of a larger binding rework, bind gained a new key notation.
In most cases the old notation should keep working, but in rare cases you
may have to change a bind invocation to use the new notation. See
below for details.
- ctrl-c now calls a new bind function called
clear-commandline. The old behavior, which leaves a "^C"
marker, is available as cancel-commandline (#10935
<https://github.com/fish-shell/fish-shell/issues/10935>)
- random will produce different values from previous versions of fish
when used with the same seed, and will work more sensibly with small seed
numbers. The seed was never guaranteed to give the same result across
systems, so we do not expect this to have a large impact (#9593
<https://github.com/fish-shell/fish-shell/issues/9593>).
- Variables in command position that expand to a subcommand keyword are now
forbidden to fix a likely user error. For example, set editor command
emacs; $editor is no longer allowed (#10249
<https://github.com/fish-shell/fish-shell/issues/10249>).
- functions --handlers will now list handlers in a different order.
Now it is definition order, first to last, where before it was last to
first. This was never specifically defined, and we recommend not relying
on a specific order (#9944
<https://github.com/fish-shell/fish-shell/issues/9944>).
- The qmark-noglob feature, introduced in fish 3.0, is enabled by
default. That means ? will no longer act as a single-character
glob. You can, for the time being, turn it back on by adding
no-qmark-noglob to fish_features and restarting fish:
set -Ua fish_features no-qmark-noglob
The flag will eventually be made read-only, making it impossible
to turn off.
- Terminals that fail to ignore unrecognized OSC or CSI sequences may
display garbage. We know cool-retro-term and emacs' ansi-term are
affected, but most mainstream terminals are not.
- fish no longer searches directories from the Windows system/user
$PATH environment variable for Linux executables. To execute Linux
binaries by name (i.e. not with a relative or absolute path) from a
Windows folder, make sure the /mnt/c/... path is explicitly added
to $fish_user_paths and not just automatically appended to
$PATH by wsl.exe (#10506
<https://github.com/fish-shell/fish-shell/issues/10506>).
- Under Microsoft Windows Subsystem for Linux 1 (not WSL 2), backgrounded
jobs that have not been disowned and do not terminate on their own after a
SIGHUP + SIGCONT sequence will be explicitly killed by fish
on exit (after the usual prompt to close or disown them) to work around a
WSL 1 deficiency that sees backgrounded processes that run into
SIGTTOU remain in a suspended state indefinitely (#5263
<https://github.com/fish-shell/fish-shell/issues/5263>). The
workaround is to explicitly disown processes you wish to outlive
the shell session.
Notable improvements and fixes
- •
- fish now requests XTerm's modifyOtherKeys keyboard encoding and
kitty keyboard protocol's
<https://sw.kovidgoyal.net/kitty/keyboard-protocol/>
progressive enhancements (#10359
<https://github.com/fish-shell/fish-shell/issues/10359>).
Depending on terminal support, this allows to binding more key
combinations, including arbitrary combinations of modifiers ctrl,
alt and shift, and distinguishing (for example)
ctrl-i from tab.
Additionally, bind now supports a human-readable syntax
in addition to byte sequences. This includes modifier names, and names
for keys like enter and backspace. For example
- bind up 'do something' binds the up-arrow key instead of a two-key
sequence ("u" and then "p")
- bind ctrl-x,alt-c 'do something' binds a sequence of two keys.
Any key argument that starts with an ASCII control character (like
\e or \cX) or is up to 3 characters long, not a named key, and
does not contain , or - will be interpreted in the old syntax
to keep compatibility for the majority of bindings.
Keyboard protocols can be turned off by disabling the
"keyboard-protocols" feature flag:
set -Ua fish_features no-keyboard-protocols
This is a temporary measure to work around buggy terminals
(#11056
<https://github.com/fish-shell/fish-shell/issues/11056>), which
appear to be relatively rare. Use this if something like "=0" or
"=5u" appears in your commandline mysteriously.
- •
- fish can now be built as a self-installing binary (#10367
<https://github.com/fish-shell/fish-shell/issues/10367>).
That means it can be easily built on one system and copied to another,
where it can extract supporting files. To do this, run:
cargo install --path . # in a clone of the fish repository
# or `cargo build --release` and copy target/release/fish{,_indent,_key_reader} wherever you want
The first time it runs interactively, it will extract all the data
files to ~/.local/share/fish/install/. A specific path can be used
for the data files with fish --install=PATH To uninstall, remove the
fish binaries and that directory.
This build system is experimental; the main build system, using
cmake, remains the recommended approach for packaging and
installation to a prefix.
- A new function fish_should_add_to_history can be overridden to
decide whether a command should be added to the history (#10302
<https://github.com/fish-shell/fish-shell/issues/10302>).
- Bindings can now mix special input functions and shell commands, so
bind ctrl-g expand-abbr "commandline -i \n" works as
expected (#8186
<https://github.com/fish-shell/fish-shell/issues/8186>).
- Special input functions run from bindings via commandline -f are
now applied immediately, instead of after the currently executing binding
(#3031
<https://github.com/fish-shell/fish-shell/issues/3031>,
#10126
<https://github.com/fish-shell/fish-shell/issues/10126>). For
example, commandline -i foo; commandline | grep foo succeeds
now.
- Undo history is no longer truncated after every command, but kept for the
lifetime of the shell process.
- The ctrl-r history search now uses glob syntax (#10131
<https://github.com/fish-shell/fish-shell/issues/10131>).
- The ctrl-r history search now operates only on the line or command
substitution at cursor, making it easier to combine commands from history
(#9751
<https://github.com/fish-shell/fish-shell/issues/9751>).
- Abbreviations can now be restricted to specific commands. For
instance:
abbr --add --command git back 'reset --hard HEAD^'
will expand "back" to reset --hard HEAD^, but
only when the command is git (#9411
<https://github.com/fish-shell/fish-shell/issues/9411>).
Deprecations and removed features
- commandline --tokenize (short option -o) has been deprecated
in favor of commandline --tokens-expanded (short option -x)
which expands variables and other shell syntax, removing the need to use
eval in completion scripts (#10212
<https://github.com/fish-shell/fish-shell/issues/10212>).
- Two new feature flags:
- remove-percent-self (see status features) disables PID
expansion of %self, which has been supplanted by $fish_pid
(#10262
<https://github.com/fish-shell/fish-shell/issues/10262>).
- test-require-arg disables test's one-argument mode. That
means test -n without an additional argument will return false,
test -z will keep returning true. Any other option without an
argument, anything that is not an option and no argument will be an error.
This also goes for [, test's alternate name. This is a frequent
source of confusion and so we are breaking with POSIX explicitly in this
regard. In addition to the feature flag, there is a debug category
"deprecated-test". Running fish with fish -d
deprecated-test will show warnings whenever a test invocation
that would change is used. (#10365
<https://github.com/fish-shell/fish-shell/issues/10365>).
These can be enabled with:
set -Ua fish_features remove-percent-self test-require-arg
We intend to enable them by default in future, and after that
eventually make them read-only.
- Specifying key names as terminfo names (using the bind -k syntax)
is deprecated and may be removed in a future version.
- When a terminal pastes text into fish using bracketed paste, fish used to
switch to a special paste bind mode. This bind mode has been
removed. The behavior on paste is no longer configurable.
- When an interactive fish is stopped or terminated by a signal that cannot
be caught (SIGSTOP or SIGKILL), it may leave the terminal in a state where
keypresses with modifiers are sent as CSI u sequences, instead of
traditional control characters or escape sequences that are recognized by
Readline and compatible programs, such as bash and python. If this
happens, you can use the reset command from ncurses to
restore the terminal state.
- fish_key_reader --verbose no longer shows timing information.
- Terminal information is no longer read from hashed terminfo databases, or
termcap databases (#10269
<https://github.com/fish-shell/fish-shell/issues/10269>). The
vast majority of systems use a non-hashed terminfo database, which is
still supported.
- source returns an error if used without a filename or
pipe/redirection (#10774
<https://github.com/fish-shell/fish-shell/issues/10774>).
Scripting improvements
- for loops will no longer remember local variables from the previous
iteration (#10525
<https://github.com/fish-shell/fish-shell/issues/10525>).
- A new history append subcommand appends a command to the history,
without executing it (#4506
<https://github.com/fish-shell/fish-shell/issues/4506>).
- A new redirection: <? /path/to/file will try opening the file as
input, and if it doesn't succeed silently uses /dev/null instead.
This can help with checks like test -f /path/to/file; and string
replace foo bar < /path/to/file. (#10387
<https://github.com/fish-shell/fish-shell/issues/10387>)
- A new option commandline --tokens-raw prints a list of tokens
without any unescaping (#10212
<https://github.com/fish-shell/fish-shell/issues/10212>).
- A new option commandline --showing-suggestion tests whether an
autosuggestion is currently displayed (#10586
<https://github.com/fish-shell/fish-shell/issues/10586>).
- functions and type now show that a function was copied and
its source, rather than solely Defined interactively (#6575
<https://github.com/fish-shell/fish-shell/issues/6575>).
- Stack trace now shows line numbers for copied functions (#6575
<https://github.com/fish-shell/fish-shell/issues/6575>).
- foo & && bar is now a syntax error, like in other
shells (#9911
<https://github.com/fish-shell/fish-shell/issues/9911>).
- if -e foo; end now prints a more accurate error (#10000
<https://github.com/fish-shell/fish-shell/issues/10000>).
- cd into a directory that is not readable but accessible
(permissions --x) is now possible (#10432
<https://github.com/fish-shell/fish-shell/issues/10432>).
- An integer overflow in string repeat leading to a near-infinite
loop has been fixed (#9899
<https://github.com/fish-shell/fish-shell/issues/9899>).
- string shorten behaves better in the presence of non-printable
characters, including fixing an integer overflow that shortened strings
more than intended (#9854
<https://github.com/fish-shell/fish-shell/issues/9854>).
- string pad no longer allows non-printable characters as padding
(#9854
<https://github.com/fish-shell/fish-shell/issues/9854>).
- string repeat now allows omission of -n when the first
argument is an integer (#10282
<https://github.com/fish-shell/fish-shell/issues/10282>).
- string match and replace have a new --max-matches
option to return as soon as the specified number of matches have been
identified, which can improve performance in scripts (#10587
<https://github.com/fish-shell/fish-shell/issues/10587>).
- functions --handlers-type caller-exit once again lists functions
defined as function --on-job-exit caller, rather than them being
listed by functions --handlers-type process-exit.
- A new set --no-event option sets or erases variables without
triggering a variable event. This can be useful to change a variable in an
event handler (#10480
<https://github.com/fish-shell/fish-shell/issues/10480>).
- Commas in command substitution output are no longer used as separators in
brace expansion, preventing a surprising expansion in some cases
(#5048
<https://github.com/fish-shell/fish-shell/issues/5048>).
- Universal variables can now store strings containing invalid UTF-8
(#10313
<https://github.com/fish-shell/fish-shell/issues/10313>).
- A new path basename -E option that causes it to return the basename
("filename" with the directory prefix removed) with the final
extension (if any) also removed. This is a shorter version of path
change-extension "" (path basename $foo) (#10521
<https://github.com/fish-shell/fish-shell/issues/10521>).
- A new math --scale-mode option to select truncate,
round, floor, ceiling as you wish; the default value
is truncate. (#9117
<https://github.com/fish-shell/fish-shell/issues/9117>).
- random is now less strict about its arguments, allowing a start
larger or equal to the end. (#10879
<https://github.com/fish-shell/fish-shell/issues/10879>)
- function --argument-names now produces an error if a read-only
variable name is used, rather than simply ignoring it (#10842
<https://github.com/fish-shell/fish-shell/issues/10842>).
- Tilde expansion in braces (that is, {~,}) works correctly
(#10610
<https://github.com/fish-shell/fish-shell/issues/10610>).
Interactive improvements
- Autosuggestions were sometimes not shown after recalling a line from
history, which has been fixed (#10287
<https://github.com/fish-shell/fish-shell/issues/10287>).
- Up-arrow search matches -- which are highlighted in reverse colors -- are
no longer syntax-highlighted, to fix bad contrast with the search match
highlighting.
- Command abbreviations (those with --position command or without a
--position) now also expand after decorators like command
(#10396
<https://github.com/fish-shell/fish-shell/issues/10396>).
- Abbreviations now expand after process separators like ; and
|. This fixes a regression in version 3.6 (#9730
<https://github.com/fish-shell/fish-shell/issues/9730>).
- When exporting interactively defined functions (using type,
functions or funcsave) the function body is now indented, to
match the interactive command line editor (#8603
<https://github.com/fish-shell/fish-shell/issues/8603>).
- ctrl-x (fish_clipboard_copy) on multiline commands now
includes indentation (#10437
<https://github.com/fish-shell/fish-shell/issues/10437>).
- ctrl-v (fish_clipboard_paste) now strips ASCII control
characters from the pasted text. This is consistent with normal keyboard
input (#5274
<https://github.com/fish-shell/fish-shell/issues/5274>).
- When a command like fg %2 fails to find the given job, it no longer
behaves as if no job spec was given (#9835
<https://github.com/fish-shell/fish-shell/issues/9835>).
- Redirection in command position like >echo is now highlighted as
error (#8877
<https://github.com/fish-shell/fish-shell/issues/8877>).
- fish_vi_cursor now works properly inside the prompt created by
builtin read (#10088
<https://github.com/fish-shell/fish-shell/issues/10088>).
- fish no longer fails to open a FIFO if interrupted by a terminal resize
signal (#10250
<https://github.com/fish-shell/fish-shell/issues/10250>).
- read --help and friends no longer ignore redirections. This fixes a
regression in version 3.1 (#10274
<https://github.com/fish-shell/fish-shell/issues/10274>).
- Measuring a command with time now considers the time taken for
command substitution (#9100
<https://github.com/fish-shell/fish-shell/issues/9100>).
- fish_add_path now automatically enables verbose mode when used
interactively (in the command line), in an effort to be clearer about what
it does (#10532
<https://github.com/fish-shell/fish-shell/issues/10532>).
- fish no longer adopts TTY modes of failed commands (#10603
<https://github.com/fish-shell/fish-shell/issues/10603>).
- complete -e cmd now prevents autoloading completions for cmd
(#6716
<https://github.com/fish-shell/fish-shell/issues/6716>).
- fish's default color scheme no longer uses the color "blue", as
it has bad contrast against the background in a few terminal's default
palettes (#10758
<https://github.com/fish-shell/fish-shell/issues/10758>,
#10786
<https://github.com/fish-shell/fish-shell/issues/10786>) The
color scheme will not be upgraded for existing installs. If you want, you
should select it again via fish_config.
- Command lines which are larger than the terminal are now displayed
correctly, instead of multiple blank lines being displayed (#7296
<https://github.com/fish-shell/fish-shell/issues/7296>).
- Prompts that use external commands will no longer produce an infinite loop
if the command crashes (#9796
<https://github.com/fish-shell/fish-shell/issues/9796>).
- Undo (ctrl-z) restores the cursor position too (#10838
<https://github.com/fish-shell/fish-shell/issues/10838>).
- The output of jobs shows "-" for jobs that have the same
process group ID as the fish process, rather than "-2"
(#10833
<https://github.com/fish-shell/fish-shell/issues/10833>).
- Job expansion (%1 syntax) works properly for jobs that are a
mixture of external commands and functions (#10832
<https://github.com/fish-shell/fish-shell/issues/10832>).
- Command lines which have more lines than the terminal can be displayed and
edited correctly (#10827
<https://github.com/fish-shell/fish-shell/issues/10827>).
- Functions that have been erased are no longer highlighted as valid
commands (#10866
<https://github.com/fish-shell/fish-shell/issues/10866>).
- not, time, and variable assignments (that is not time a=b
env) is correctly recognized as valid syntax (#10890
<https://github.com/fish-shell/fish-shell/issues/10890>).
- The Web-based configuration removes old right-hand-side prompts again,
fixing a regression in fish 3.4.0 (#10675
<https://github.com/fish-shell/fish-shell/issues/10675>).
- Further protection against programs which crash and leave the terminal in
an inconsistent state (#10834
<https://github.com/fish-shell/fish-shell/issues/10834>,
#11038
<https://github.com/fish-shell/fish-shell/issues/11038>).
- A workaround for git being very slow on macOS has been applied, improving
performance after a fresh boot (#10535
<https://github.com/fish-shell/fish-shell/issues/10535>).
New or improved bindings
- When the cursor is on a command that resolves to an executable script,
alt-o will now open that script in your editor (#10266
<https://github.com/fish-shell/fish-shell/issues/10266>).
- During up-arrow history search, shift-delete will delete the
current search item and move to the next older item. Previously this was
only supported in the history pager.
- shift-delete will also remove the currently-displayed
autosuggestion from history, and remove it as a suggestion.
- ctrl-Z (also known as ctrl-shift-z) is now bound to
redo.
- Some improvements to the alt-e binding which edits the command line
in an external editor: - The editor's cursor position is copied back to
fish. This is currently supported for Vim and Kakoune. - Cursor position
synchronization is only supported for a set of known editors, which are
now also detected in aliases which use complete --wraps. For
example, use complete --wraps my-vim vim to synchronize cursors
when EDITOR=my-vim. - Multiline commands are indented before being
sent to the editor, which matches how they are displayed in fish.
- The ...-path-component bindings, like
backward-kill-path-component, now treat # as part of a path
component (#10271
<https://github.com/fish-shell/fish-shell/issues/10271>).
- Bindings like alt-l that print output in between prompts now work
correctly with multiline commandlines.
- alt-d on an empty command line lists the directory history again.
This restores the behavior of version 2.1.
- history-prefix-search-backward and -forward now maintain the
cursor position, instead of moving the cursor to the end of the command
line (#10430
<https://github.com/fish-shell/fish-shell/issues/10430>).
- The following keys have refined behavior if the terminal supports the
new keyboard encodings: - shift-enter now inserts a newline
instead of executing the command line. - ctrl-backspace now deletes
the last word instead of only one character (#10741
<https://github.com/fish-shell/fish-shell/issues/10741>). -
ctrl-delete deletes the next word (same as alt-d).
- New special input functions: - forward-char-passive and
backward-char-passive are like their non-passive variants but do
not accept autosuggestions or move focus in the completion pager
(#10398
<https://github.com/fish-shell/fish-shell/issues/10398>). -
forward-token, backward-token, kill-token, and
backward-kill-token are similar to the *-bigword variants
but for the whole argument token (which includes escaped spaces)
(#2014
<https://github.com/fish-shell/fish-shell/issues/2014>). -
clear-commandline, which merely clears the command line, as an
alternative to cancel-commandline which prints ^C and a new
prompt (#10213
<https://github.com/fish-shell/fish-shell/issues/10213>).
- The accept-autosuggestion special input function now returns false
when there was nothing to accept (#10608
<https://github.com/fish-shell/fish-shell/issues/10608>).
- Vi mode has seen some improvements but continues to suffer from the lack
of people working on it. - New default cursor shapes for insert and
replace mode. - ctrl-n in insert mode accepts autosuggestions
(#10339
<https://github.com/fish-shell/fish-shell/issues/10339>). -
Outside insert mode, the cursor will no longer be placed beyond the last
character on the commandline. - When the cursor is at the end of the
commandline, a single l will accept an autosuggestion
(#10286
<https://github.com/fish-shell/fish-shell/issues/10286>). -
The cursor position after pasting (p) has been corrected. - Added
an additional binding, _, for moving to the beginning of the line
(#10720
<https://github.com/fish-shell/fish-shell/issues/10720>). -
When the cursor is at the start of a line, escaping from insert mode no
longer moves the cursor to the previous line. - Added bindings for
clipboard interaction, like ",+,p and ",+,y,y. -
Deleting in visual mode now moves the cursor back, matching vi
(#10394
<https://github.com/fish-shell/fish-shell/issues/10394>). -
The ;, ,, v, V, I, and gU
bindings work in visual mode (#10601
<https://github.com/fish-shell/fish-shell/issues/10601>,
#10648
<https://github.com/fish-shell/fish-shell/issues/10648>). -
Support % motion (#10593
<https://github.com/fish-shell/fish-shell/issues/10593>). -
ctrl-k to remove the contents of the line beyond the cursor in all
modes (#10648
<https://github.com/fish-shell/fish-shell/issues/10648>). -
Support ab and ib vi text objects. New input functions are
introduced jump-{to,till}-matching-bracket (#1842
<https://github.com/fish-shell/fish-shell/issues/1842>). -
The E binding now correctly handles the last character of the word,
by jumping to the next word (#9700
<https://github.com/fish-shell/fish-shell/issues/9700>).
- Command-specific tab completions may now offer results whose first
character is a period. For example, it is now possible to tab-complete
git add for files with leading periods. The default file
completions hide these files, unless the token itself has a leading period
(#3707
<https://github.com/fish-shell/fish-shell/issues/3707>).
- Option completion now uses fuzzy subsequence filtering, just like
non-option completion (#830
<https://github.com/fish-shell/fish-shell/issues/830>). This
means that --fb may be completed to --foobar if there is no
better match.
- Completions that insert an entire token now use quotes instead of
backslashes to escape special characters (#5433
<https://github.com/fish-shell/fish-shell/issues/5433>).
- Normally, file name completions start after the last : or =
in a token. This helps commands like rsync --files-from=. This
special meaning can now disabled by escaping these separators as \:
and \=. This matches Bash's behavior. Note that this escaping is
usually not necessary since the completion engine already tries to guess
whether the separator is actually part of a file name.
- Various new completion scripts and numerous updates to existing ones.
- Completions could hang if the PAGER environment variable was sent
to certain editors on macOS, FreeBSD and some other platforms. This has
been fixed (#10820
<https://github.com/fish-shell/fish-shell/issues/10820>).
- Generated completions are now stored in $XDG_CACHE_HOME/fish or
~/.cache/fish by default (#10369
<https://github.com/fish-shell/fish-shell/issues/10369>)
- A regression in fish 3.1, where completing a command line could change it
completely, has been fixed (#10904
<https://github.com/fish-shell/fish-shell/issues/10904>).
Improved terminal support
- fish now marks the prompt and command-output regions (via OSC 133) to
enable terminal shell integration (#10352
<https://github.com/fish-shell/fish-shell/issues/10352>).
Shell integration shortcuts can scroll to the next/previous prompt or show
the last command output in a pager.
- fish now reports the working directory (via OSC 7) unconditionally instead
of only for some terminals (#9955
<https://github.com/fish-shell/fish-shell/issues/9955>).
- fish now sets the terminal window title (via OSC 0) unconditionally
instead of only for some terminals (#10037
<https://github.com/fish-shell/fish-shell/issues/10037>).
- Focus reporting in tmux is no longer disabled on the first prompt.
- Focus reporting is now disabled during commands run inside key bindings
(#6942
<https://github.com/fish-shell/fish-shell/issues/6942>).
- Cursor changes are applied to all terminals that support them, and the
list of specifically-supported terminals has been removed (#10693
<https://github.com/fish-shell/fish-shell/issues/10693>).
- If it cannot find the terminfo entry given by TERM environment
variable, fish will now use an included xterm-256color definition
to match the vast majority of current terminal emulators (#10905
<https://github.com/fish-shell/fish-shell/issues/10905>). If
you need to have a specific terminfo profile for your terminal's
TERM variable, install it into the terminfo database.
- Further improvements to the correct display of prompts which fill the
width of the terminal (#8164
<https://github.com/fish-shell/fish-shell/issues/8164>).
Other improvements
- status gained a buildinfo subcommand, to print information
on how fish was built, to help with debugging (#10896
<https://github.com/fish-shell/fish-shell/issues/10896>).
- fish_indent will now collapse multiple empty lines into one
(#10325
<https://github.com/fish-shell/fish-shell/issues/10325>).
- fish_indent now preserves the modification time of files if there
were no changes (#10624
<https://github.com/fish-shell/fish-shell/issues/10624>).
- Performance in launching external processes has been improved for many
cases (#10869
<https://github.com/fish-shell/fish-shell/issues/10869>).
- Performance and interactivity under Windows Subsystem for Linux has been
improved, with a workaround for Windows-specific locations being appended
to $PATH by default (#10506
<https://github.com/fish-shell/fish-shell/issues/10506>).
- On macOS, paths from /etc/paths and /etc/manpaths containing
colons are handled correctly (#10684
<https://github.com/fish-shell/fish-shell/issues/10684>).
- Additional filesystems such as AFS are properly detected as remote, which
avoids certain hangs due to expensive filesystem locks (#10818
<https://github.com/fish-shell/fish-shell/issues/10818>).
- A spurious error when launching multiple instances of fish for the first
time has been removed (#10813
<https://github.com/fish-shell/fish-shell/issues/10813>).
For distributors
fish has been ported to Rust. This means a significant change in
dependencies, which are listed in the README. In short, Rust 1.70 or greater
is required, and a C++ compiler is no longer needed (although a C compiler
is still required, for some C glue code and the tests).
CMake remains the recommended build system, because of cargo's
limited support for installing support files. Version 3.5 remains the
minimum supported version. The Xcode generator for CMake is not supported
any longer (#9924
<https://github.com/fish-shell/fish-shell/issues/9924>). CMake
builds default to optimized release builds (#10799
<https://github.com/fish-shell/fish-shell/issues/10799>).
fish no longer depends on the ncurses library, but still uses a
terminfo database. When packaging fish, please add a dependency on the
package containing your terminfo database instead of curses.
The test target was removed as it can no longer be defined
in new CMake versions. Use make fish_run_tests. Any existing test
target will not print output if it fails (#11116
<https://github.com/fish-shell/fish-shell/issues/11116>).
The Web-based configuration has been rewritten to use Alpine.js
(#9554
<https://github.com/fish-shell/fish-shell/issues/9554>).
----
A number of improvements were included in fish 4.0.0 following the
beta release of 4.0b1. These include fixes for regressions, improvements to
completions and documentation, and the removal of a small number of
problematic changes.
The full list of fixed issues can be found on the GitHub
milestone page for 4.0-final
<https://github.com/fish-shell/fish-shell/milestone/43>.
----
This release of fish fixes the following problems identified in
fish 3.7.0:
- Deleting the last history entry via history delete works again
(#10190
<https://github.com/fish-shell/fish-shell/issues/10190>).
- Wildcards (*) will no longer sometimes generate paths that did not
exist (#10205
<https://github.com/fish-shell/fish-shell/issues/10205>).
This release also contains some improvements:
- A crash when trying to run an ELF program with a missing interpreter has
been fixed. This crashed in the process after fork, so did not affect the
fish process that tried to start the program (#10199
<https://github.com/fish-shell/fish-shell/issues/10199>).
- funced will now always source the file after it has written
it, even if the contents did not change. This prevents issues if the file
was otherwise modified (#10318
<https://github.com/fish-shell/fish-shell/issues/10318>).
- The warning for when a builtin returns a negative exit code was improved,
now mentioning the original status (#10187
<https://github.com/fish-shell/fish-shell/issues/10187>).
- Added completions for
- cobra-cli (#10293
<https://github.com/fish-shell/fish-shell/issues/10293>)
- dmidecode (#10368
<https://github.com/fish-shell/fish-shell/issues/10368>)
- mycli (#10309
<https://github.com/fish-shell/fish-shell/issues/10309>)
- ollama (#10327
<https://github.com/fish-shell/fish-shell/issues/10327>)
- pstree (#10317
<https://github.com/fish-shell/fish-shell/issues/10317>)
- •
- Some improvements to documentation and completions.
----
This release of fish includes a number of improvements over fish
3.6.4, detailed below. Although work continues on the porting of fish
internals to the Rust programming language, that work is not included in
this release. fish 3.7.0 and any future releases in the 3.7 series remain
C++ programs.
Notable improvements and fixes
- •
- Improvements to the history pager, including:
- The history pager will now also attempt subsequence matches (#9476
<https://github.com/fish-shell/fish-shell/issues/9476>), so
you can find a command line like git log 3.6.1..Integration_3.7.0
by searching for gitInt.
- Opening the history pager will now fill the search field with a search
string if you're already in a search (#10005
<https://github.com/fish-shell/fish-shell/issues/10005>).
This makes it nicer to search something with up and then later
decide to switch to the full pager.
- Closing the history pager with enter will now copy the search text to the
commandline if there was no match, so you can continue editing the command
you tried to find right away (#9934
<https://github.com/fish-shell/fish-shell/issues/9934>).
- Performance improvements for command completions and globbing, where
supported by the operating system, especially on slow filesystems such as
NFS (#9891
<https://github.com/fish-shell/fish-shell/issues/9891>,
#9931
<https://github.com/fish-shell/fish-shell/issues/9931>,
#10032
<https://github.com/fish-shell/fish-shell/issues/10032>,
#10052
<https://github.com/fish-shell/fish-shell/issues/10052>).
- fish can now be configured to wait a specified amount of time for a
multi-key sequence to be completed, instead of waiting indefinitely. For
example, this makes binding kj to switching modes in vi mode
possible. The timeout can be set via the new
fish_sequence_key_delay_ms variable (#7401
<https://github.com/fish-shell/fish-shell/issues/7401>), and
may be set by default in future versions.
Deprecations and removed features
- •
- LS_COLORS is no longer set automatically by the ls function
(#10080
<https://github.com/fish-shell/fish-shell/issues/10080>).
Users that set .dircolors should manually import it using other
means. Typically this would be set -gx LS_COLORS (dircolors -c
.dircolors | string split ' ')[3]
Scripting improvements
- Running exit with a negative number no longer crashes fish
(#9659
<https://github.com/fish-shell/fish-shell/issues/9659>).
- fish --command will now return a non-zero status if parsing failed
(#9888
<https://github.com/fish-shell/fish-shell/issues/9888>).
- The jobs builtin will now escape the commands it prints
(#9808
<https://github.com/fish-shell/fish-shell/issues/9808>).
- string repeat no longer overflows if the count is a multiple of the
chunk size (#9900
<https://github.com/fish-shell/fish-shell/issues/9900>).
- The builtin builtin will now properly error out with invalid
arguments instead of doing nothing and returning true (#9942
<https://github.com/fish-shell/fish-shell/issues/9942>).
- command time in a pipeline is allowed again, as is command
and and command or (#9985
<https://github.com/fish-shell/fish-shell/issues/9985>).
- exec will now also apply variable overrides, so FOO=bar exec
will now set $FOO correctly (#9995
<https://github.com/fish-shell/fish-shell/issues/9995>).
- umask will now handle empty symbolic modes correctly, like umask
u=,g=rwx,o= (#10177
<https://github.com/fish-shell/fish-shell/issues/10177>).
- Improved error messages for errors occurring in command substitutions
(#10054
<https://github.com/fish-shell/fish-shell/issues/10054>).
Interactive improvements
- read no longer enables bracketed paste so it doesn't stay enabled
in combined commandlines like mysql -p(read --silent) (#8285
<https://github.com/fish-shell/fish-shell/issues/8285>).
- Vi mode now uses fish_cursor_external to set the cursor shape for
external commands (#4656
<https://github.com/fish-shell/fish-shell/issues/4656>).
- Opening the history search in vi mode switches to insert mode correctly
(#10141
<https://github.com/fish-shell/fish-shell/issues/10141>).
- Vi mode cursor shaping is now enabled in iTerm2 (#9698
<https://github.com/fish-shell/fish-shell/issues/9698>).
- Completing commands as root includes commands not owned by root, fixing a
regression introduced in fish 3.2.0 (#9699
<https://github.com/fish-shell/fish-shell/issues/9699>).
- Selection uses fish_color_selection for the foreground and
background colors, as intended, rather than just the background
(#9717
<https://github.com/fish-shell/fish-shell/issues/9717>).
- The completion pager will no longer sometimes skip the last entry when
moving through a long list (#9833
<https://github.com/fish-shell/fish-shell/issues/9833>).
- The interactive history delete interface now allows specifying
index ranges like "1..5" (#9736
<https://github.com/fish-shell/fish-shell/issues/9736>), and
history delete --exact now properly saves the history
(#10066
<https://github.com/fish-shell/fish-shell/issues/10066>).
- Command completion will now call the stock manpath on macOS,
instead of a potential Homebrew version. This prevents awkward error
messages (#9817
<https://github.com/fish-shell/fish-shell/issues/9817>).
- the redo special input function restores the pre-undo cursor
position.
- A new bind function history-pager-delete, bound to
shift-delete by default, will delete the currently-selected history
pager item from history (#9454
<https://github.com/fish-shell/fish-shell/issues/9454>).
- fish_key_reader will now use printable characters as-is, so
pressing "ö" no longer leads to it telling you to bind
\u00F6 (#9986
<https://github.com/fish-shell/fish-shell/issues/9986>).
- open can be used to launch terminal programs again, as an
xdg-open bug has been fixed and a workaround has been removed
(#10045
<https://github.com/fish-shell/fish-shell/issues/10045>).
- The repaint-mode binding will now only move the cursor if there is
repainting to be done. This fixes alt combination bindings in vi
mode (#7910
<https://github.com/fish-shell/fish-shell/issues/7910>).
- A new clear-screen bind function is used for ctrl-l by
default. This clears the screen and repaints the existing prompt at first,
so it eliminates visible flicker unless the terminal is very slow
(#10044
<https://github.com/fish-shell/fish-shell/issues/10044>).
- The alias convenience function has better support for commands with
unusual characters, like + (#8720
<https://github.com/fish-shell/fish-shell/issues/8720>).
- A longstanding issue where items in the pager would sometimes display
without proper formatting has been fixed (#9617
<https://github.com/fish-shell/fish-shell/issues/9617>).
- The alt-l binding, which lists the directory of the token under the
cursor, correctly expands tilde (~) to the home directory
(#9954
<https://github.com/fish-shell/fish-shell/issues/9954>).
- Various fish utilities that use an external pager will now try a selection
of common pagers if the PAGER environment variable is not set, or
write the output to the screen without a pager if there is not one
available (#10074
<https://github.com/fish-shell/fish-shell/issues/10074>).
- Command-specific tab completions may now offer results whose first
character is a period. For example, it is now possible to tab-complete
git add for files with leading periods. The default file
completions hide these files, unless the token itself has a leading period
(#3707
<https://github.com/fish-shell/fish-shell/issues/3707>).
Improved prompts
- The default theme now only uses named colors, so it will track the
terminal's palette (#9913
<https://github.com/fish-shell/fish-shell/issues/9913>).
- The Dracula theme has now been synced with upstream (#9807
<https://github.com/fish-shell/fish-shell/issues/9807>); use
fish_config to re-apply it to pick up the changes.
- fish_vcs_prompt now also supports fossil (#9497
<https://github.com/fish-shell/fish-shell/issues/9497>).
- Prompts which display the working directory using the prompt_pwd
function correctly display directories beginning with dashes
(#10169
<https://github.com/fish-shell/fish-shell/issues/10169>).
- •
- Added completions for:
- age and age-keygen (#9813
<https://github.com/fish-shell/fish-shell/issues/9813>)
- airmon-ng (#10116
<https://github.com/fish-shell/fish-shell/issues/10116>)
- ar (#9720
<https://github.com/fish-shell/fish-shell/issues/9720>)
- blender (#9905
<https://github.com/fish-shell/fish-shell/issues/9905>)
- bws (#10165
<https://github.com/fish-shell/fish-shell/issues/10165>)
- calendar (#10138
<https://github.com/fish-shell/fish-shell/issues/10138>)
- checkinstall (#10106
<https://github.com/fish-shell/fish-shell/issues/10106>)
- crc (#10034
<https://github.com/fish-shell/fish-shell/issues/10034>)
- doctl
- gimp (#9904
<https://github.com/fish-shell/fish-shell/issues/9904>)
- gojq (#9740
<https://github.com/fish-shell/fish-shell/issues/9740>)
- horcrux (#9922
<https://github.com/fish-shell/fish-shell/issues/9922>)
- ibmcloud (#10004
<https://github.com/fish-shell/fish-shell/issues/10004>)
- iwctl (#6884
<https://github.com/fish-shell/fish-shell/issues/6884>)
- java_home (#9998
<https://github.com/fish-shell/fish-shell/issues/9998>)
- krita (#9903
<https://github.com/fish-shell/fish-shell/issues/9903>)
- oc (#10034
<https://github.com/fish-shell/fish-shell/issues/10034>)
- qjs (#9723
<https://github.com/fish-shell/fish-shell/issues/9723>)
- qjsc (#9731
<https://github.com/fish-shell/fish-shell/issues/9731>)
- rename (#10136
<https://github.com/fish-shell/fish-shell/issues/10136>)
- rpm-ostool (#9669
<https://github.com/fish-shell/fish-shell/issues/9669>)
- smerge (#10135
<https://github.com/fish-shell/fish-shell/issues/10135>)
- userdel (#10056
<https://github.com/fish-shell/fish-shell/issues/10056>)
- watchexec (#10027
<https://github.com/fish-shell/fish-shell/issues/10027>)
- wpctl (#10043
<https://github.com/fish-shell/fish-shell/issues/10043>)
- xxd (#10137
<https://github.com/fish-shell/fish-shell/issues/10137>)
- zabbix (#9647
<https://github.com/fish-shell/fish-shell/issues/9647>)
- The zfs completions no longer print errors about setting a
read-only variable (#9705
<https://github.com/fish-shell/fish-shell/issues/9705>).
- The kitty completions have been removed in favor of keeping them
upstream (#9750
<https://github.com/fish-shell/fish-shell/issues/9750>).
- git completions now support aliases that reference other aliases
(#9992
<https://github.com/fish-shell/fish-shell/issues/9992>).
- The gw and gradlew completions are loaded properly
(#10127
<https://github.com/fish-shell/fish-shell/issues/10127>).
- Improvements to many other completions.
- Improvements to the manual page completion generator (#9787
<https://github.com/fish-shell/fish-shell/issues/9787>,
#9814
<https://github.com/fish-shell/fish-shell/issues/9814>,
#9961
<https://github.com/fish-shell/fish-shell/issues/9961>).
Other improvements
- Improvements and corrections to the documentation.
- The Web-based configuration now uses a more readable style when printed,
such as for a keybinding reference (#9828
<https://github.com/fish-shell/fish-shell/issues/9828>).
- Updates to the German translations (#9824
<https://github.com/fish-shell/fish-shell/issues/9824>).
- The colors of the Nord theme better match their official style
(#10168
<https://github.com/fish-shell/fish-shell/issues/10168>).
For distributors
- The licensing information for some of the derived code distributed with
fish was incomplete. Though the license information was present in the
source distribution, it was not present in the documentation. This has
been corrected (#10162
<https://github.com/fish-shell/fish-shell/issues/10162>).
- The CMake configure step will now also look for libterminfo as an
alternative name for libtinfo, as used in NetBSD curses (#9794
<https://github.com/fish-shell/fish-shell/issues/9794>).
----
This release contains a complete fix for the test suite failure in
fish 3.6.2 and 3.6.3.
----
This release contains a fix for a test suite failure in fish
3.6.2.
----
This release of fish contains a security fix for CVE-2023-49284, a
minor security problem identified in fish 3.6.1 and previous versions
(thought to affect all released versions of fish).
fish uses certain Unicode non-characters internally for marking
wildcards and expansions. It incorrectly allowed these markers to be read on
command substitution output, rather than transforming them into a safe
internal representation.
For example, echo \UFDD2HOME has the same output as echo
$HOME.
While this may cause unexpected behavior with direct input, this
may become a minor security problem if the output is being fed from an
external program into a command substitution where this output may not be
expected.
----
This release of fish contains a number of fixes for problems
identified in fish 3.6.1, as well as some enhancements.
Notable improvements and fixes
- •
- abbr --erase now also erases the universal variables used by the
old abbr function. That means:
abbr --erase (abbr --list)
can now be used to clean out all old abbreviations (#9468
<https://github.com/fish-shell/fish-shell/issues/9468>).
- •
- abbr --add --universal now warns about --universal being
non-functional, to make it easier to detect old-style abbr calls
(#9475
<https://github.com/fish-shell/fish-shell/issues/9475>).
Deprecations and removed features
- •
- The Web-based configuration for abbreviations has been removed, as it was
not functional with the changes abbreviations introduced in 3.6.0
(#9460
<https://github.com/fish-shell/fish-shell/issues/9460>).
Scripting improvements
- abbr --list no longer escapes the abbr name, which is necessary to
be able to pass it to abbr --erase (#9470
<https://github.com/fish-shell/fish-shell/issues/9470>).
- read will now print an error if told to set a read-only variable,
instead of silently doing nothing (#9346
<https://github.com/fish-shell/fish-shell/issues/9346>).
- set_color -v no longer crashes fish (#9640
<https://github.com/fish-shell/fish-shell/issues/9640>).
Interactive improvements
- Using fish_vi_key_bindings in combination with fish's
--no-config mode works without locking up the shell (#9443
<https://github.com/fish-shell/fish-shell/issues/9443>).
- The history pager now uses more screen space, usually half the screen
(#9458
<https://github.com/fish-shell/fish-shell/issues/9458>)
- Variables that were set while the locale was C (the default ASCII-only
locale) will now properly be encoded if the locale is switched
(#2613
<https://github.com/fish-shell/fish-shell/issues/2613>,
#9473
<https://github.com/fish-shell/fish-shell/issues/9473>).
- Escape during history search restores the original command line again
(fixing a regression in 3.6.0).
- Using --help on builtins now respects the $MANPAGER
variable, in preference to $PAGER (#9488
<https://github.com/fish-shell/fish-shell/issues/9488>).
- ctrl-g closes the history pager, like other shells (#9484
<https://github.com/fish-shell/fish-shell/issues/9484>).
- The documentation for the :, [ and . builtin commands
can now be looked up with man (#9552
<https://github.com/fish-shell/fish-shell/issues/9552>).
- fish no longer crashes when searching history for non-ASCII codepoints
case-insensitively (#9628
<https://github.com/fish-shell/fish-shell/issues/9628>).
- The alt-s binding will now also use please if available
(#9635
<https://github.com/fish-shell/fish-shell/issues/9635>).
- Themes that don't specify every color option can be installed correctly in
the Web-based configuration (#9590
<https://github.com/fish-shell/fish-shell/issues/9590>).
- Compatibility with Midnight Commander's prompt integration has been
improved (#9540
<https://github.com/fish-shell/fish-shell/issues/9540>).
- A spurious error, noted when using fish in Google Drive directories under
WSL 2, has been silenced (#9550
<https://github.com/fish-shell/fish-shell/issues/9550>).
- Using read in fish_greeting or similar functions will not
trigger an infinite loop (#9564
<https://github.com/fish-shell/fish-shell/issues/9564>).
- Compatibility when upgrading from old versions of fish (before 3.4.0) has
been improved (#9569
<https://github.com/fish-shell/fish-shell/issues/9569>).
Improved prompts
- •
- The git prompt will compute the stash count to be used independently of
the informative status (#9572
<https://github.com/fish-shell/fish-shell/issues/9572>).
- •
- Added completions for:
- apkanalyzer (#9558
<https://github.com/fish-shell/fish-shell/issues/9558>)
- neovim (#9543
<https://github.com/fish-shell/fish-shell/issues/9543>)
- otool
- pre-commit (#9521
<https://github.com/fish-shell/fish-shell/issues/9521>)
- proxychains (#9486
<https://github.com/fish-shell/fish-shell/issues/9486>)
- scrypt (#9583
<https://github.com/fish-shell/fish-shell/issues/9583>)
- stow (#9571
<https://github.com/fish-shell/fish-shell/issues/9571>)
- trash and helper utilities trash-empty, trash-list,
trash-put, trash-restore (#9560
<https://github.com/fish-shell/fish-shell/issues/9560>)
- ssh-copy-id (#9675
<https://github.com/fish-shell/fish-shell/issues/9675>)
- Improvements to many completions, including the speed of completing
directories in WSL 2 (#9574
<https://github.com/fish-shell/fish-shell/issues/9574>).
- Completions using __fish_complete_suffix are now offered in the
correct order, fixing a regression in 3.6.0 (#8924
<https://github.com/fish-shell/fish-shell/issues/8924>).
- git completions for git-foo-style commands was restored,
fixing a regression in 3.6.0 (#9457
<https://github.com/fish-shell/fish-shell/issues/9457>).
- File completion now offers ../ and ./ again, fixing a
regression in 3.6.0 (#9477
<https://github.com/fish-shell/fish-shell/issues/9477>).
- The behaviour of completions using __fish_complete_path matches
standard path completions (#9285
<https://github.com/fish-shell/fish-shell/issues/9285>).
Other improvements
- •
- Improvements and corrections to the documentation.
For distributors
- •
- fish 3.6.1 builds correctly on Cygwin (#9502
<https://github.com/fish-shell/fish-shell/issues/9502>).
----
Notable improvements and fixes
- By default, ctrl-r now opens the command history in the pager
(#602
<https://github.com/fish-shell/fish-shell/issues/602>). This
is fully searchable and syntax-highlighted, as an alternative to the
incremental search seen in other shells. The new special input function
history-pager has been added for custom bindings.
- Abbrevations are more flexible (#9313
<https://github.com/fish-shell/fish-shell/issues/9313>,
#5003
<https://github.com/fish-shell/fish-shell/issues/5003>,
#2287
<https://github.com/fish-shell/fish-shell/issues/2287>):
- They may optionally replace tokens anywhere on the command line, instead
of only commands
- Matching tokens may be described using a regular expression instead of a
literal word
- The replacement text may be produced by a fish function, instead of a
literal word
- They may position the cursor anywhere in the expansion, instead of at the
end
For example:
function multicd
echo cd (string repeat -n (math (string length -- $argv[1]) - 1) ../)
end
abbr --add dotdot --regex '^\.\.+$' --function multicd
This expands .. to cd ../, ... to cd
../../ and .... to cd ../../../ and so on.
Or:
function last_history_item; echo $history[1]; end
abbr -a !! --position anywhere --function last_history_item
which expands !! to the last history item, anywhere on the
command line, mimicking other shells' history expansion.
See the documentation for more.
- •
- path gained a new mtime subcommand to print the modification
time stamp for files. For example, this can be used to handle cache file
ages (#9057
<https://github.com/fish-shell/fish-shell/issues/9057>):
> touch foo
> sleep 10
> path mtime --relative foo
10
- •
- string gained a new shorten subcommand to shorten strings to
a given visible width (#9156
<https://github.com/fish-shell/fish-shell/issues/9156>):
> string shorten --max 10 "Hello this is a long string"
Hello thi…
- test (aka [) gained -ot (older than) and -nt
(newer than) operators to compare file modification times, and -ef
to compare whether the arguments are the same file (#3589
<https://github.com/fish-shell/fish-shell/issues/3589>).
- fish will now mark the extent of many errors with a squiggly line, instead
of just a caret (^) at the beginning (#9130
<https://github.com/fish-shell/fish-shell/issues/9130>). For
example:
checks/set.fish (line 471): for: a,b: invalid variable name. See `help identifiers`
for a,b in y 1 z 3
^~^
- A new function, fish_delta, shows changes that have been made in
fish's configuration from the defaults (#9255
<https://github.com/fish-shell/fish-shell/issues/9255>).
- set --erase can now be used with multiple scopes at once, like
set -efglU foo (#7711
<https://github.com/fish-shell/fish-shell/issues/7711>,
#9280
<https://github.com/fish-shell/fish-shell/issues/9280>).
- status gained a new subcommand, current-commandline, which
retrieves the entirety of the currently-executing command line when called
from a function during execution. This allows easier job introspection
(#8905
<https://github.com/fish-shell/fish-shell/issues/8905>,
#9296
<https://github.com/fish-shell/fish-shell/issues/9296>).
Deprecations and removed features
- The \x and \X escape syntax is now equivalent. \xAB
previously behaved the same as \XAB, except that it would error if
the value "AB" was larger than "7f" (127 in decimal,
the highest ASCII value) (#9247
<https://github.com/fish-shell/fish-shell/issues/9247>,
#9245
<https://github.com/fish-shell/fish-shell/issues/9245>,
#1352
<https://github.com/fish-shell/fish-shell/issues/1352>).
- The fish_git_prompt will now only turn on features if the
appropriate variable has been set to a true value (of "1",
"yes" or "true") instead of just checking if it is
defined. This allows specifically turning features off without
having to erase variables, such as via universal variables. If you have
defined a variable to a different value and expect it to count as true,
you need to change it (#9274
<https://github.com/fish-shell/fish-shell/issues/9274>). For
example, set -g __fish_git_prompt_show_informative_status 0
previously would have enabled informative status (because any value would
have done so), but now it turns it off.
- Abbreviations are no longer stored in universal variables. Existing
universal abbreviations are still imported, but new abbreviations should
be added to config.fish.
- The short option -r for abbreviations has changed from
rename to regex, for consistency with string.
Scripting improvements
- •
- argparse can now be used without option specifications, to allow
using --min-args, --max-args or for commands that take no
options (but might in future) (#9006
<https://github.com/fish-shell/fish-shell/issues/9006>):
function my_copy
argparse --min-args 2 -- $argv
or return
cp $argv
end
- •
- set --show now shows when a variable was inherited from fish's
parent process, which should help with debugging (#9029
<https://github.com/fish-shell/fish-shell/issues/9029>):
> set --show XDG_DATA_DIRS
$XDG_DATA_DIRS: set in global scope, exported, a path variable with 4 elements
$XDG_DATA_DIRS[1]: |/home/alfa/.local/share/flatpak/exports/share|
$XDG_DATA_DIRS[2]: |/var/lib/flatpak/exports/share|
$XDG_DATA_DIRS[3]: |/usr/local/share|
$XDG_DATA_DIRS[4]: |/usr/share|
$XDG_DATA_DIRS: originally inherited as |/home/alfa/.local/share/flatpak/exports/share:/var/lib/flatpak/exports/share:/usr/local/share/:/usr/share/|
- The read limit is now restored to the default when fish_read_limit
is unset (#9129
<https://github.com/fish-shell/fish-shell/issues/9129>).
- math produces an error for division-by-zero, as well as augmenting
some errors with their extent (#9190
<https://github.com/fish-shell/fish-shell/issues/9190>). This
changes behavior in some limited cases, such as:
which would previously print "5" (because in floating
point division "1 / 0" yields infinite, and 5 is smaller than
infinite) but will now return an error.
- •
- fish_clipboard_copy and fish_clipboard_paste can now be used
in pipes (#9271
<https://github.com/fish-shell/fish-shell/issues/9271>):
git rev-list 3.5.1 | fish_clipboard_copy
fish_clipboard_paste | string join + | math
- •
- status fish-path returns a fully-normalised path, particularly
noticeable on NetBSD (#9085
<https://github.com/fish-shell/fish-shell/issues/9085>).
Interactive improvements
- If the terminal definition for TERM can't be found, fish now tries
using the "xterm-256color" and "xterm" definitions
before "ansi" and "dumb". As the majority of terminal
emulators in common use are now more or less xterm-compatible (often even
explicitly claiming the xterm-256color entry), this should often result in
a fully or almost fully usable terminal (#9026
<https://github.com/fish-shell/fish-shell/issues/9026>).
- A new variable, fish_cursor_selection_mode, can be used to
configure whether the command line selection includes the character under
the cursor (inclusive) or not (exclusive). The new default
is exclusive; use set fish_cursor_selection_mode inclusive
to get the previous behavior back (#7762
<https://github.com/fish-shell/fish-shell/issues/7762>).
- fish's completion pager now fills half the terminal on first tab press
instead of only 4 rows, which should make results visible more often and
save key presses, without constantly snapping fish to the top of the
terminal (#9105
<https://github.com/fish-shell/fish-shell/issues/9105>,
#2698
<https://github.com/fish-shell/fish-shell/issues/2698>).
- The complete-and-search binding, used with shift-tab by
default, selects the first item in the results immediately (#9080
<https://github.com/fish-shell/fish-shell/issues/9080>).
- bind output is now syntax-highlighted when used interacively.
- alt-h (the default __fish_man_page binding) does a better
job of showing the manual page of the command under cursor (#9020
<https://github.com/fish-shell/fish-shell/issues/9020>).
- If fish_color_valid_path contains an actual color instead of just
modifiers, those will be used for valid paths even if the underlying color
isn't "normal" (#9159
<https://github.com/fish-shell/fish-shell/issues/9159>).
- The key combination for the QUIT terminal sequence, often ctrl-\
(\x1c), can now be used as a binding (#9234
<https://github.com/fish-shell/fish-shell/issues/9234>).
- fish's vi mode uses normal xterm-style sequences to signal cursor change,
instead of using the iTerm's proprietary escape sequences. This allows for
a blinking cursor and makes it work in complicated scenarios with nested
terminals. (#3741
<https://github.com/fish-shell/fish-shell/issues/3741>,
#9172
<https://github.com/fish-shell/fish-shell/issues/9172>)
- When running fish on a remote system (such as inside SSH or a container),
ctrl-x now copies to the local client system's clipboard if the
terminal supports OSC 52.
- commandline gained two new options, --selection-start and
--selection-end, to set the start/end of the current selection
(#9197
<https://github.com/fish-shell/fish-shell/issues/9197>,
#9215
<https://github.com/fish-shell/fish-shell/issues/9215>).
- fish's builtins now handle keyboard interrupts (ctrl-c) correctly
(#9266
<https://github.com/fish-shell/fish-shell/issues/9266>).
- •
- Added completions for:
- ark
- asciinema (#9257
<https://github.com/fish-shell/fish-shell/issues/9257>)
- clojure (#9272
<https://github.com/fish-shell/fish-shell/issues/9272>)
- csh
- direnv (#9268
<https://github.com/fish-shell/fish-shell/issues/9268>)
- dive (#9082
<https://github.com/fish-shell/fish-shell/issues/9082>)
- dolphin
- dua (#9277
<https://github.com/fish-shell/fish-shell/issues/9277>)
- efivar (#9318
<https://github.com/fish-shell/fish-shell/issues/9318>)
- eg
- es (#9388
<https://github.com/fish-shell/fish-shell/issues/9388>)
- firefox-developer-edition and firefox (#9090
<https://github.com/fish-shell/fish-shell/issues/9090>)
- fortune (#9177
<https://github.com/fish-shell/fish-shell/issues/9177>)
- kb
- kind (#9110
<https://github.com/fish-shell/fish-shell/issues/9110>)
- konsole
- ksh
- loadkeys (#9312
<https://github.com/fish-shell/fish-shell/issues/9312>)
- okular
- op (#9300
<https://github.com/fish-shell/fish-shell/issues/9300>)
- ouch (#9405
<https://github.com/fish-shell/fish-shell/issues/9405>)
- pix
- readelf (#8746
<https://github.com/fish-shell/fish-shell/issues/8746>,
#9386
<https://github.com/fish-shell/fish-shell/issues/9386>)
- qshell
- rc
- sad (#9145
<https://github.com/fish-shell/fish-shell/issues/9145>)
- tcsh
- toot
- tox (#9078
<https://github.com/fish-shell/fish-shell/issues/9078>)
- wish
- xed
- xonsh (#9389
<https://github.com/fish-shell/fish-shell/issues/9389>)
- xplayer
- xreader
- xviewer
- yash (#9391
<https://github.com/fish-shell/fish-shell/issues/9391>)
- zig (#9083
<https://github.com/fish-shell/fish-shell/issues/9083>)
- Improvements to many completions, including making cd completion
much faster (#9220
<https://github.com/fish-shell/fish-shell/issues/9220>).
- Completion of tilde (~) works properly even when the file name
contains an escaped character (#9073
<https://github.com/fish-shell/fish-shell/issues/9073>).
- fish no longer loads completions if the command is used via a relative
path and is not in PATH (#9133
<https://github.com/fish-shell/fish-shell/issues/9133>).
- fish no longer completes inside of comments (#9320
<https://github.com/fish-shell/fish-shell/issues/9320>).
Improved terminal support
- •
- Opening help on WSL now uses PowerShell to open the browser if
available, removing some awkward UNC path errors (#9119
<https://github.com/fish-shell/fish-shell/issues/9119>).
Other improvements
- The Web-based configuration tool now works on systems with IPv6 disabled
(#3857
<https://github.com/fish-shell/fish-shell/issues/3857>).
- Aliases can ignore arguments by ending them with # (#9199
<https://github.com/fish-shell/fish-shell/issues/9199>).
- string is now faster when reading large strings from stdin
(#9139
<https://github.com/fish-shell/fish-shell/issues/9139>).
- string repeat uses less memory and is faster. (#9124
<https://github.com/fish-shell/fish-shell/issues/9124>)
- Builtins are much faster when writing to a pipe or file. (#9229
<https://github.com/fish-shell/fish-shell/issues/9229>).
- Performance improvements to highlighting (#9180
<https://github.com/fish-shell/fish-shell/issues/9180>)
should make using fish more pleasant on slow systems.
- On 32-bit systems, globs like * will no longer fail to return some
files, as large file support has been enabled.
- The history search text for a token search is now highlighted correctly if
the line contains multiple instances of that text (#9066
<https://github.com/fish-shell/fish-shell/issues/9066>).
- process-exit and job-exit events are now generated for all
background jobs, including those launched from event handlers
(#9096
<https://github.com/fish-shell/fish-shell/issues/9096>).
- A crash when completing a token that contained both a potential glob and a
quoted variable expansion was fixed (#9137
<https://github.com/fish-shell/fish-shell/issues/9137>).
- prompt_pwd no longer accidentally overwrites a global or universal
$fish_prompt_pwd_full_dirs when called with the -d or
--full-length-dirs option (#9123
<https://github.com/fish-shell/fish-shell/issues/9123>).
- A bug which caused fish to freeze or exit after running a command which
does not preserve the foreground process group was fixed (#9181
<https://github.com/fish-shell/fish-shell/issues/9181>).
- The "Disco" sample prompt no longer prints an error in some
working directories (#9164
<https://github.com/fish-shell/fish-shell/issues/9164>). If
you saved this prompt, you should run fish_config prompt save disco
again.
- fish launches external commands via the given path again, rather than
always using an absolute path. This behaviour was inadvertently changed in
3.5.0 and is visible, for example, when launching a bash script which
checks $0 (#9143
<https://github.com/fish-shell/fish-shell/issues/9143>).
- printf no longer tries to interpret the first argument as an option
(#9132
<https://github.com/fish-shell/fish-shell/issues/9132>).
- Interactive read in scripts will now have the correct keybindings
again (#9227
<https://github.com/fish-shell/fish-shell/issues/9227>).
- A possible stack overflow when recursively evaluating substitutions has
been fixed (#9302
<https://github.com/fish-shell/fish-shell/issues/9302>).
- A crash with relative $CDPATH has been fixed (#9407
<https://github.com/fish-shell/fish-shell/issues/9407>).
- printf now properly fills extra %d specifiers with 0 even on
macOS and BSD (#9321
<https://github.com/fish-shell/fish-shell/issues/9321>).
- fish_key_reader now correctly exits when receiving a SIGHUP (like
after closing the terminal) (#9309
<https://github.com/fish-shell/fish-shell/issues/9309>).
- fish_config theme save now works as documented instead of erroring
out (#9088
<https://github.com/fish-shell/fish-shell/issues/9088>,
#9273
<https://github.com/fish-shell/fish-shell/issues/9273>).
- fish no longer triggers prompts to install command line tools when first
run on macOS (#9343
<https://github.com/fish-shell/fish-shell/issues/9343>).
- fish_git_prompt now quietly fails on macOS if the xcrun cache is
not yet populated (#6625
<https://github.com/fish-shell/fish-shell/issues/6625>),
working around a potential hang.
For distributors
- •
- The vendored PCRE2 sources have been removed. It is recommended to declare
PCRE2 as a dependency when packaging fish. If the CMake variable
FISH_USE_SYSTEM_PCRE2 is false, fish will now download and build PCRE2
from the official repo (#8355
<https://github.com/fish-shell/fish-shell/issues/8355>,
#8363
<https://github.com/fish-shell/fish-shell/issues/8363>). Note
this variable defaults to true if PCRE2 is found installed on the
system.
----
This release of fish introduces the following small
enhancements:
- Cursor shaping for Vi mode is enabled by default in tmux, and will be used
if the outer terminal is capable (#8981
<https://github.com/fish-shell/fish-shell/issues/8981>).
- printf returns a better error when used with arguments interpreted
as octal numbers (#9035
<https://github.com/fish-shell/fish-shell/issues/9035>).
- history merge when in private mode is now an error, rather than
wiping out other sessions' history (#9050
<https://github.com/fish-shell/fish-shell/issues/9050>).
- The error message when launching a command that is built for the wrong
architecture on macOS is more helpful (#9052
<https://github.com/fish-shell/fish-shell/issues/9052>).
- Added completions for:
- choose (#9065
<https://github.com/fish-shell/fish-shell/issues/9065>)
- expect (#9060
<https://github.com/fish-shell/fish-shell/issues/9060>)
- navi (#9064
<https://github.com/fish-shell/fish-shell/issues/9064>)
- qdbus (#9031
<https://github.com/fish-shell/fish-shell/issues/9031>)
- reflector (#9027
<https://github.com/fish-shell/fish-shell/issues/9027>)
- •
- Improvements to some completions.
This release also fixes a number of problems identified in fish
3.5.0.
- Completing git blame or git -C works correctly (#9053
<https://github.com/fish-shell/fish-shell/issues/9053>).
- On terminals that emit a CSI u sequence for shift-space,
fish inserts a space instead of printing an error. (#9054
<https://github.com/fish-shell/fish-shell/issues/9054>).
- status fish-path on Linux-based platforms could print the path with
a " (deleted)" suffix (such as /usr/bin/fish (deleted)),
which is now removed (#9019
<https://github.com/fish-shell/fish-shell/issues/9019>).
- Cancelling an initial command (from fish's --init-command option)
with ctrl-c no longer prevents configuration scripts from running
(#9024
<https://github.com/fish-shell/fish-shell/issues/9024>).
- The job summary contained extra blank lines if the prompt used multiple
lines, which is now fixed (#9044
<https://github.com/fish-shell/fish-shell/issues/9044>).
- Using special input functions in bindings, in combination with
and/or conditionals, no longer crashes (#9051
<https://github.com/fish-shell/fish-shell/issues/9051>).
----
Notable improvements and fixes
- •
- A new path builtin command to filter and transform paths
(#7659
<https://github.com/fish-shell/fish-shell/issues/7659>,
#8958
<https://github.com/fish-shell/fish-shell/issues/8958>). For
example, to list all the separate extensions used on files in
/usr/share/man (after removing one extension, commonly a
".gz"):
path filter -f /usr/share/man/** | path change-extension '' | path extension | path sort -u
- Tab (or any key bound to complete) now expands wildcards instead of
invoking completions, if there is a wildcard in the path component under
the cursor (#954
<https://github.com/fish-shell/fish-shell/issues/954>,
#8593
<https://github.com/fish-shell/fish-shell/issues/8593>).
- Scripts can now catch and handle the SIGINT and SIGTERM signals, either
via function --on-signal or with trap (#6649
<https://github.com/fish-shell/fish-shell/issues/6649>).
Deprecations and removed features
- •
- The stderr-nocaret feature flag, introduced in fish 3.0 and enabled
by default in fish 3.1, has been made read-only. That means it is no
longer possible to disable it, and code supporting the ^
redirection has been removed (#8857
<https://github.com/fish-shell/fish-shell/issues/8857>,
#8865
<https://github.com/fish-shell/fish-shell/issues/8865>).
To recap: fish used to support ^ to redirect stderr, so
you could use commands like:
test "$foo" -gt 8 ^/dev/null
to ignore error messages. This made the ^ symbol require
escaping and quoting, and was a bit of a weird shortcut considering
2> already worked, which is only one character longer.
So the above can simply become:
test "$foo" -gt 8 2>/dev/null
- •
- The following feature flags have been enabled by default:
- regex-easyesc, which makes string replace -r not do a
superfluous round of unescaping in the replacement expression. That means
e.g. to escape any "a" or "b" in an argument you can
use string replace -ra '([ab])' '\\\\$1' foobar instead of needing
8 backslashes.
This only affects the replacement expression, not the
match expression (the '([ab])' part in the example). A
survey of plugins on GitHub did not turn up any affected code, so we do
not expect this to affect many users.
This flag was introduced in fish 3.1.
- ampersand-nobg-in-token, which means that & will not
create a background job if it occurs in the middle of a word. For example,
echo foo&bar will print "foo&bar" instead of
running echo foo in the background and then starting bar as
a second job.
Reformatting with fish_indent would already introduce
spaces, turning echo foo&bar into echo foo &
bar.
This flag was introduced in fish 3.4.
To turn off these flags, add no-regex-easyesc or
no-ampersand-nobg-in-token to fish_features and restart
fish:
set -Ua fish_features no-regex-easyesc
Like stderr-nocaret, they will eventually be made
read-only.
- Most string subcommands no longer append a newline to their input
if the input didn't have one (#8473
<https://github.com/fish-shell/fish-shell/issues/8473>,
#3847
<https://github.com/fish-shell/fish-shell/issues/3847>)
- Fish's escape sequence removal (like for string length --visible or
to figure out how wide the prompt is) no longer has special support for
non-standard color sequences like from Data General terminals, e.g. the
Data General Dasher D220 from 1984. This removes a bunch of work in the
common case, allowing string length --visible to be much faster
with unknown escape sequences. We don't expect anyone to have ever used
fish with such a terminal (#8769
<https://github.com/fish-shell/fish-shell/issues/8769>).
- Code to upgrade universal variables from fish before 3.0 has been removed.
Users who upgrade directly from fish versions 2.7.1 or before will have to
set their universal variables & abbreviations again. (#8781
<https://github.com/fish-shell/fish-shell/issues/8781>)
- The meaning of an empty color variable has changed (#8793
<https://github.com/fish-shell/fish-shell/issues/8793>).
Previously, when a variable was set but empty, it would be interpreted as
the "normal" color. Now, empty color variables cause the same
effect as unset variables - the general highlighting variable for that
type is used instead. For example:
set -g fish_color_command blue
set -g fish_color_keyword
would previously make keywords "normal" (usually white
in a dark terminal). Now it'll make them blue. To achieve the previous
behavior, use the normal color explicitly: set -g fish_color_keyword
normal.
This makes it easier to make self-contained color schemes that
don't accidentally use color that was set before. fish_config has
been adjusted to set known color variables that a theme doesn't explicitly
set to empty.
- eval is now a reserved keyword, so it can't be used as a function
name. This follows set and read, and is necessary because it
can't be cleanly shadowed by a function - at the very least eval set -l
argv foo breaks. Fish will ignore autoload files for it, so left over
eval.fish from previous fish versions won't be loaded.
- The git prompt in informative mode now defaults to skipping counting
untracked files, as this was extremely slow. To turn it on, set
__fish_git_prompt_showuntrackedfiles or set the git config value
"bash.showuntrackedfiles" to true explicitly (which can
be done for individual repositories). The "informative+vcs"
sample prompt already skipped display of untracked files, but didn't do so
in a way that skipped the computation, so it should be quite a bit faster
in many cases (#8980
<https://github.com/fish-shell/fish-shell/issues/8980>).
- The __terlar_git_prompt function, used by the "Terlar"
sample prompt, has been rebuilt as a configuration of the normal
fish_git_prompt to ease maintenance, improve performance and add
features (like reading per-repo git configuration). Some slight changes
remain; users who absolutely must have the same behavior are encouraged to
copy the old function (#9011
<https://github.com/fish-shell/fish-shell/issues/9011>,
#7918
<https://github.com/fish-shell/fish-shell/issues/7918>,
#8979
<https://github.com/fish-shell/fish-shell/issues/8979>).
Scripting improvements
- Quoted command substitution that directly follow a variable expansion
(like echo "$var$(echo x)") no longer affect the variable
expansion (#8849
<https://github.com/fish-shell/fish-shell/issues/8849>).
- Fish now correctly expands command substitutions that are preceded by an
escaped dollar (like echo \$(echo)). This regressed in version
3.4.0.
- math can now handle underscores (_) as visual separators in
numbers (#8611
<https://github.com/fish-shell/fish-shell/issues/8611>,
#8496
<https://github.com/fish-shell/fish-shell/issues/8496>):
- •
- math's min and max functions now take a variable
number of arguments instead of always requiring 2 (#8644
<https://github.com/fish-shell/fish-shell/issues/8644>,
#8646
<https://github.com/fish-shell/fish-shell/issues/8646>):
- read is now faster as the last process in a pipeline (#8552
<https://github.com/fish-shell/fish-shell/issues/8552>).
- string join gained a new --no-empty flag to skip empty
arguments (#8774
<https://github.com/fish-shell/fish-shell/issues/8774>,
#8351
<https://github.com/fish-shell/fish-shell/issues/8351>).
- read now only triggers the fish_read event, not the
fish_prompt event (#8797
<https://github.com/fish-shell/fish-shell/issues/8797>). It
was supposed to work this way in fish 3.2.0 and later, but both events
were emitted.
- The TTY modes are no longer restored when non-interactive shells exit.
This fixes wrong tty modes in pipelines with interactive commands.
(#8705
<https://github.com/fish-shell/fish-shell/issues/8705>).
- Some functions shipped with fish printed error messages to standard
output, but they now they rightly go to standard error (#8855
<https://github.com/fish-shell/fish-shell/issues/8855>).
- jobs now correctly reports CPU usage as a percentage, instead of as
a number of clock ticks (#8919
<https://github.com/fish-shell/fish-shell/issues/8919>).
- process-exit events now fire when the process exits even if the job
has not yet exited, fixing a regression in 3.4.1 (#8914
<https://github.com/fish-shell/fish-shell/issues/8914>).
Interactive improvements
- Fish now reports a special error if a command wasn't found and there is a
non-executable file by that name in PATH (#8804
<https://github.com/fish-shell/fish-shell/issues/8804>).
- less and other interactive commands would occasionally be stopped
when run in a pipeline with fish functions; this has been fixed
(#8699
<https://github.com/fish-shell/fish-shell/issues/8699>).
- Case-changing autosuggestions generated mid-token now correctly append
only the suffix, instead of duplicating the token (#8820
<https://github.com/fish-shell/fish-shell/issues/8820>).
- ulimit learned a number of new options for the resource limits
available on Linux, FreeBSD ande NetBSD, and returns a specific warning if
the limit specified is not available on the active operating system
(#8823
<https://github.com/fish-shell/fish-shell/issues/8823>,
#8786
<https://github.com/fish-shell/fish-shell/issues/8786>).
- The vared command can now successfully edit variables named
"tmp" or "prompt" (#8836
<https://github.com/fish-shell/fish-shell/issues/8836>,
#8837
<https://github.com/fish-shell/fish-shell/issues/8837>).
- time now emits an error if used after the first command in a
pipeline (#8841
<https://github.com/fish-shell/fish-shell/issues/8841>).
- fish_add_path now prints a message for skipped non-existent paths
when using the -v flag (#8884
<https://github.com/fish-shell/fish-shell/issues/8884>).
- Since fish 3.2.0, pressing ctrl-d while a command is running would
end up inserting a space into the next commandline, which has been fixed
(#8871
<https://github.com/fish-shell/fish-shell/issues/8871>).
- A bug that caused multi-line prompts to be moved down a line when pasting
or switching modes has been fixed (#3481
<https://github.com/fish-shell/fish-shell/issues/3481>).
- The Web-based configuration system no longer strips too many quotes in the
abbreviation display (#8917
<https://github.com/fish-shell/fish-shell/issues/8917>,
#8918
<https://github.com/fish-shell/fish-shell/issues/8918>).
- Fish started with --no-config will now use the default keybindings
(#8493
<https://github.com/fish-shell/fish-shell/issues/8493>)
- When fish inherits a USER environment variable value that doesn't
correspond to the current effective user ID, it will now correct it in all
cases (#8879
<https://github.com/fish-shell/fish-shell/issues/8879>,
#8583
<https://github.com/fish-shell/fish-shell/issues/8583>).
- Fish sets a new EUID variable containing the current effective user
id (#8866
<https://github.com/fish-shell/fish-shell/issues/8866>).
- history search no longer interprets the search term as an option
(#8853
<https://github.com/fish-shell/fish-shell/issues/8853>)
- The status message when a job terminates should no longer be erased by a
multiline prompt (#8817
<https://github.com/fish-shell/fish-shell/issues/8817>)
New or improved bindings
- The alt-s binding will now insert doas instead of
sudo if necessary (#8942
<https://github.com/fish-shell/fish-shell/issues/8942>).
- The kill-whole-line special input function now kills the newline
preceeding the last line. This makes dd in vi-mode clear the last
line properly.
- The new kill-inner-line special input function kills the line
without any newlines, allowing cc in vi-mode to clear the line
while preserving newlines (#8983
<https://github.com/fish-shell/fish-shell/issues/8983>).
- On terminals that emit special sequences for these combinations,
shift-space is bound like space, and ctrl-enter is
bound like return (#8874
<https://github.com/fish-shell/fish-shell/issues/8874>).
Improved prompts
- •
- A new Astronaut prompt (#8775
<https://github.com/fish-shell/fish-shell/issues/8775>), a
multi-line prompt using plain text reminiscent of the Starship.rs
prompt.
- •
- Added completions for:
- archlinux-java (#8911
<https://github.com/fish-shell/fish-shell/issues/8911>)
- apk (#8951
<https://github.com/fish-shell/fish-shell/issues/8951>)
- brightnessctl (#8758
<https://github.com/fish-shell/fish-shell/issues/8758>)
- efibootmgr (#9010
<https://github.com/fish-shell/fish-shell/issues/9010>)
- fastboot (#8904
<https://github.com/fish-shell/fish-shell/issues/8904>)
- optimus-manager (#8913
<https://github.com/fish-shell/fish-shell/issues/8913>)
- rclone (#8819
<https://github.com/fish-shell/fish-shell/issues/8819>)
- sops (#8821
<https://github.com/fish-shell/fish-shell/issues/8821>)
- tuned-adm (#8760
<https://github.com/fish-shell/fish-shell/issues/8760>)
- wg-quick (#8687
<https://github.com/fish-shell/fish-shell/issues/8687>)
- •
- complete can now be given multiple --condition options. They
will be attempted in the order they were given, and only if all succeed
will the completion be made available (as if they were connected with
&&). This helps with caching - fish's complete system
stores the return value of each condition as long as the commandline
doesn't change, so this can reduce the number of conditions that need to
be evaluated (#8536
<https://github.com/fish-shell/fish-shell/issues/8536>,
#8967
<https://github.com/fish-shell/fish-shell/issues/8967>).
Improved terminal support
- Working directory reporting is enabled for kitty (#8806
<https://github.com/fish-shell/fish-shell/issues/8806>).
- Changing the cursor shape is now enabled by default in iTerm2
(#3696
<https://github.com/fish-shell/fish-shell/issues/3696>).
For distributors
- libatomic is now correctly detected as necessary when building on RISC-V
(#8850
<https://github.com/fish-shell/fish-shell/issues/8850>,
#8851
<https://github.com/fish-shell/fish-shell/issues/8851>).
- In some cases, the build process found the wrong libintl on macOS. This
has been corrected (#5244
<https://github.com/fish-shell/fish-shell/issues/5244>).
- The paths for completions, functions, and configuration snippets now
include subdirectories fish/vendor_completions.d,
fish/vendor_functions.d, and fish/vendor_conf.d
(respectively) within XDG_DATA_HOME (or ~/.local/share if
not defined) (#8887
<https://github.com/fish-shell/fish-shell/issues/8887>,
#7816
<https://github.com/fish-shell/fish-shell/issues/7816>).
----
This release of fish fixes the following problems identified in
fish 3.4.0:
- An error printed after upgrading, where old instances could pick up a
newer version of the fish_title function, has been fixed
(#8778
<https://github.com/fish-shell/fish-shell/issues/8778>)
- fish builds correctly on NetBSD (#8788
<https://github.com/fish-shell/fish-shell/issues/8788>) and
OpenIndiana (#8780
<https://github.com/fish-shell/fish-shell/issues/8780>).
- nextd-or-forward-word, bound to alt-right by default, was
inadvertently changed to move like forward-bigword. This has been
corrected (#8790
<https://github.com/fish-shell/fish-shell/issues/8790>).
- funcsave -q and funcsave --quiet now work correctly
(#8830
<https://github.com/fish-shell/fish-shell/issues/8830>).
- Issues with the csharp and nmcli completions were
corrected.
If you are upgrading from version 3.3.1 or before, please also
review the release notes for 3.4.0 (included below).
----
Notable improvements and fixes
- •
- fish's command substitution syntax has been extended: $(cmd) now
has the same meaning as (cmd) but it can be used inside double
quotes, to prevent line splitting of the results (#159
<https://github.com/fish-shell/fish-shell/issues/159>):
foo (bar | string collect)
# can now be written as
foo "$(bar)"
# and
foo (bar)
# can now be written as
foo $(bar)
# this will still split on newlines only.
- Complementing the prompt command in 3.3.0, fish_config
gained a theme subcommand to show and pick from the sample themes
(meaning color schemes) directly in the terminal, instead of having to
open a Web browser. For example fish_config theme choose Nord loads
the Nord theme in the current session (#8132
<https://github.com/fish-shell/fish-shell/issues/8132>). The
current theme can be saved with fish_config theme dump, and custom
themes can be added by saving them in ~/.config/fish/themes/.
- set and read learned a new option, --function, to set
a variable in the function's top scope. This should be a more familiar way
of scoping variables and avoids issues with --local, which is
actually block-scoped (#565
<https://github.com/fish-shell/fish-shell/issues/565>,
#8145
<https://github.com/fish-shell/fish-shell/issues/8145>):
function demonstration
if true
set --function foo bar
set --local baz banana
end
echo $foo # prints "bar" because $foo is still valid
echo $baz # prints nothing because $baz went out of scope
end
- •
- string pad now excludes escape sequences like colors that fish
knows about, and a new --visible flag to string length makes
it use that kind of visible width. This is useful to get the number of
terminal cells an already colored string would occupy, like in a prompt.
(#8182
<https://github.com/fish-shell/fish-shell/issues/8182>,
#7784
<https://github.com/fish-shell/fish-shell/issues/7784>,
#4012
<https://github.com/fish-shell/fish-shell/issues/4012>):
> string length --visible (set_color red)foo
3
- Performance improvements to globbing, especially on systems using glibc.
In some cases (large directories with files with many numbers in the
names) this almost halves the time taken to expand the glob.
- Autosuggestions can now be turned off by setting
$fish_autosuggestion_enabled to 0, and (almost) all highlighting
can be turned off by choosing the new "None" theme. The
exception is necessary colors, like those which distinguish
autosuggestions from the actual command line. (#8376
<https://github.com/fish-shell/fish-shell/issues/8376>)
- The fish_git_prompt function, which is included in the default
prompts, now overrides git to avoid running commands set by
per-repository configuration. This avoids a potential security issue in
some circumstances, and has been assigned CVE-2022-20001 (#8589
<https://github.com/fish-shell/fish-shell/issues/8589>).
Deprecations and removed features
- •
- A new feature flag, ampersand-nobg-in-token makes & only
act as background operator if followed by a separator. In combination with
qmark-noglob, this allows entering most URLs at the command line
without quoting or escaping (#7991
<https://github.com/fish-shell/fish-shell/issues/7991>). For
example:
> echo foo&bar # will print "foo&bar", instead of running "echo foo" in the background and executing "bar"
> echo foo & bar # will still run "echo foo" in the background and then run "bar"
# with both ampersand-nobg-in-token and qmark-noglob, this argument has no special characters anymore
> open https://www.youtube.com/watch?v=dQw4w9WgXcQ&feature=youtu.be
As a reminder, feature flags can be set on startup with fish
--features ampersand-nobg-in-token,qmark-noglob or with a universal
variable called fish_features:
> set -Ua fish_features ampersand-nobg-in-token
- $status is now forbidden as a command, to prevent a surprisingly
common error among new users: Running if $status (#8171
<https://github.com/fish-shell/fish-shell/issues/8171>). This
applies only to $status, other variables are still
allowed.
- set --query now returns an exit status of 255 if given no variable
names. This means if set -q $foo will not enter the if-block if
$foo is empty or unset. To restore the previous behavior, use if
not set -q foo; or set -q $foo - but this is unlikely to be desireable
(#8214
<https://github.com/fish-shell/fish-shell/issues/8214>).
- _ is now a reserved keyword (#8342
<https://github.com/fish-shell/fish-shell/issues/8342>).
- The special input functions delete-or-exit,
nextd-or-forward-word and prevd-or-backward-word replace
fish functions of the same names (#8538
<https://github.com/fish-shell/fish-shell/issues/8538>).
- Mac OS X 10.9 is no longer supported. The minimum Mac version is now 10.10
"Yosemite."
Scripting improvements
- string collect supports a new --allow-empty option, which
will output one empty argument in a command substitution that has no
output (#8054
<https://github.com/fish-shell/fish-shell/issues/8054>). This
allows commands like test -n (echo -n | string collect
--allow-empty) to work more reliably. Note this can also be written as
test -n "$(echo -n)" (see above).
- string match gained a --groups-only option, which makes it
only output capturing groups, excluding the full match. This allows
string match to do simple transformations (#6056
<https://github.com/fish-shell/fish-shell/issues/6056>):
> string match -r --groups-only '(.*)fish' 'catfish' 'twofish' 'blue fish' | string escape
cat
two
'blue '
- $fish_user_paths is now automatically deduplicated to fix a common
user error of appending to it in config.fish when it is universal
(#8117
<https://github.com/fish-shell/fish-shell/issues/8117>).
fish_add_path remains the recommended way to add to $PATH.
- return can now be used outside functions. In scripts, it does the
same thing as exit. In interactive mode,it sets $status
without exiting (#8148
<https://github.com/fish-shell/fish-shell/issues/8148>).
- An oversight prevented all syntax checks from running on commands given to
fish -c (#8171
<https://github.com/fish-shell/fish-shell/issues/8171>). This
includes checks such as exec not being allowed in a pipeline, and
$$ not being a valid variable. Generally, another error was
generated anyway.
- fish_indent now correctly reformats tokens that end with a
backslash followed by a newline (#8197
<https://github.com/fish-shell/fish-shell/issues/8197>).
- commandline gained an --is-valid option to check if the
command line is syntactically valid and complete. This allows basic
implementation of transient prompts (#8142
<https://github.com/fish-shell/fish-shell/issues/8142>).
- commandline gained a --paging-full-mode option to check if
the pager is showing all the possible lines (no "7 more rows"
message) (#8485
<https://github.com/fish-shell/fish-shell/issues/8485>).
- List expansion correctly reports an error when used with all zero indexes
(#8213
<https://github.com/fish-shell/fish-shell/issues/8213>).
- Running fish with a directory instead of a script as argument (eg
fish .) no longer leads to an infinite loop. Instead it errors out
immediately (#8258
<https://github.com/fish-shell/fish-shell/issues/8258>)
- Some error messages occuring after fork, like "text file busy"
have been replaced by bespoke error messages for fish (like "File is
currently open for writing"). This also restores error messages with
current glibc versions that removed sys_errlist (#8234
<https://github.com/fish-shell/fish-shell/issues/8234>,
#4183
<https://github.com/fish-shell/fish-shell/issues/4183>).
- The realpath builtin now also squashes leading slashes with the
--no-symlinks option (#8281
<https://github.com/fish-shell/fish-shell/issues/8281>).
- When trying to cd to a dangling (broken) symbolic link, fish will
print an error noting that the target is a broken link (#8264
<https://github.com/fish-shell/fish-shell/issues/8264>).
- On MacOS terminals that are not granted permissions to access a folder,
cd would print a spurious "rotten symlink" error, which
has been corrected to "permission denied" (#8264
<https://github.com/fish-shell/fish-shell/issues/8264>).
- Since fish 3.0, for loops would trigger a variable handler function
before the loop was entered. As the variable had not actually changed or
been set, this was a spurious event and has been removed (#8384
<https://github.com/fish-shell/fish-shell/issues/8384>).
- math now correctly prints negative values and values larger than
2**31 when in hex or octal bases (#8417
<https://github.com/fish-shell/fish-shell/issues/8417>).
- dirs always produces an exit status of 0, instead of sometimes
returning 1 (#8211
<https://github.com/fish-shell/fish-shell/issues/8211>).
- cd "" no longer crashes fish (#8147
<https://github.com/fish-shell/fish-shell/issues/8147>).
- set --query can now query whether a variable is a path variable via
--path or --unpath (#8494
<https://github.com/fish-shell/fish-shell/issues/8494>).
- Tilde characters (~) produced by custom completions are no longer
escaped when applied to the command line, making it easier to use the
output of a recursive complete -C in completion scripts
(#4570
<https://github.com/fish-shell/fish-shell/issues/4570>).
- set --show reports when a variable is read-only (#8179
<https://github.com/fish-shell/fish-shell/issues/8179>).
- Erasing $fish_emoji_width will reset fish to the default guessed
emoji width (#8274
<https://github.com/fish-shell/fish-shell/issues/8274>).
- The la function no longer lists entries for "." and
"..", matching other systems defaults (#8519
<https://github.com/fish-shell/fish-shell/issues/8519>).
- abbr -q returns the correct exit status when given multiple
abbreviation names as arguments (#8431
<https://github.com/fish-shell/fish-shell/issues/8431>).
- command -v returns an exit status of 127 instead of 1 if no command
was found (#8547
<https://github.com/fish-shell/fish-shell/issues/8547>).
- argparse with --ignore-unknown no longer breaks with
multiple unknown options in a short option group (#8637
<https://github.com/fish-shell/fish-shell/issues/8637>).
- Comments inside command substitutions or brackets now correctly ignore
parentheses, quotes, and brackets (#7866
<https://github.com/fish-shell/fish-shell/issues/7866>,
#8022
<https://github.com/fish-shell/fish-shell/issues/8022>,
#8695
<https://github.com/fish-shell/fish-shell/issues/8695>).
- complete -C supports a new --escape option, which turns on
escaping in returned completion strings (#3469
<https://github.com/fish-shell/fish-shell/issues/3469>).
- Invalid byte or unicode escapes like \Utest or \xNotHex are
now a tokenizer error instead of causing the token to be truncated
(#8545
<https://github.com/fish-shell/fish-shell/issues/8545>).
Interactive improvements
- Vi mode cursors are now set properly after ctrl-c (#8125
<https://github.com/fish-shell/fish-shell/issues/8125>).
- funced will try to edit the whole file containing a function
definition, if there is one (#391
<https://github.com/fish-shell/fish-shell/issues/391>).
- Running a command line consisting of just spaces now deletes an ephemeral
(starting with space) history item again (#8232
<https://github.com/fish-shell/fish-shell/issues/8232>).
- Command substitutions no longer respect job control, instead running
inside fish's own process group (#8172
<https://github.com/fish-shell/fish-shell/issues/8172>). This
more closely matches other shells, and improves ctrl-c reliability
inside a command substitution.
- history and __fish_print_help now properly support
less before version 530, including the version that ships with
macOS. (#8157
<https://github.com/fish-shell/fish-shell/issues/8157>).
- help now knows which section is in which document again
(#8245
<https://github.com/fish-shell/fish-shell/issues/8245>).
- fish's highlighter will now color options (starting with - or
--) with the color given in the new $fish_color_option, up to the
first --. It falls back on $fish_color_param, so nothing changes
for existing setups (#8292
<https://github.com/fish-shell/fish-shell/issues/8292>).
- When executing a command, abbreviations are no longer expanded when the
cursor is separated from the command by spaces, making it easier to
suppress abbreviation expansion of commands without arguments.
(#8423
<https://github.com/fish-shell/fish-shell/issues/8423>).
- fish_key_reader's output was simplified. By default, it now only
prints a bind statement. The previous per-character timing information can
be seen with a new --verbose switch (#8467
<https://github.com/fish-shell/fish-shell/issues/8467>).
- Custom completions are now also loaded for commands that contain tildes or
variables like ~/bin/fish or $PWD/fish (#8442
<https://github.com/fish-shell/fish-shell/issues/8442>).
- Command lines spanning multiple lines will not be overwritten by the
completion pager when it fills the entire terminal (#8509
<https://github.com/fish-shell/fish-shell/issues/8509>,
#8405
<https://github.com/fish-shell/fish-shell/issues/8405>).
- When redrawing a multiline prompt, the old prompt is now properly cleared
(#8163
<https://github.com/fish-shell/fish-shell/issues/8163>).
- Interactive completion would occasionally ignore the last word on the
command line due to a race condition. This has been fixed (#8175
<https://github.com/fish-shell/fish-shell/issues/8175>).
- Propagation of universal variables from a fish process that is closing is
faster (#8209
<https://github.com/fish-shell/fish-shell/issues/8209>).
- The command line is drawn in the correct place if the prompt ends with a
newline (#8298
<https://github.com/fish-shell/fish-shell/issues/8298>).
- history learned a new subcommand clear-session to erase all
history from the current session (#5791
<https://github.com/fish-shell/fish-shell/issues/5791>).
- Pressing ctrl-c in fish_key_reader will no longer print the
incorrect "Press [ctrl-C] again to exit" message (#8510
<https://github.com/fish-shell/fish-shell/issues/8510>).
- The default command-not-found handler for Fedora/PackageKit now passes the
whole command line, allowing for functionality such as running the
suggested command directly (#8579
<https://github.com/fish-shell/fish-shell/issues/8579>).
- When looking for locale information, the Debian configuration is now used
when available (#8557
<https://github.com/fish-shell/fish-shell/issues/8557>).
- Pasting text containing quotes from the clipboard trims spaces more
appropriately (#8550
<https://github.com/fish-shell/fish-shell/issues/8550>).
- The clipboard bindings ignore X-based clipboard programs if the
DISPLAY environment variable is not set, which helps prefer the
Windows clipboard when it is available (such as on WSL).
- funcsave will remove a saved copy of a function that has been
erased with functions --erase.
- The Web-based configuration tool gained a number of improvements,
including the ability to set pager colors.
- The default fish_title prints a shorter title with shortened $PWD
and no more redundant "fish" (#8641
<https://github.com/fish-shell/fish-shell/issues/8641>).
- Holding down an arrow key won't freeze the terminal with long periods of
flashing (#8610
<https://github.com/fish-shell/fish-shell/issues/8610>).
- Multi-char bindings are no longer interrupted if a signal handler enqueues
an event. (#8628
<https://github.com/fish-shell/fish-shell/issues/8628>).
New or improved bindings
- escape can now bound without breaking arrow key bindings
(#8428
<https://github.com/fish-shell/fish-shell/issues/8428>).
- The alt-h binding (to open a command’s manual page) now also
ignores command (#8447
<https://github.com/fish-shell/fish-shell/issues/8447>).
Improved prompts
- The fish_status_to_signal helper function returns the correct
signal names for the current platform, rather than Linux (#8530
<https://github.com/fish-shell/fish-shell/issues/8530>).
- The prompt_pwd helper function learned a --full-length-dirs
N option to keep the last N directory components unshortened. In
addition the number of characters to shorten each component should be
shortened to can now be given as -d N or --dir-length N.
(#8208
<https://github.com/fish-shell/fish-shell/issues/8208>):
> prompt_pwd --full-length-dirs 2 -d 1 ~/dev/fish-shell/share/tools/web_config
~/d/f/s/tools/web_config
- •
- Added completions for:
- Apple's shortcuts
- argparse (#8434
<https://github.com/fish-shell/fish-shell/issues/8434>)
- asd (#8759
<https://github.com/fish-shell/fish-shell/issues/8759>)
- az (#8141
<https://github.com/fish-shell/fish-shell/issues/8141>)
- black (#8123
<https://github.com/fish-shell/fish-shell/issues/8123>)
- clasp (#8373
<https://github.com/fish-shell/fish-shell/issues/8373>)
- cpupower (#8302
<https://github.com/fish-shell/fish-shell/issues/8302>)
- dart (#8315
<https://github.com/fish-shell/fish-shell/issues/8315>)
- dscacheutil
- elvish (#8416
<https://github.com/fish-shell/fish-shell/issues/8416>)
- ethtool (#8283
<https://github.com/fish-shell/fish-shell/issues/8283>)
- exif (#8246
<https://github.com/fish-shell/fish-shell/issues/8246>)
- findstr (#8481
<https://github.com/fish-shell/fish-shell/issues/8481>)
- git-sizer (#8156
<https://github.com/fish-shell/fish-shell/issues/8156>)
- gnome-extensions (#8732
<https://github.com/fish-shell/fish-shell/issues/8732>)
- gping (#8181
<https://github.com/fish-shell/fish-shell/issues/8181>)
- isatty (#8609
<https://github.com/fish-shell/fish-shell/issues/8609>)
- istioctl (#8343
<https://github.com/fish-shell/fish-shell/issues/8343>)
- kmutil
- kubectl (#8734
<https://github.com/fish-shell/fish-shell/issues/8734>)
- matlab (#8505
<https://github.com/fish-shell/fish-shell/issues/8505>)
- mono (#8415
<https://github.com/fish-shell/fish-shell/issues/8415>) and
related tools csharp, gacutil, gendarme,
ikdasm, ilasm, mkbundle, monodis,
monop, sqlsharp and xsp (#8452
<https://github.com/fish-shell/fish-shell/issues/8452>)
- Angular's ng (#8111
<https://github.com/fish-shell/fish-shell/issues/8111>)
- nodeenv (#8533
<https://github.com/fish-shell/fish-shell/issues/8533>)
- octave (#8505
<https://github.com/fish-shell/fish-shell/issues/8505>)
- pabcnet_clear (#8421
<https://github.com/fish-shell/fish-shell/issues/8421>)
- qmk (#8180
<https://github.com/fish-shell/fish-shell/issues/8180>)
- rakudo (#8113
<https://github.com/fish-shell/fish-shell/issues/8113>)
- rc-status (#8757
<https://github.com/fish-shell/fish-shell/issues/8757>)
- roswell (#8330
<https://github.com/fish-shell/fish-shell/issues/8330>)
- sbcl (#8330
<https://github.com/fish-shell/fish-shell/issues/8330>)
- starship (#8520
<https://github.com/fish-shell/fish-shell/issues/8520>)
- topgrade (#8651
<https://github.com/fish-shell/fish-shell/issues/8651>)
- wine, wineboot and winemaker (#8411
<https://github.com/fish-shell/fish-shell/issues/8411>)
- Windows Subsystem for Linux (WSL)'s wslpath (#8364
<https://github.com/fish-shell/fish-shell/issues/8364>)
- Windows' color (#8483
<https://github.com/fish-shell/fish-shell/issues/8483>),
attrib, attributes, choice, clean,
cleanmgr, cmd, cmdkey, comp, forfiles,
powershell, reg, schtasks, setx (#8486
<https://github.com/fish-shell/fish-shell/issues/8486>)
- zef (#8114
<https://github.com/fish-shell/fish-shell/issues/8114>)
- Improvements to many completions, especially for git aliases
(#8129
<https://github.com/fish-shell/fish-shell/issues/8129>),
subcommands (#8134
<https://github.com/fish-shell/fish-shell/issues/8134>) and
submodules (#8716
<https://github.com/fish-shell/fish-shell/issues/8716>).
- Many adjustments to complete correct options for system utilities on BSD
and macOS.
- When evaluating custom completions, the command line state no longer
includes variable overrides (var=val). This unbreaks completions
that read commandline -op.
Improved terminal support
- Dynamic terminal titles are enabled on WezTerm (#8121
<https://github.com/fish-shell/fish-shell/issues/8121>).
- Directory history navigation works out of the box with Apple Terminal's
default key settings (#2330
<https://github.com/fish-shell/fish-shell/issues/2330>).
- fish now assumes Unicode 9+ widths for emoji under iTerm 2 (#8200
<https://github.com/fish-shell/fish-shell/issues/8200>).
- Skin-tone emoji modifiers (U+1F3FB through U+1F3FF) are now measured as
width 0 (#8275
<https://github.com/fish-shell/fish-shell/issues/8275>).
- fish's escape sequence removal now also knows Tmux's wrapped escapes.
- Vi mode cursors are enabled in Apple Terminal.app (#8167
<https://github.com/fish-shell/fish-shell/issues/8167>).
- Vi cursor shaping and $PWD reporting is now also enabled on foot
(#8422
<https://github.com/fish-shell/fish-shell/issues/8422>).
- ls will use colors also on newer versions of Apple Terminal.app
(#8309
<https://github.com/fish-shell/fish-shell/issues/8309>).
- The delete and shift-tab keys work more reliably under
st (#8352
<https://github.com/fish-shell/fish-shell/issues/8352>,
#8354
<https://github.com/fish-shell/fish-shell/issues/8354>).
Other improvements
- Fish's test suite now uses ctest, and has become much faster to
run. It is now also possible to run only specific tests with targets named
test_$filename - make test_set.fish only runs the set.fish
test. (#7851
<https://github.com/fish-shell/fish-shell/issues/7851>)
- The HTML version of the documentation now includes copy buttons for code
examples (#8218
<https://github.com/fish-shell/fish-shell/issues/8218>).
- The HTML version of the documentation and the web-based configuration tool
now pick more modern system fonts instead of falling back to Arial and
something like Courier New most of the time (#8632
<https://github.com/fish-shell/fish-shell/issues/8632>).
- The Debian & Ubuntu package linked from fishshell.com is now a single
package, rather than split into fish and fish-common
(#7845
<https://github.com/fish-shell/fish-shell/issues/7845>).
- The macOS installer does not assert that Rosetta is required to install
fish on machines with Apple Silicon (#8566
<https://github.com/fish-shell/fish-shell/issues/8566>).
- The macOS installer now cleans up previous .pkg installations when
upgrading. (#2963
<https://github.com/fish-shell/fish-shell/issues/2963>).
For distributors
- The minimum version of CMake required to build fish is now 3.5.0.
- The CMake installation supports absolute paths for
CMAKE_INSTALL_DATADIR (#8150
<https://github.com/fish-shell/fish-shell/issues/8150>).
- Building using NetBSD curses works on any platform (#8087
<https://github.com/fish-shell/fish-shell/issues/8087>).
- The build system now uses the default linker instead of forcing use of the
gold or lld linker (#8152
<https://github.com/fish-shell/fish-shell/issues/8152>).
----
This release of fish fixes the following problems identified in
fish 3.3.0:
- The prompt and command line are redrawn correctly in response to universal
variable changes (#8088
<https://github.com/fish-shell/fish-shell/issues/8088>).
- A superfluous error that was produced when setting the PATH or
CDPATH environment variables to include colon-delimited components
that do not exist was removed (#8095
<https://github.com/fish-shell/fish-shell/issues/8095>).
- The Vi mode indicator in the prompt is repainted correctly after
ctrl-c cancels the current command (#8103
<https://github.com/fish-shell/fish-shell/issues/8103>).
- fish builds correctly on platforms that do not have a spawn.h
header, such as old versions of OS X (#8097
<https://github.com/fish-shell/fish-shell/issues/8097>).
A number of improvements to the documentation, and fixes for
completions, are included as well.
If you are upgrading from version 3.2.2 or before, please also
review the release notes for 3.3.0 (included below).
----
Notable improvements and fixes
- fish_config gained a prompt subcommand to show and pick from
the sample prompts directly in the terminal, instead of having to open a
webbrowser. For example fish_config prompt choose default loads the
default prompt in the current session (#7958
<https://github.com/fish-shell/fish-shell/issues/7958>).
- The documentation has been reorganized to be easier to understand
(#7773
<https://github.com/fish-shell/fish-shell/issues/7773>).
Deprecations and removed features
- The $fish_history value "default" is no longer special.
It used to be treated the same as "fish" (#7650
<https://github.com/fish-shell/fish-shell/issues/7650>).
- Redirection to standard error with the ^ character has been
disabled by default. It can be turned back on using the
stderr-nocaret feature flag, but will eventually be disabled
completely (#7105
<https://github.com/fish-shell/fish-shell/issues/7105>).
- Specifying an initial tab to fish_config now only works with
fish_config browse (eg fish_config browse variables),
otherwise it would interfere with the new prompt subcommand (see
below) (#7958
<https://github.com/fish-shell/fish-shell/issues/7958>).
Scripting improvements
- math gained new functions log2 (like the documentation
claimed), max and min (#7856
<https://github.com/fish-shell/fish-shell/issues/7856>).
math functions can be used without the parentheses (eg math sin
2 + 6), and functions have the lowest precedence in the order of
operations (#7877
<https://github.com/fish-shell/fish-shell/issues/7877>).
- Shebang (#!) lines are no longer required within shell scripts,
improving support for scripts with concatenated binary contents. If a file
fails to execute and passes a (rudimentary) binary safety check, fish will
re-invoke it using /bin/sh (#7802
<https://github.com/fish-shell/fish-shell/issues/7802>).
- Exit codes are better aligned with bash. A failed execution now reports
$status of 127 if the file is not found, and 126 if it is not
executable.
- echo no longer writes its output one byte at a time, improving
performance and allowing use with Linux's special API files (/proc,
/sys and such) (#7836
<https://github.com/fish-shell/fish-shell/issues/7836>).
- fish should now better handle cd on filesystems with broken
stat(3) responses (#7577
<https://github.com/fish-shell/fish-shell/issues/7577>).
- Builtins now properly report a $status of 1 upon unsuccessful
writes (#7857
<https://github.com/fish-shell/fish-shell/issues/7857>).
- string match with unmatched capture groups and without the
--all flag now sets an empty variable instead of a variable
containing the empty string. It also correctly imports the first match if
multiple arguments are provided, matching the documentation. (#7938
<https://github.com/fish-shell/fish-shell/issues/7938>).
- fish produces more specific errors when a command in a command
substitution wasn't found or is not allowed. This now prints something
like "Unknown command" instead of "Unknown error while
evaluating command substitution".
- fish_indent allows inline variable assignments (FOO=BAR
command) to use line continuation, instead of joining them into one
line (#7955
<https://github.com/fish-shell/fish-shell/issues/7955>).
- fish gained a --no-config option to disable configuration files.
This applies to user-specific and the systemwide config.fish
(typically in /etc/fish/config.fish), and configuration snippets
(typically in conf.d directories). It also disables universal
variables, history, and loading of functions from system or user
configuration directories (#7921
<https://github.com/fish-shell/fish-shell/issues/7921>,
#1256
<https://github.com/fish-shell/fish-shell/issues/1256>).
- When universal variables are unavailable for some reason, setting a
universal variable now sets a global variable instead (#7921
<https://github.com/fish-shell/fish-shell/issues/7921>).
- $last_pid now contains the process ID of the last process in the
pipeline, allowing it to be used in scripts (#5036
<https://github.com/fish-shell/fish-shell/issues/5036>,
#5832
<https://github.com/fish-shell/fish-shell/issues/5832>,
#7721
<https://github.com/fish-shell/fish-shell/issues/7721>).
Previously, this value contained the process group ID, but in scripts this
was the same as the running fish's process ID.
- process-exit event handlers now receive the same value as
$status in all cases, instead of receiving -1 when the exit was due
to a signal.
- process-exit event handlers for PID 0 also received JOB_EXIT
events; this has been fixed.
- job-exit event handlers may now be created with any of the PIDs
from the job. The handler is passed the last PID in the job as its second
argument, instead of the process group.
- Trying to set an empty variable name with set no longer works
(these variables could not be used in expansions anyway).
- fish_add_path handles an undefined PATH environment variable
correctly (#8082
<https://github.com/fish-shell/fish-shell/issues/8082>).
Interactive improvements
- Commands entered before the previous command finishes will now be properly
syntax highlighted.
- fish now automatically creates config.fish and the configuration
directories in $XDG_CONFIG_HOME/fish (by default
~/.config/fish) if they do not already exist (#7402
<https://github.com/fish-shell/fish-shell/issues/7402>).
- $SHLVL is no longer incremented in non-interactive shells. This
means it won't be set to values larger than 1 just because your
environment happens to run some scripts in $SHELL in its startup path
(#7864
<https://github.com/fish-shell/fish-shell/issues/7864>).
- fish no longer rings the bell when flashing the command line. The flashing
should already be enough notification and the bell can be annoying
(#7875
<https://github.com/fish-shell/fish-shell/issues/7875>).
- fish --help is more helpful if the documentation isn't installed
(#7824
<https://github.com/fish-shell/fish-shell/issues/7824>).
- funced won't include an entry on where a function is defined,
thanks to the new functions --no-details option (#7879
<https://github.com/fish-shell/fish-shell/issues/7879>).
- A new variable, fish_killring, containing entries from the
killring, is now available (#7445
<https://github.com/fish-shell/fish-shell/issues/7445>).
- fish --private prints a note on private mode on startup even if
$fish_greeting is an empty list (#7974
<https://github.com/fish-shell/fish-shell/issues/7974>).
- fish no longer attempts to lock history or universal variable files on
remote filesystems, including NFS and Samba mounts. In rare cases, updates
to these files may be dropped if separate fish instances modify them
simultaneously. (#7968
<https://github.com/fish-shell/fish-shell/issues/7968>).
- wait and on-process-exit work correctly with jobs that have
already exited (#7210
<https://github.com/fish-shell/fish-shell/issues/7210>).
- __fish_print_help (used for --help output for fish's
builtins) now respects the LESS environment variable, and if not
set, uses better default pager settings (#7997
<https://github.com/fish-shell/fish-shell/issues/7997>).
- Errors from alias are now printed to standard error, matching other
builtins and functions (#7925
<https://github.com/fish-shell/fish-shell/issues/7925>).
- ls output is colorized on OpenBSD if colorls utility is installed
(#8035
<https://github.com/fish-shell/fish-shell/issues/8035>)
- The default pager color looks better in terminals with light backgrounds
(#3412
<https://github.com/fish-shell/fish-shell/issues/3412>).
- Further robustness improvements to the bash history import (#7874
<https://github.com/fish-shell/fish-shell/issues/7874>).
- fish now tries to find a Unicode-aware locale for encoding
(LC_CTYPE) if started without any locale information, improving the
display of emoji and other non-ASCII text on misconfigured systems
(#8031
<https://github.com/fish-shell/fish-shell/issues/8031>). To
allow a C locale, set the variable fish_allow_singlebyte_locale to
1.
- The Web-based configuration and documentation now feature a dark mode if
the browser requests it (#8043
<https://github.com/fish-shell/fish-shell/issues/8043>).
- Color variables can now also be given like --background red and
-b red, not just --background=red (#8053
<https://github.com/fish-shell/fish-shell/issues/8053>).
- exit run within fish_prompt now exits properly (#8033
<https://github.com/fish-shell/fish-shell/issues/8033>).
- When attempting to execute the unsupported POSIX-style brace command group
({ ... }) fish will suggest its equivalent begin; ...; end
commands (#6415
<https://github.com/fish-shell/fish-shell/issues/6415>).
New or improved bindings
- Pasting in Vi mode puts text in the right place in normal mode
(#7847
<https://github.com/fish-shell/fish-shell/issues/7847>).
- Vi mode's u is bound to undo instead of
history-search-backward, following GNU readline's behavior.
Similarly, ctrl-r is bound to redo instead of
history-search-backward, following Vim (#7908
<https://github.com/fish-shell/fish-shell/issues/7908>).
- s in Vi visual mode now does the same thing as c
(#8039
<https://github.com/fish-shell/fish-shell/issues/8039>).
- The binding for ",*,y now uses fish_clipboard_copy,
allowing it to support more than just xsel.
- The ctrl-space binding can be correctly customised (#7922
<https://github.com/fish-shell/fish-shell/issues/7922>).
- exit works correctly in bindings (#7967
<https://github.com/fish-shell/fish-shell/issues/7967>).
- The f1 binding, which opens the manual page for the current
command, now works around a bug in certain less versions that fail
to clear the screen (#7863
<https://github.com/fish-shell/fish-shell/issues/7863>).
- The binding for alt-s now toggles whether sudo is prepended,
even when it took the commandline from history instead of only adding
it.
- The new functions fish_commandline_prepend and
fish_commandline_append allow toggling the presence of a
prefix/suffix on the current commandline. (#7905
<https://github.com/fish-shell/fish-shell/issues/7905>).
- backward-kill-path-component ctrl-w) no longer erases parts
of two tokens when the cursor is positioned immediately after /.
(#6258
<https://github.com/fish-shell/fish-shell/issues/6258>).
Improved prompts
- The default Vi mode prompt now uses foreground instead of background
colors, making it less obtrusive (#7880
<https://github.com/fish-shell/fish-shell/issues/7880>).
- Performance of the "informative" git prompt is improved somewhat
(#7871
<https://github.com/fish-shell/fish-shell/issues/7871>). This
is still slower than the non-informative version by its very nature. In
particular it is IO-bound, so it will be very slow on slow disks or
network mounts.
- The sample prompts were updated. Some duplicated prompts, like the various
classic variants, or less useful ones, like the "justadollar"
prompt were removed, some prompts were cleaned up, and in some cases
renamed. A new "simple" and "disco" prompt were added
(#7884
<https://github.com/fish-shell/fish-shell/issues/7884>,
#7897
<https://github.com/fish-shell/fish-shell/issues/7897>,
#7930
<https://github.com/fish-shell/fish-shell/issues/7930>). The
new prompts will only take effect when selected and existing installed
prompts will remain unchanged.
- A new prompt_login helper function to describe the kind of
"login" (user, host and chroot status) for use in prompts. This
replaces the old "debian chroot" prompt and has been added to
the default and terlar prompts (#7932
<https://github.com/fish-shell/fish-shell/issues/7932>).
- The Web-based configuration's prompt picker now shows and installs right
prompts (#7930
<https://github.com/fish-shell/fish-shell/issues/7930>).
- The git prompt now has the same symbol order in normal and
"informative" mode, and it's customizable via
$__fish_git_prompt_status_order (#7926
<https://github.com/fish-shell/fish-shell/issues/7926>).
- •
- Added completions for:
- firewall-cmd (#7900
<https://github.com/fish-shell/fish-shell/issues/7900>)
- sv (#8069
<https://github.com/fish-shell/fish-shell/issues/8069>)
- Improvements to plenty of completions!
- Commands that wrap cd (using complete --wraps cd) get the
same completions as cd (#4693
<https://github.com/fish-shell/fish-shell/issues/4693>).
- The --force-files option to complete works for bare
arguments, not just options (#7920
<https://github.com/fish-shell/fish-shell/issues/7920>).
- Completion descriptions for functions don't include the function
definition, making them more concise (#7911
<https://github.com/fish-shell/fish-shell/issues/7911>).
- The kill completions no longer error on MSYS2 (#8046
<https://github.com/fish-shell/fish-shell/issues/8046>).
- Completion scripts are now loaded when calling a command via a relative
path (like ./git) (#6001
<https://github.com/fish-shell/fish-shell/issues/6001>,
#7992
<https://github.com/fish-shell/fish-shell/issues/7992>).
- When there are multiple completion candidates, fish inserts their shared
prefix. This prefix was computed in a case-insensitive way, resulting in
wrong case in the completion pager. This was fixed by only inserting
prefixes with matching case (#7744
<https://github.com/fish-shell/fish-shell/issues/7744>).
Improved terminal support
- fish no longer tries to detect a missing new line during startup,
preventing an erroneous ⏎ from appearing if the terminal is
resized at the wrong time, which can happen in tiling window managers
(#7893
<https://github.com/fish-shell/fish-shell/issues/7893>).
- fish behaves better when it disagrees with the terminal on the width of
characters. In particular, staircase effects with right prompts should be
gone in most cases (#8011
<https://github.com/fish-shell/fish-shell/issues/8011>).
- If the prompt takes up the entire line, the last character should no
longer be chopped off in certain terminals (#8002
<https://github.com/fish-shell/fish-shell/issues/8002>).
- fish's reflow handling has been disabled by default for kitty
(#7961
<https://github.com/fish-shell/fish-shell/issues/7961>).
- The default prompt no longer produces errors when used with a dumb
terminal (#7904
<https://github.com/fish-shell/fish-shell/issues/7904>).
- Terminal size variables are updated for window size change signal handlers
(SIGWINCH).
- Pasting within a multi-line command using a terminal that supports
bracketed paste works correctly, instead of producing an error
(#7782
<https://github.com/fish-shell/fish-shell/issues/7782>).
- set_color produces an error when used with invalid arguments,
rather than empty output which interacts badly with Cartesian product
expansion.
For distributors
- •
- fish runs correctly on platforms without the O_CLOEXEC flag for
open(2) (#8023
<https://github.com/fish-shell/fish-shell/issues/8023>).
----
This release of fish fixes a number of additional issues
identified in the fish 3.2 series:
- The command-not-found handler used suggestions from pacman on Arch
Linux, but this caused major slowdowns on some systems and has been
disabled (#7841
<https://github.com/fish-shell/fish-shell/issues/7841>).
- fish will no longer hang on exit if another process is in the foreground
on macOS (#7901
<https://github.com/fish-shell/fish-shell/issues/7901>).
- Certain programs (such as lazygit) could create situations where
fish would not receive keystrokes correctly, but it is now more robust in
these situations (#7853
<https://github.com/fish-shell/fish-shell/issues/7853>).
- Arguments longer than 1024 characters no longer trigger excessive CPU
usage on macOS (#7837
<https://github.com/fish-shell/fish-shell/issues/7837>).
- fish builds correctly on macOS when using new versions of Xcode
(#7838
<https://github.com/fish-shell/fish-shell/issues/7838>).
- Completions for aura (#7865
<https://github.com/fish-shell/fish-shell/issues/7865>) and
tshark (#7858
<https://github.com/fish-shell/fish-shell/issues/7858>)
should no longer produce errors.
- Background jobs no longer interfere with syntax highlighting (a regression
introduced in fish 3.2.1, #7842
<https://github.com/fish-shell/fish-shell/issues/7842>).
If you are upgrading from version 3.1.2 or before, please also
review the release notes for 3.2.1 and 3.2.0 (included below).
----
This release of fish fixes the following problems identified in
fish 3.2.0:
- Commands in key bindings are run with fish's internal terminal modes,
instead of the terminal modes typically used for commands. This fixes a
bug introduced in 3.2.0, where text would unexpectedly appear on the
terminal, especially when pasting (#7770
<https://github.com/fish-shell/fish-shell/issues/7770>).
- Prompts which use the internal __fish_print_pipestatus function
will display correctly rather than carrying certain modifiers (such as
bold) further than intended (#7771
<https://github.com/fish-shell/fish-shell/issues/7771>).
- Redirections to internal file descriptors is allowed again, reversing the
changes in 3.2.0. This fixes a problem with Midnight Commander
(#7769
<https://github.com/fish-shell/fish-shell/issues/7769>).
- Universal variables should be fully reliable regardless of operating
system again (#7774
<https://github.com/fish-shell/fish-shell/issues/7774>).
- fish_git_prompt no longer causes screen flickering in certain
terminals (#7775
<https://github.com/fish-shell/fish-shell/issues/7775>).
- fish_add_path manipulates the fish_user_paths variable
correctly when moving multiple paths (#7776
<https://github.com/fish-shell/fish-shell/issues/7776>).
- Pasting with a multi-line command no longer causes a
__fish_tokenizer_state error (#7782
<https://github.com/fish-shell/fish-shell/issues/7782>).
- psub inside event handlers cleans up temporary files properly
(#7792
<https://github.com/fish-shell/fish-shell/issues/7792>).
- Event handlers declared with --on-job-exit $fish_pid no longer run
constantly (#7721
<https://github.com/fish-shell/fish-shell/issues/7721>),
although these functions should use --on-event fish_exit
instead.
- Changing terminal modes inside config.fish works (#7783
<https://github.com/fish-shell/fish-shell/issues/7783>).
- set_color --print-colors no longer prints all colors in bold
(#7805
<https://github.com/fish-shell/fish-shell/issues/7805>)
- Completing commands starting with a - no longer prints an error
(#7809
<https://github.com/fish-shell/fish-shell/issues/7809>).
- Running fish_command_not_found directly no longer produces an error
on macOS or other OSes which do not have a handler available (#7777
<https://github.com/fish-shell/fish-shell/issues/7777>).
- The new type builtin now has the (deprecated) --quiet long
form of -q (#7766
<https://github.com/fish-shell/fish-shell/issues/7766>).
It also includes some small enhancements:
- help and fish_config work correctly when fish is running in
a Chrome OS Crostini Linux VM (#7789
<https://github.com/fish-shell/fish-shell/issues/7789>).
- The history file can be made a symbolic link without it being overwritten
(#7754
<https://github.com/fish-shell/fish-shell/issues/7754>),
matching a similar improvement for the universal variable file in
3.2.0.
- An unhelpful error ("access: No error"), seen on Cygwin, is no
longer produced (#7785
<https://github.com/fish-shell/fish-shell/issues/7785>).
- Improvements to the rsync completions (#7763
<https://github.com/fish-shell/fish-shell/issues/7763>), some
completion descriptions (#7788
<https://github.com/fish-shell/fish-shell/issues/7788>), and
completions that use IP address (#7787
<https://github.com/fish-shell/fish-shell/issues/7787>).
- Improvements to the appearance of fish_config (#7811
<https://github.com/fish-shell/fish-shell/issues/7811>).
If you are upgrading from version 3.1.2 or before, please also
review the release notes for 3.2.0 (included below).
----
Notable improvements and fixes
- Undo and redo support for the command-line editor and pager search
(#1367
<https://github.com/fish-shell/fish-shell/issues/1367>). By
default, undo is bound to Control+Z, and redo to Alt+/.
- Builtins can now output before all data is read. For example,
string replace no longer has to read all of stdin before it can
begin to output. This makes it usable also for pipes where the previous
command hasn't finished yet, like:
# Show all dmesg lines related to "usb"
dmesg -w | string match '*usb*'
- •
- Prompts will now be truncated instead of replaced with
"> " if they are wider than the terminal (#904
<https://github.com/fish-shell/fish-shell/issues/904>). For
example:
~/dev/build/fish-shell-git/src/fish-shell/build (makepkg)>
will turn into:
…h-shell/build (makepkg)>
It is still possible to react to the COLUMNS variable
inside the prompt to implement smarter behavior.
- fish completes ambiguous completions after pressing tab even
when they have a common prefix, without the user having to press
tab again (#6924
<https://github.com/fish-shell/fish-shell/issues/6924>).
- fish is less aggressive about resetting terminal modes, such as flow
control, after every command. Although flow control remains off by
default, enterprising users can now enable it with stty
(#2315
<https://github.com/fish-shell/fish-shell/issues/2315>,
#7704
<https://github.com/fish-shell/fish-shell/issues/7704>).
- A new "fish_add_path" helper function to add paths to
$PATH without producing duplicates, to be used interactively or in
config.fish (#6960
<https://github.com/fish-shell/fish-shell/issues/6960>,
#7028
<https://github.com/fish-shell/fish-shell/issues/7028>). For
example:
fish_add_path /opt/mycoolthing/bin
will add /opt/mycoolthing/bin to the beginning of $fish_user_path
without creating duplicates, so it can be called safely from config.fish or
interactively, and the path will just be there, once.
- •
- Better errors with "test" (#6030
<https://github.com/fish-shell/fish-shell/issues/6030>):
> test 1 = 2 and echo true or false
test: Expected a combining operator like '-a' at index 4
1 = 2 and echo true or echo false
^
This includes numbering the index from 1 instead of 0, like fish
lists.
- A new theme for the documentation and Web-based configuration
(#6500
<https://github.com/fish-shell/fish-shell/issues/6500>,
#7371
<https://github.com/fish-shell/fish-shell/issues/7371>,
#7523
<https://github.com/fish-shell/fish-shell/issues/7523>),
matching the design on fishshell.com.
- fish --no-execute will no longer complain about unknown
commands or non-matching wildcards, as these could be defined
differently at runtime (especially for functions). This makes it usable as
a static syntax checker (#977
<https://github.com/fish-shell/fish-shell/issues/977>).
- string match --regex now integrates named PCRE2 capture groups
as fish variables, allowing variables to be set directly from
string match (#7459
<https://github.com/fish-shell/fish-shell/issues/7459>). To
support this functionality, string is now a reserved word and can
no longer be wrapped in a function.
- Globs and other expansions are limited to 512,288 results
(#7226
<https://github.com/fish-shell/fish-shell/issues/7226>).
Because operating systems limit the number of arguments to commands,
larger values are unlikely to work anyway, and this helps to avoid
hangs.
- A new "fish for bash users" documentation page gives a
quick overview of the scripting differences between bash and fish
(#2382
<https://github.com/fish-shell/fish-shell/issues/2382>), and
the completion tutorial has also been moved out into its own document
(#6709
<https://github.com/fish-shell/fish-shell/issues/6709>).
Syntax changes and new commands
- •
- Range limits in index range expansions like $x[$start..$end] may be
omitted: $start and $end default to 1 and -1 (the last item)
respectively (#6574
<https://github.com/fish-shell/fish-shell/issues/6574>):
echo $var[1..]
echo $var[..-1]
echo $var[..]
All print the full list $var.
- •
- When globbing, a segment which is exactly ** may now match zero
directories. For example **/foo may match foo in the current
directory (#7222
<https://github.com/fish-shell/fish-shell/issues/7222>).
Scripting improvements
- The type, _ (gettext), . (source) and :
(no-op) functions are now implemented builtins for performance purposes
(#7342
<https://github.com/fish-shell/fish-shell/issues/7342>,
#7036
<https://github.com/fish-shell/fish-shell/issues/7036>,
#6854
<https://github.com/fish-shell/fish-shell/issues/6854>).
- set and backgrounded jobs no longer overwrite $pipestatus
(#6820
<https://github.com/fish-shell/fish-shell/issues/6820>),
improving its use in command substitutions (#6998
<https://github.com/fish-shell/fish-shell/issues/6998>).
- Computed ("electric") variables such as status are now
only global in scope, so set -Uq status returns false (#7032
<https://github.com/fish-shell/fish-shell/issues/7032>).
- The output for set --show has been shortened, only mentioning the
scopes in which a variable exists (#6944
<https://github.com/fish-shell/fish-shell/issues/6944>). In
addition, it now shows if a variable is a path variable.
- A new variable, fish_kill_signal, is set to the signal that
terminated the last foreground job, or 0 if the job exited normally
(#6824
<https://github.com/fish-shell/fish-shell/issues/6824>,
#6822
<https://github.com/fish-shell/fish-shell/issues/6822>).
- A new subcommand, string pad, allows extending strings to a given
width (#7340
<https://github.com/fish-shell/fish-shell/issues/7340>,
#7102
<https://github.com/fish-shell/fish-shell/issues/7102>).
- string sub has a new --end option to specify the end index
of a substring (#6765
<https://github.com/fish-shell/fish-shell/issues/6765>,
#5974
<https://github.com/fish-shell/fish-shell/issues/5974>).
- string split has a new --fields option to specify fields to
output, similar to cut -f (#6770
<https://github.com/fish-shell/fish-shell/issues/6770>).
- string trim now also trims vertical tabs by default (#6795
<https://github.com/fish-shell/fish-shell/issues/6795>).
- string replace no longer prints an error if a capturing group
wasn't matched, instead treating it as empty (#7343
<https://github.com/fish-shell/fish-shell/issues/7343>).
- string subcommands now quit early when used with --quiet
(#7495
<https://github.com/fish-shell/fish-shell/issues/7495>).
- string repeat now handles multiple arguments, repeating each one
(#5988
<https://github.com/fish-shell/fish-shell/issues/5988>).
- printf no longer prints an error if not given an argument (not even
a format string).
- The true and false builtins ignore any arguments, like other
shells (#7030
<https://github.com/fish-shell/fish-shell/issues/7030>).
- fish_indent now removes unnecessary quotes in simple cases
(#6722
<https://github.com/fish-shell/fish-shell/issues/6722>) and
gained a --check option to just check if a file is indented
correctly (#7251
<https://github.com/fish-shell/fish-shell/issues/7251>).
- fish_indent indents continuation lines that follow a line ending in
a backslash, |, && or ||.
- pushd only adds a directory to the stack if changing to it was
successful (#6947
<https://github.com/fish-shell/fish-shell/issues/6947>).
- A new fish_job_summary function is called whenever a background job
stops or ends, or any job terminates from a signal (#6959
<https://github.com/fish-shell/fish-shell/issues/6959>,
#2727
<https://github.com/fish-shell/fish-shell/issues/2727>,
#4319
<https://github.com/fish-shell/fish-shell/issues/4319>). The
default behaviour can now be customized by redefining it.
- status gained new dirname and basename convenience
subcommands to get just the directory to the running script or the name of
it, to simplify common tasks such as running (dirname (status
filename)) (#7076
<https://github.com/fish-shell/fish-shell/issues/7076>,
#1818
<https://github.com/fish-shell/fish-shell/issues/1818>).
- Broken pipelines are now handled more smoothly; in particular, bad
redirection mid-pipeline results in the job continuing to run but with the
broken file descriptor replaced with a closed file descriptor. This allows
better error recovery and is more in line with other shells' behaviour
(#7038
<https://github.com/fish-shell/fish-shell/issues/7038>).
- jobs --quiet PID no longer prints "no suitable job" if
the job for PID does not exist (eg because it has finished)
(#6809
<https://github.com/fish-shell/fish-shell/issues/6809>,
#6812
<https://github.com/fish-shell/fish-shell/issues/6812>).
- jobs now shows continued child processes correctly (#6818
<https://github.com/fish-shell/fish-shell/issues/6818>)
- disown should no longer create zombie processes when job control is
off, such as in config.fish (#7183
<https://github.com/fish-shell/fish-shell/issues/7183>).
- command, jobs and type builtins support
--query as the long form of -q, matching other builtins. The
long form --quiet is deprecated (#7276
<https://github.com/fish-shell/fish-shell/issues/7276>).
- argparse no longer requires a short flag letter for long-only
options (#7585
<https://github.com/fish-shell/fish-shell/issues/7585>) and
only prints a backtrace with invalid options to argparse itself
(#6703
<https://github.com/fish-shell/fish-shell/issues/6703>).
- argparse now passes the validation variables (e.g.
$_flag_value) as local-exported variables, avoiding the need for
--no-scope-shadowing in validation functions.
- complete takes the first argument as the name of the command if the
--command/-c option is not used, so complete git is
treated like complete --command git, and it can show the loaded
completions for specific commands with complete COMMANDNAME
(#7321
<https://github.com/fish-shell/fish-shell/issues/7321>).
- set_color -b (without an argument) no longer prints an error
message, matching other invalid invocations of this command (#7154
<https://github.com/fish-shell/fish-shell/issues/7154>).
- exec no longer produces a syntax error when the command cannot be
found (#6098
<https://github.com/fish-shell/fish-shell/issues/6098>).
- set --erase and abbr --erase can now erase multiple things
in one go, matching functions --erase (#7377
<https://github.com/fish-shell/fish-shell/issues/7377>).
- abbr --erase no longer prints errors when used with no arguments or
on an unset abbreviation (#7376
<https://github.com/fish-shell/fish-shell/issues/7376>,
#7732
<https://github.com/fish-shell/fish-shell/issues/7732>).
- test -t, for testing whether file descriptors are connected to a
terminal, works for file descriptors 0, 1, and 2 (#4766
<https://github.com/fish-shell/fish-shell/issues/4766>). It
can still return incorrect results in other cases (#1228
<https://github.com/fish-shell/fish-shell/issues/1228>).
- Trying to execute scripts with Windows line endings (CRLF) produces a
sensible error (#2783
<https://github.com/fish-shell/fish-shell/issues/2783>).
- Trying to execute commands with arguments that exceed the operating system
limit now produces a specific error (#6800
<https://github.com/fish-shell/fish-shell/issues/6800>).
- An alias that delegates to a command with the same name no longer
triggers an error about recursive completion (#7389
<https://github.com/fish-shell/fish-shell/issues/7389>).
- math now has a --base option to output the result in
hexadecimal or octal (#7496
<https://github.com/fish-shell/fish-shell/issues/7496>) and
produces more specific error messages (#7508
<https://github.com/fish-shell/fish-shell/issues/7508>).
- math learned bitwise functions bitand, bitor and
bitxor, used like math "bitand(0xFE, 5)"
(#7281
<https://github.com/fish-shell/fish-shell/issues/7281>).
- math learned tau for those who don't like typing "2 *
pi".
- Failed redirections will now set $status (#7540
<https://github.com/fish-shell/fish-shell/issues/7540>).
- fish sets exit status in a more consistent manner after errors, including
invalid expansions like $foo[.
- Using read --silent while fish is in private mode was adding these
potentially-sensitive entries to the history; this has been fixed
(#7230
<https://github.com/fish-shell/fish-shell/issues/7230>).
- read can now read interactively from other files, and can be used
to read from the terminal via read </dev/tty (if the operating
system provides /dev/tty) (#7358
<https://github.com/fish-shell/fish-shell/issues/7358>).
- A new fish_status_to_signal function for transforming exit statuses
to signal names has been added (#7597
<https://github.com/fish-shell/fish-shell/issues/7597>,
#7595
<https://github.com/fish-shell/fish-shell/issues/7595>).
- The fallback realpath builtin supports the
-s/--no-symlinks option, like GNU realpath (#7574
<https://github.com/fish-shell/fish-shell/issues/7574>).
- functions and type now explain when a function was defined
via source instead of just saying Defined in -.
- Significant performance improvements when globbing, appending to variables
or in math.
- echo no longer interprets options at the beginning of an argument
(eg echo "-n foo") (#7614
<https://github.com/fish-shell/fish-shell/issues/7614>).
- fish now finds user configuration even if the HOME environment
variable is not set (#7620
<https://github.com/fish-shell/fish-shell/issues/7620>).
- fish no longer crashes when started from a Windows-style working directory
(eg F:\path) (#7636
<https://github.com/fish-shell/fish-shell/issues/7636>).
- fish -c now reads the remaining arguments into $argv
(#2314
<https://github.com/fish-shell/fish-shell/issues/2314>).
- The pwd command supports the long options --logical and
--physical, matching other implementations (#6787
<https://github.com/fish-shell/fish-shell/issues/6787>).
- fish --profile now only starts profiling after fish is ready to
execute commands (all configuration is completed). There is a new
--profile-startup option that only profiles the startup and
configuration process (#7648
<https://github.com/fish-shell/fish-shell/issues/7648>).
- Builtins return a maximum exit status of 255, rather than potentially
overflowing. In particular, this affects exit, return,
functions --query, and set --query (#7698
<https://github.com/fish-shell/fish-shell/issues/7698>,
#7702
<https://github.com/fish-shell/fish-shell/issues/7702>).
- It is no longer an error to run builtin with closed stdin. For example
count <&- now prints 0, instead of failing.
- Blocks, functions, and builtins no longer permit redirecting to file
descriptors other than 0 (standard input), 1 (standard output) and 2
(standard error). For example, echo hello >&5 is now an
error. This prevents corruption of internal state (#3303
<https://github.com/fish-shell/fish-shell/issues/3303>).
Interactive improvements
- fish will now always attempt to become process group leader in interactive
mode (#7060
<https://github.com/fish-shell/fish-shell/issues/7060>). This
helps avoid hangs in certain circumstances, and allows tmux's current
directory introspection to work (#5699
<https://github.com/fish-shell/fish-shell/issues/5699>).
- The interactive reader now allows ending a line in a logical operators
(&& and ||) instead of complaining about a missing
command. (This was already syntactically valid, but interactive sessions
didn't know about it yet).
- The prompt is reprinted after a background job exits (#1018
<https://github.com/fish-shell/fish-shell/issues/1018>).
- fish no longer inserts a space after a completion ending in .,
, or - is accepted, improving completions for tools that
provide dynamic completions (#6928
<https://github.com/fish-shell/fish-shell/issues/6928>).
- If a filename is invalid when first pressing tab, but becomes
valid, it will be completed properly on the next attempt (#6863
<https://github.com/fish-shell/fish-shell/issues/6863>).
- help string match/replace/<subcommand> will show the help for
string subcommands (#6786
<https://github.com/fish-shell/fish-shell/issues/6786>).
- fish_key_reader sets the exit status to 0 when used with
--help or --version (#6964
<https://github.com/fish-shell/fish-shell/issues/6964>).
- fish_key_reader and fish_indent send output from
--version to standard output, matching other fish binaries
(#6964
<https://github.com/fish-shell/fish-shell/issues/6964>).
- A new variable $status_generation is incremented only when the
previous command produces an exit status (#6815
<https://github.com/fish-shell/fish-shell/issues/6815>). This
can be used, for example, to check whether a failure status is a holdover
due to a background job, or actually produced by the last run
command.
- fish_greeting is now a function that reads a variable of the same
name, and defaults to setting it globally. This removes a universal
variable by default and helps with updating the greeting. However, to
disable the greeting it is now necessary to explicitly specify universal
scope (set -U fish_greeting) or to disable it in config.fish
(#7265
<https://github.com/fish-shell/fish-shell/issues/7265>).
- Events are properly emitted after a job is cancelled (#2356
<https://github.com/fish-shell/fish-shell/issues/2356>).
- fish_preexec and fish_postexec events are no longer
triggered for empty commands (#4829
<https://github.com/fish-shell/fish-shell/issues/4829>,
#7085
<https://github.com/fish-shell/fish-shell/issues/7085>).
- Functions triggered by the fish_exit event are correctly run when
the terminal is closed or the shell receives SIGHUP (#7014
<https://github.com/fish-shell/fish-shell/issues/7014>).
- The fish_prompt event no longer fires when read is used. If
you need a function to run any time read is invoked by a script,
use the new fish_read event instead (#7039
<https://github.com/fish-shell/fish-shell/issues/7039>).
- A new fish_posterror event is emitted when attempting to execute a
command with syntax errors (#6880
<https://github.com/fish-shell/fish-shell/issues/6880>,
#6816
<https://github.com/fish-shell/fish-shell/issues/6816>).
- The debugging system has now fully switched from the old numbered level to
the new named category system introduced in 3.1. A number of new debugging
categories have been added, including config, path,
reader and screen (#6511
<https://github.com/fish-shell/fish-shell/issues/6511>). See
the output of fish --print-debug-categories for the full list.
- The warning about read-only filesystems has been moved to a new
"warning-path" debug category and can be disabled by setting a
debug category of -warning-path (#6630
<https://github.com/fish-shell/fish-shell/issues/6630>):
fish --debug=-warning-path
- The enabled debug categories are now printed on shell startup
(#7007
<https://github.com/fish-shell/fish-shell/issues/7007>).
- The -o short option to fish, for --debug-output, works
correctly instead of producing an invalid option error (#7254
<https://github.com/fish-shell/fish-shell/issues/7254>).
- fish's debugging can now also be enabled via FISH_DEBUG and
FISH_DEBUG_OUTPUT environment variables. This helps with debugging
when no commandline options can be passed, like when fish is called in a
shebang (#7359
<https://github.com/fish-shell/fish-shell/issues/7359>).
- Abbreviations are now expanded after all command terminators (eg ;
or |), not just space, as in fish 2.7.1 and before (#6970
<https://github.com/fish-shell/fish-shell/issues/6970>), and
after closing a command substitution (#6658
<https://github.com/fish-shell/fish-shell/issues/6658>).
- The history file is now created with user-private permissions, matching
other shells (#6926
<https://github.com/fish-shell/fish-shell/issues/6926>). The
directory containing the history file was already private, so there should
not have been any private data revealed.
- The output of time is now properly aligned in all cases
(#6726
<https://github.com/fish-shell/fish-shell/issues/6726>,
#6714
<https://github.com/fish-shell/fish-shell/issues/6714>) and
no longer depends on locale (#6757
<https://github.com/fish-shell/fish-shell/issues/6757>).
- The command-not-found handling has been simplified. When it can't find a
command, fish now just executes a function called
fish_command_not_found instead of firing an event, making it easier
to replace and reason about. Previously-defined
__fish_command_not_found_handler functions with an appropriate
event listener will still work (#7293
<https://github.com/fish-shell/fish-shell/issues/7293>).
- ctrl-c handling has been reimplemented in C++ and is therefore
quicker (#5259
<https://github.com/fish-shell/fish-shell/issues/5259>), no
longer occasionally prints an "unknown command" error
(#7145
<https://github.com/fish-shell/fish-shell/issues/7145>) or
overwrites multiline prompts (#3537
<https://github.com/fish-shell/fish-shell/issues/3537>).
- ctrl-c no longer kills background jobs for which job control is
disabled, matching POSIX semantics (#6828
<https://github.com/fish-shell/fish-shell/issues/6828>,
#6861
<https://github.com/fish-shell/fish-shell/issues/6861>).
- Autosuggestions work properly after ctrl-c cancels the current
commmand line (#6937
<https://github.com/fish-shell/fish-shell/issues/6937>).
- History search is now case-insensitive unless the search string contains
an uppercase character (#7273
<https://github.com/fish-shell/fish-shell/issues/7273>).
- fish_update_completions gained a new --keep option, which
improves speed by skipping completions that already exist (#6775
<https://github.com/fish-shell/fish-shell/issues/6775>,
#6796
<https://github.com/fish-shell/fish-shell/issues/6796>).
- Aliases containing an embedded backslash appear properly in the output of
alias (#6910
<https://github.com/fish-shell/fish-shell/issues/6910>).
- open no longer hangs indefinitely on certain systems, as a bug in
xdg-open has been worked around (#7215
<https://github.com/fish-shell/fish-shell/issues/7215>).
- Long command lines no longer add a blank line after execution
(#6826
<https://github.com/fish-shell/fish-shell/issues/6826>) and
behave better with backspace (#6951
<https://github.com/fish-shell/fish-shell/issues/6951>).
- functions -t works like the long option --handlers-type, as
documented, instead of producing an error (#6985
<https://github.com/fish-shell/fish-shell/issues/6985>).
- History search now flashes when it found no more results (#7362
<https://github.com/fish-shell/fish-shell/issues/7362>)
- fish now creates the path in the environment variable
XDG_RUNTIME_DIR if it does not exist, before using it for runtime
data storage (#7335
<https://github.com/fish-shell/fish-shell/issues/7335>).
- set_color --print-colors now also respects the bold, dim,
underline, reverse, italic and background modifiers, to better show their
effect (#7314
<https://github.com/fish-shell/fish-shell/issues/7314>).
- The fish Web configuration tool (fish_config) shows prompts
correctly on Termux for Android (#7298
<https://github.com/fish-shell/fish-shell/issues/7298>) and
detects Windows Services for Linux 2 properly (#7027
<https://github.com/fish-shell/fish-shell/issues/7027>). It
no longer shows the history variable as it may be too large (one
can use the History tab instead). It also starts the browser in another
thread, avoiding hangs in some circumstances, especially with Firefox's
Developer Edition (#7158
<https://github.com/fish-shell/fish-shell/issues/7158>).
Finally, a bug in the Source Code Pro font may cause browsers to hang, so
this font is no longer chosen by default (#7714
<https://github.com/fish-shell/fish-shell/issues/7714>).
- funcsave gained a new --directory option to specify the
location of the saved function (#7041
<https://github.com/fish-shell/fish-shell/issues/7041>).
- help works properly on MSYS2 (#7113
<https://github.com/fish-shell/fish-shell/issues/7113>) and
only uses cmd.exe if running on WSL (#6797
<https://github.com/fish-shell/fish-shell/issues/6797>).
- Resuming a piped job by its number, like fg %1, works correctly
(#7406
<https://github.com/fish-shell/fish-shell/issues/7406>).
Resumed jobs show the correct title in the terminal emulator (#7444
<https://github.com/fish-shell/fish-shell/issues/7444>).
- Commands run from key bindings now use the same TTY modes as normal
commands (#7483
<https://github.com/fish-shell/fish-shell/issues/7483>).
- Autosuggestions from history are now case-sensitive (#3978
<https://github.com/fish-shell/fish-shell/issues/3978>).
- $status from completion scripts is no longer passed outside the
completion, which keeps the status display in the prompt as the last
command's status (#7555
<https://github.com/fish-shell/fish-shell/issues/7555>).
- Updated localisations for pt_BR (#7480
<https://github.com/fish-shell/fish-shell/issues/7480>).
- fish_trace output now starts with -> (like fish
--profile), making the depth more visible (#7538
<https://github.com/fish-shell/fish-shell/issues/7538>).
- Resizing the terminal window no longer produces a corrupted prompt
(#6532
<https://github.com/fish-shell/fish-shell/issues/6532>,
#7404
<https://github.com/fish-shell/fish-shell/issues/7404>).
- functions produces an error rather than crashing on certain invalid
arguments (#7515
<https://github.com/fish-shell/fish-shell/issues/7515>).
- A crash in completions with inline variable assignment (eg A= b)
has been fixed (#7344
<https://github.com/fish-shell/fish-shell/issues/7344>).
- fish_private_mode may now be changed dynamically using set
(#7589
<https://github.com/fish-shell/fish-shell/issues/7589>), and
history is kept in memory in private mode (but not stored permanently)
(#7590
<https://github.com/fish-shell/fish-shell/issues/7590>).
- Commands with leading spaces may be retrieved from history with up-arrow
until a new command is run, matching zsh's HIST_IGNORE_SPACE
(#1383
<https://github.com/fish-shell/fish-shell/issues/1383>).
- Importing bash history or reporting errors with recursive globs
(**) no longer hangs (#7407
<https://github.com/fish-shell/fish-shell/issues/7407>,
#7497
<https://github.com/fish-shell/fish-shell/issues/7497>).
- bind now shows \x7f for the del key instead of a literal DEL
character (#7631
<https://github.com/fish-shell/fish-shell/issues/7631>)
- Paths containing variables or tilde expansion are only suggested when they
are still valid (#7582
<https://github.com/fish-shell/fish-shell/issues/7582>).
- Syntax highlighting can now color a command as invalid even if executed
quickly (#5912
<https://github.com/fish-shell/fish-shell/issues/5912>).
- Redirection targets are no longer highlighted as error if they contain
variables which will likely be defined by the current commandline
(#6654
<https://github.com/fish-shell/fish-shell/issues/6654>).
- fish is now more resilient against broken terminal modes (#7133
<https://github.com/fish-shell/fish-shell/issues/7133>,
#4873
<https://github.com/fish-shell/fish-shell/issues/4873>).
- fish handles being in control of the TTY without owning its own process
group better, avoiding some hangs in special configurations (#7388
<https://github.com/fish-shell/fish-shell/issues/7388>).
- Keywords can now be colored differently by setting the
fish_color_keyword variable (fish_color_command is used as a
fallback) (#7678
<https://github.com/fish-shell/fish-shell/issues/7678>).
- Just like fish_indent, the interactive reader will indent
continuation lines that follow a line ending in a backslash, |,
&& or || (#7694
<https://github.com/fish-shell/fish-shell/issues/7694>).
- Commands with a trailing escaped space are saved in history correctly
(#7661
<https://github.com/fish-shell/fish-shell/issues/7661>).
- fish_prompt no longer mangles Unicode characters in the private-use
range U+F600-U+F700. (#7723
<https://github.com/fish-shell/fish-shell/issues/7723>).
- The universal variable file, fish_variables, can be made a symbolic
link without it being overwritten (#7466
<https://github.com/fish-shell/fish-shell/issues/7466>).
- fish is now more resilient against mktemp failing (#7482
<https://github.com/fish-shell/fish-shell/issues/7482>).
New or improved bindings
- As mentioned above, new special input functions undo (ctrl-_
or ctrl-z) and redo (alt-/) can be used to revert
changes to the command line or the pager search field (#6570
<https://github.com/fish-shell/fish-shell/issues/6570>).
- ctrl-z is now available for binding (#7152
<https://github.com/fish-shell/fish-shell/issues/7152>).
- Additionally, using the cancel special input function (bound to
escape by default) right after fish picked an unambiguous
completion will undo that (#7433
<https://github.com/fish-shell/fish-shell/issues/7433>).
- fish_clipboard_paste (ctrl-v) trims indentation from
multiline commands, because fish already indents (#7662
<https://github.com/fish-shell/fish-shell/issues/7662>).
- Vi mode bindings now support dh, dl, c0, cf,
ct, cF, cT, ch, cl, y0,
ci, ca, yi, ya, di, da,
d;, d,, o, O and Control+left/right keys to
navigate by word (#6648
<https://github.com/fish-shell/fish-shell/issues/6648>,
#6755
<https://github.com/fish-shell/fish-shell/issues/6755>,
#6769
<https://github.com/fish-shell/fish-shell/issues/6769>,
#7442
<https://github.com/fish-shell/fish-shell/issues/7442>,
#7516
<https://github.com/fish-shell/fish-shell/issues/7516>).
- Vi mode bindings support ~ (tilde) to toggle the case of the
selected character (#6908
<https://github.com/fish-shell/fish-shell/issues/6908>).
- Functions up-or-search and down-or-search (up and
down) can cross empty lines, and don't activate search mode if the
search fails, which makes them easier to use to move between lines in some
situations.
- If history search fails to find a match, the cursor is no longer moved.
This is useful when accidentally starting a history search on a multi-line
commandline.
- The special input function beginning-of-history (pageup) now
moves to the oldest search instead of the youngest - that's
end-of-history (pagedown).
- A new special input function forward-single-char moves one
character to the right, and if an autosuggestion is available, only take a
single character from it (#7217
<https://github.com/fish-shell/fish-shell/issues/7217>,
#4984
<https://github.com/fish-shell/fish-shell/issues/4984>).
- Special input functions can now be joined with or as a modifier
(adding to and), though only some commands set an exit status
(#7217
<https://github.com/fish-shell/fish-shell/issues/7217>). This
includes suppress-autosuggestion to reflect whether an
autosuggestion was suppressed (#1419
<https://github.com/fish-shell/fish-shell/issues/1419>)
- A new function __fish_preview_current_file, bound to alt-o,
opens the current file at the cursor in a pager (#6838
<https://github.com/fish-shell/fish-shell/issues/6838>,
#6855
<https://github.com/fish-shell/fish-shell/issues/6855>).
- edit_command_buffer (alt-e and alt-v) passes the
cursor position to the external editor if the editor is recognized
(#6138
<https://github.com/fish-shell/fish-shell/issues/6138>,
#6954
<https://github.com/fish-shell/fish-shell/issues/6954>).
- __fish_prepend_sudo (alt-s) now toggles a sudo prefix
(#7012
<https://github.com/fish-shell/fish-shell/issues/7012>) and
avoids shifting the cursor (#6542
<https://github.com/fish-shell/fish-shell/issues/6542>).
- __fish_prepend_sudo (alt-s) now uses the previous
commandline if the current one is empty, to simplify rerunning the
previous command with sudo (#7079
<https://github.com/fish-shell/fish-shell/issues/7079>).
- __fish_toggle_comment_commandline (alt-#) now uncomments and
presents the last comment from history if the commandline is empty
(#7137
<https://github.com/fish-shell/fish-shell/issues/7137>).
- __fish_whatis_current_token (alt-w) prints descriptions for
functions and builtins (#7191
<https://github.com/fish-shell/fish-shell/issues/7191>,
#2083
<https://github.com/fish-shell/fish-shell/issues/2083>).
- The definition of "word" and "bigword" for movements
was refined, fixing (eg) vi mode's behavior with e on the
second-to-last char, and bigword's behavior with single-character words
and non-blank non-graphical characters (#7353
<https://github.com/fish-shell/fish-shell/issues/7353>,
#7354
<https://github.com/fish-shell/fish-shell/issues/7354>,
#4025
<https://github.com/fish-shell/fish-shell/issues/4025>,
#7328
<https://github.com/fish-shell/fish-shell/issues/7328>,
#7325
<https://github.com/fish-shell/fish-shell/issues/7325>)
- fish's clipboard bindings now also support Windows Subsystem for Linux via
PowerShell and clip.exe (#7455
<https://github.com/fish-shell/fish-shell/issues/7455>,
#7458
<https://github.com/fish-shell/fish-shell/issues/7458>) and
will properly copy newlines in multi-line commands.
- Using the *-jump special input functions before typing anything
else no longer crashes fish.
- Completing variable overrides (foo=bar) could replace the entire
thing with just the completion in some circumstances. This has been fixed
(#7398
<https://github.com/fish-shell/fish-shell/issues/7398>).
Improved prompts
- The default and example prompts print the correct exit status for commands
prefixed with not (#6566
<https://github.com/fish-shell/fish-shell/issues/6566>).
- git prompts include all untracked files in the repository, not just those
in the current directory (#6086
<https://github.com/fish-shell/fish-shell/issues/6086>).
- The git prompts correctly show stash states (#6876
<https://github.com/fish-shell/fish-shell/issues/6876>,
#7136
<https://github.com/fish-shell/fish-shell/issues/7136>) and
clean states (#7471
<https://github.com/fish-shell/fish-shell/issues/7471>).
- The Mercurial prompt correctly shows untracked status (#6906
<https://github.com/fish-shell/fish-shell/issues/6906>), and
by default only shows the branch for performance reasons. A new variable
$fish_prompt_hg_show_informative_status can be set to enable more
information.
- The fish_vcs_prompt passes its arguments to the various VCS prompts
that it calls (#7033
<https://github.com/fish-shell/fish-shell/issues/7033>).
- The Subversion prompt was broken in a number of ways in 3.1.0 and has been
restored (#6715
<https://github.com/fish-shell/fish-shell/issues/6715>,
#7278
<https://github.com/fish-shell/fish-shell/issues/7278>).
- A new helper function fish_is_root_user simplifies checking for
superuser privilege (#7031
<https://github.com/fish-shell/fish-shell/issues/7031>,
#7123
<https://github.com/fish-shell/fish-shell/issues/7123>).
- New colorschemes - ayu Light, ayu Dark and ayu Mirage
(#7596
<https://github.com/fish-shell/fish-shell/issues/7596>).
- Bugs related to multiline prompts, including repainting (#5860
<https://github.com/fish-shell/fish-shell/issues/5860>) or
navigating directory history (#3550
<https://github.com/fish-shell/fish-shell/issues/3550>)
leading to graphical glitches have been fixed.
- The nim prompt now handles vi mode better (#6802
<https://github.com/fish-shell/fish-shell/issues/6802>)
Improved terminal support
- A new variable, fish_vi_force_cursor, can be set to force
fish_vi_cursor to attempt changing the cursor shape in vi mode,
regardless of terminal (#6968
<https://github.com/fish-shell/fish-shell/issues/6968>). The
fish_vi_cursor option --force-iterm has been
deprecated.
- diff will now colourize output, if supported (#7308
<https://github.com/fish-shell/fish-shell/issues/7308>).
- Autosuggestions appear when the cursor passes the right prompt
(#6948
<https://github.com/fish-shell/fish-shell/issues/6948>) or
wraps to the next line (#7213
<https://github.com/fish-shell/fish-shell/issues/7213>).
- The cursor shape in Vi mode changes properly in Windows Terminal
(#6999
<https://github.com/fish-shell/fish-shell/issues/6999>,
#6478
<https://github.com/fish-shell/fish-shell/issues/6478>).
- The spurious warning about terminal size in small terminals has been
removed (#6980
<https://github.com/fish-shell/fish-shell/issues/6980>).
- Dynamic titles are now enabled in Alacritty (#7073
<https://github.com/fish-shell/fish-shell/issues/7073>) and
emacs' vterm (#7122
<https://github.com/fish-shell/fish-shell/issues/7122>).
- Current working directory updates are enabled in foot (#7099
<https://github.com/fish-shell/fish-shell/issues/7099>) and
WezTerm (#7649
<https://github.com/fish-shell/fish-shell/issues/7649>).
- The width computation for certain emoji agrees better with terminals
(especially flags). (#7237
<https://github.com/fish-shell/fish-shell/issues/7237>).
- Long command lines are wrapped in all cases, instead of sometimes being
put on a new line (#5118
<https://github.com/fish-shell/fish-shell/issues/5118>).
- The pager is properly rendered with long command lines selected
(#2557
<https://github.com/fish-shell/fish-shell/issues/2557>).
- Sessions with right prompts can be resized correctly in terminals that
handle reflow, like GNOME Terminal (and other VTE-based terminals),
upcoming Konsole releases and Alacritty. This detection can be overridden
with the new fish_handle_reflow variable (#7491
<https://github.com/fish-shell/fish-shell/issues/7491>).
- fish now sets terminal modes sooner, which stops output from appearing
before the greeting and prompt are ready (#7489
<https://github.com/fish-shell/fish-shell/issues/7489>).
- Better detection of new Konsole versions for true color support and cursor
shape changing.
- fish no longer attempts to modify the terminal size via TIOCSWINSZ,
improving compatibility with Kitty (#6994
<https://github.com/fish-shell/fish-shell/issues/6994>).
- •
- Added completions for
- 7z, 7za and 7zr (#7220
<https://github.com/fish-shell/fish-shell/issues/7220>)
- alias (#7035
<https://github.com/fish-shell/fish-shell/issues/7035>)
- alternatives (#7616
<https://github.com/fish-shell/fish-shell/issues/7616>)
- apk (#7108
<https://github.com/fish-shell/fish-shell/issues/7108>)
- asciidoctor (#7000
<https://github.com/fish-shell/fish-shell/issues/7000>)
- avifdec and avifenc (#7674
<https://github.com/fish-shell/fish-shell/issues/7674>)
- bluetoothctl (#7438
<https://github.com/fish-shell/fish-shell/issues/7438>)
- cjxl and djxl (#7673
<https://github.com/fish-shell/fish-shell/issues/7673>)
- cmark (#7000
<https://github.com/fish-shell/fish-shell/issues/7000>)
- create_ap (#7096
<https://github.com/fish-shell/fish-shell/issues/7096>)
- deno (#7138
<https://github.com/fish-shell/fish-shell/issues/7138>)
- dhclient (#6684
<https://github.com/fish-shell/fish-shell/issues/6684>)
- Postgres-related commands dropdb, createdb,
pg_restore, pg_dump and pg_dumpall (#6620
<https://github.com/fish-shell/fish-shell/issues/6620>)
- dotnet (#7558
<https://github.com/fish-shell/fish-shell/issues/7558>)
- downgrade (#6751
<https://github.com/fish-shell/fish-shell/issues/6751>)
- gapplication, gdbus, gio and gresource
(#7300
<https://github.com/fish-shell/fish-shell/issues/7300>)
- gh (#7112
<https://github.com/fish-shell/fish-shell/issues/7112>)
- gitk
- groups (#6889
<https://github.com/fish-shell/fish-shell/issues/6889>)
- hashcat (#7746
<https://github.com/fish-shell/fish-shell/issues/7746>)
- hikari (#7083
<https://github.com/fish-shell/fish-shell/issues/7083>)
- icdiff (#7503
<https://github.com/fish-shell/fish-shell/issues/7503>)
- imv (#6675
<https://github.com/fish-shell/fish-shell/issues/6675>)
- john (#7746
<https://github.com/fish-shell/fish-shell/issues/7746>)
- julia (#7468
<https://github.com/fish-shell/fish-shell/issues/7468>)
- k3d (#7202
<https://github.com/fish-shell/fish-shell/issues/7202>)
- ldapsearch (#7578
<https://github.com/fish-shell/fish-shell/issues/7578>)
- lightdm and dm-tool (#7624
<https://github.com/fish-shell/fish-shell/issues/7624>)
- losetup (#7621
<https://github.com/fish-shell/fish-shell/issues/7621>)
- micro (#7339
<https://github.com/fish-shell/fish-shell/issues/7339>)
- mpc (#7169
<https://github.com/fish-shell/fish-shell/issues/7169>)
- Metasploit's msfconsole, msfdb and msfvenom
(#6930
<https://github.com/fish-shell/fish-shell/issues/6930>)
- mtr (#7638
<https://github.com/fish-shell/fish-shell/issues/7638>)
- mysql (#6819
<https://github.com/fish-shell/fish-shell/issues/6819>)
- ncat, nc.openbsd, nc.traditional and nmap
(#6873
<https://github.com/fish-shell/fish-shell/issues/6873>)
- openssl (#6845
<https://github.com/fish-shell/fish-shell/issues/6845>)
- prime-run (#7241
<https://github.com/fish-shell/fish-shell/issues/7241>)
- ps2pdf{12,13,14,wr} (#6673
<https://github.com/fish-shell/fish-shell/issues/6673>)
- pyenv (#6551
<https://github.com/fish-shell/fish-shell/issues/6551>)
- rst2html, rst2html4, rst2html5, rst2latex,
rst2man, rst2odt, rst2pseudoxml, rst2s5,
rst2xetex, rst2xml and rstpep2html (#7019
<https://github.com/fish-shell/fish-shell/issues/7019>)
- spago (#7381
<https://github.com/fish-shell/fish-shell/issues/7381>)
- sphinx-apidoc, sphinx-autogen, sphinx-build and
sphinx-quickstart (#7000
<https://github.com/fish-shell/fish-shell/issues/7000>)
- strace (#6656
<https://github.com/fish-shell/fish-shell/issues/6656>)
- systemd's bootctl, coredumpctl, hostnamectl
(#7428
<https://github.com/fish-shell/fish-shell/issues/7428>),
homectl (#7435
<https://github.com/fish-shell/fish-shell/issues/7435>),
networkctl (#7668
<https://github.com/fish-shell/fish-shell/issues/7668>) and
userdbctl (#7667
<https://github.com/fish-shell/fish-shell/issues/7667>)
- tcpdump (#6690
<https://github.com/fish-shell/fish-shell/issues/6690>)
- tig
- traceroute and tracepath (#6803
<https://github.com/fish-shell/fish-shell/issues/6803>)
- windscribe (#6788
<https://github.com/fish-shell/fish-shell/issues/6788>)
- wireshark, tshark, and dumpcap
- xbps-* (#7239
<https://github.com/fish-shell/fish-shell/issues/7239>)
- xxhsum, xxh32sum, xxh64sum and xxh128sum
(#7103
<https://github.com/fish-shell/fish-shell/issues/7103>)
- yadm (#7100
<https://github.com/fish-shell/fish-shell/issues/7100>)
- zopfli and zopflipng (#6872
<https://github.com/fish-shell/fish-shell/issues/6872>)
- •
- Lots of improvements to completions, including:
- git completions can complete the right and left parts of a commit
range like from..to or left...right.
- Completion scripts for custom Git subcommands like git-xyz are now
loaded with Git completions. The completions can now be defined directly
on the subcommand (using complete git-xyz), and completion for
git xyz will work. (#7075
<https://github.com/fish-shell/fish-shell/issues/7075>,
#7652
<https://github.com/fish-shell/fish-shell/issues/7652>,
#4358
<https://github.com/fish-shell/fish-shell/issues/4358>)
- make completions no longer second-guess make's file detection,
fixing target completion in some cases (#7535
<https://github.com/fish-shell/fish-shell/issues/7535>).
- Command completions now correctly print the description even if the
command was fully matched (like in ls<TAB>).
- set completions no longer hide variables starting with __,
they are sorted last instead.
- Improvements to the manual page completion generator (#7086
<https://github.com/fish-shell/fish-shell/issues/7086>,
#6879
<https://github.com/fish-shell/fish-shell/issues/6879>,
#7187
<https://github.com/fish-shell/fish-shell/issues/7187>).
- Significant performance improvements to completion of the available
commands (#7153
<https://github.com/fish-shell/fish-shell/issues/7153>),
especially on macOS Big Sur where there was a significant regression
(#7365
<https://github.com/fish-shell/fish-shell/issues/7365>,
#7511
<https://github.com/fish-shell/fish-shell/issues/7511>).
- Suffix completion using __fish_complete_suffix uses the same fuzzy
matching logic as normal file completion, and completes any file but sorts
files with matching suffix first (#7040
<https://github.com/fish-shell/fish-shell/issues/7040>,
#7547
<https://github.com/fish-shell/fish-shell/issues/7547>).
Previously, it only completed files with matching suffix.
For distributors
- fish has a new interactive test driver based on pexpect, removing the
optional dependency on expect (and adding an optional dependency on
pexpect) (#5451
<https://github.com/fish-shell/fish-shell/issues/5451>,
#6825
<https://github.com/fish-shell/fish-shell/issues/6825>).
- The CHANGELOG was moved to restructured text, allowing it to be included
in the documentation (#7057
<https://github.com/fish-shell/fish-shell/issues/7057>).
- fish handles ncurses installed in a non-standard prefix better
(#6600
<https://github.com/fish-shell/fish-shell/issues/6600>,
#7219
<https://github.com/fish-shell/fish-shell/issues/7219>), and
uses variadic tparm on NetBSD curses (#6626
<https://github.com/fish-shell/fish-shell/issues/6626>).
- The Web-based configuration tool no longer uses an obsolete Angular
version (#7147
<https://github.com/fish-shell/fish-shell/issues/7147>).
- The fish project has adopted the Contributor Covenant code of conduct
(#7151
<https://github.com/fish-shell/fish-shell/issues/7151>).
Deprecations and removed features
- The fish_color_match variable is no longer used. (Previously this
controlled the color of matching quotes and parens when using
read).
- fish 3.2.0 will be the last release in which the redirection to standard
error with the ^ character is enabled. The stderr-nocaret
feature flag will be changed to "on" in future releases.
- string is now a reserved word and cannot be used for function names
(see above).
- fish_vi_cursor's option --force-iterm has been deprecated
(see above).
- command, jobs and type long-form option
--quiet is deprecated in favor of --query (see above).
- The fish_command_not_found event is no longer emitted, instead
there is a function of that name. By default it will call a
previously-defined __fish_command_not_found_handler. To emit the
event manually use emit fish_command_not_found.
- The fish_prompt event no longer fires when read is used. If
you need a function to run any time read is invoked by a script,
use the new fish_read event instead (#7039
<https://github.com/fish-shell/fish-shell/issues/7039>).
- To disable the greeting message permanently it is no longer enough to just
run set fish_greeting interactively as it is no longer implicitly a
universal variable. Use set -U fish_greeting or disable it in
config.fish with set -g fish_greeting.
- The long-deprecated and non-functional -m/--read-mode
options to read were removed in 3.1b1. Using the short form, or a
never-implemented -B option, no longer crashes fish (#7659
<https://github.com/fish-shell/fish-shell/issues/7659>).
- With the addition of new categories for debug options, the old numbered
debugging levels have been removed.
For distributors and developers
- fish source tarballs are now distributed using the XZ compression method
(#5460
<https://github.com/fish-shell/fish-shell/issues/5460>).
- The fish source tarball contains an example FreeDesktop entry and
icon.
- The CMake variable MAC_CODESIGN_ID can now be set to
"off" to disable code-signing (#6952
<https://github.com/fish-shell/fish-shell/issues/6952>,
#6792
<https://github.com/fish-shell/fish-shell/issues/6792>).
- Building on on macOS earlier than 10.13.6 succeeds, instead of failing on
code-signing (#6791
<https://github.com/fish-shell/fish-shell/issues/6791>).
- The pkg-config file now uses variables to ensure paths used are portable
across prefixes.
- The default values for the extra_completionsdir,
extra_functionsdir and extra_confdir options now use the
installation prefix rather than /usr/local (#6778
<https://github.com/fish-shell/fish-shell/issues/6778>).
- A new CMake variable FISH_USE_SYSTEM_PCRE2 controls whether fish
builds with the system-installed PCRE2, or the version it bundles. By
default it prefers the system library if available, unless Mac codesigning
is enabled (#6952
<https://github.com/fish-shell/fish-shell/issues/6952>).
- Running the full interactive test suite now requires Python 3.5+ and the
pexpect package (#6825
<https://github.com/fish-shell/fish-shell/issues/6825>); the
expect package is no longer required.
- Support for Python 2 in fish's tools (fish_config and the manual
page completion generator) is no longer guaranteed. Please use Python 3.5
or later (#6537
<https://github.com/fish-shell/fish-shell/issues/6537>).
- The Web-based configuration tool is compatible with Python 3.10
(#7600
<https://github.com/fish-shell/fish-shell/issues/7600>) and
no longer requires Python's distutils package (#7514
<https://github.com/fish-shell/fish-shell/issues/7514>).
- fish 3.2 is the last release to support Red Hat Enterprise Linux &
CentOS version 6.
----
This release of fish fixes a major issue discovered in fish
3.1.1:
- •
- Commands such as fzf and enhancd, when used with
eval, would hang. eval buffered output too aggressively,
which has been fixed (#6955
<https://github.com/fish-shell/fish-shell/issues/6955>).
If you are upgrading from version 3.0.0 or before, please also
review the release notes for 3.1.1, 3.1.0 and 3.1b1 (included below).
----
This release of fish fixes a number of major issues discovered in
fish 3.1.0.
- Commands which involve . ( ... | psub) now work correctly, as a bug
in the function --on-job-exit option has been fixed (#6613
<https://github.com/fish-shell/fish-shell/issues/6613>).
- Conflicts between upstream packages for ripgrep and bat, and the fish
packages, have been resolved (#5822
<https://github.com/fish-shell/fish-shell/issues/5822>).
- Starting fish in a directory without read access, such as via su,
no longer crashes (#6597
<https://github.com/fish-shell/fish-shell/issues/6597>).
- Glob ordering changes which were introduced in 3.1.0 have been reverted,
returning the order of globs to the previous state (#6593
<https://github.com/fish-shell/fish-shell/issues/6593>).
- Redirections using the deprecated caret syntax to a file descriptor (eg
^&2) work correctly (#6591
<https://github.com/fish-shell/fish-shell/issues/6591>).
- Redirections that append to a file descriptor (eg 2>>&1)
work correctly (#6614
<https://github.com/fish-shell/fish-shell/issues/6614>).
- Building fish on macOS (#6602
<https://github.com/fish-shell/fish-shell/issues/6602>) or
with new versions of GCC (#6604
<https://github.com/fish-shell/fish-shell/issues/6604>,
#6609
<https://github.com/fish-shell/fish-shell/issues/6609>) is
now successful.
- time is now correctly listed in the output of builtin -n,
and time --help works correctly (#6598
<https://github.com/fish-shell/fish-shell/issues/6598>).
- Exported universal variables now update properly (#6612
<https://github.com/fish-shell/fish-shell/issues/6612>).
- status current-command gives the expected output when used with an
environment override - that is, F=B status current-command returns
status instead of F=B (#6635
<https://github.com/fish-shell/fish-shell/issues/6635>).
- test no longer crashes when used with “nan” or
“inf” arguments, erroring out instead (#6655
<https://github.com/fish-shell/fish-shell/issues/6655>).
- Copying from the end of the command line no longer crashes fish
(#6680
<https://github.com/fish-shell/fish-shell/issues/6680>).
- read no longer removes multiple separators when splitting a
variable into a list, restoring the previous behaviour from fish 3.0 and
before (#6650
<https://github.com/fish-shell/fish-shell/issues/6650>).
- Functions using --on-job-exit and --on-process-exit work
reliably again (#6679
<https://github.com/fish-shell/fish-shell/issues/6679>).
- Functions using --on-signal INT work reliably in interactive
sessions, as they did in fish 2.7 and before (#6649
<https://github.com/fish-shell/fish-shell/issues/6649>).
These handlers have never worked in non-interactive sessions, and making
them work is an ongoing process.
- Functions using --on-variable work reliably with variables which
are set implicitly (rather than with set), such as
“fish_bind_mode” and “PWD”
(#6653
<https://github.com/fish-shell/fish-shell/issues/6653>).
- 256 colors are properly enabled under certain conditions that were
incorrectly detected in fish 3.1.0 ($TERM begins with xterm, does
not include “256color”, and $TERM_PROGRAM is
not set) (#6701
<https://github.com/fish-shell/fish-shell/issues/6701>).
- The Mercurial (hg) prompt no longer produces an error when the
current working directory is removed (#6699
<https://github.com/fish-shell/fish-shell/issues/6699>).
Also, for performance reasons it shows only basic information by default;
to restore the detailed status, set
$fish_prompt_hg_show_informative_status.
- The VCS prompt, fish_vcs_prompt, no longer displays Subversion
(svn) status by default, due to the potential slowness of this
operation (#6681
<https://github.com/fish-shell/fish-shell/issues/6681>).
- Pasting of commands has been sped up (#6713
<https://github.com/fish-shell/fish-shell/issues/6713>).
- Using extended Unicode characters, such as emoji, in a non-Unicode capable
locale (such as the C or POSIX locale) no longer renders all
output blank (#6736
<https://github.com/fish-shell/fish-shell/issues/6736>).
- help prefers to use xdg-open, avoiding the use of
open on Debian systems where this command is actually openvt
(#6739
<https://github.com/fish-shell/fish-shell/issues/6739>).
- Command lines starting with a space, which are not saved in history, now
do not get autosuggestions. This fixes an issue with Midnight Commander
integration (#6763
<https://github.com/fish-shell/fish-shell/issues/6763>), but
may be changed in a future version.
- Copying to the clipboard no longer inserts a newline at the end of the
content, matching fish 2.7 and earlier (#6927
<https://github.com/fish-shell/fish-shell/issues/6927>).
- fzf in complex pipes no longer hangs. More generally, code run as
part of command substitutions or eval will no longer have separate
process groups. (#6624
<https://github.com/fish-shell/fish-shell/issues/6624>,
#6806
<https://github.com/fish-shell/fish-shell/issues/6806>).
This release also includes:
- several changes to improve macOS compatibility with code signing and
notarization;
- several improvements to completions; and
- several content and formatting improvements to the documentation.
If you are upgrading from version 3.0.0 or before, please also
review the release notes for 3.1.0 and 3.1b1 (included below).
A new builtin, time, was introduced in the fish 3.1
releases. This builtin is a reserved word (like test,
function, and others) because of the way it is implemented, and
functions can no longer be named time. This was not clear in the fish
3.1b1 changelog.
----
Compared to the beta release of fish 3.1b1, fish version
3.1.0:
- Fixes a regression where spaces after a brace were removed despite brace
expansion not occurring (#6564
<https://github.com/fish-shell/fish-shell/issues/6564>).
- Fixes a number of problems in compiling and testing on Cygwin
(#6549
<https://github.com/fish-shell/fish-shell/issues/6549>) and
Solaris-derived systems such as Illumos (#6553
<https://github.com/fish-shell/fish-shell/issues/6553>,
#6554
<https://github.com/fish-shell/fish-shell/issues/6554>,
#6555
<https://github.com/fish-shell/fish-shell/issues/6555>,
#6556
<https://github.com/fish-shell/fish-shell/issues/6556>, and
#6558
<https://github.com/fish-shell/fish-shell/issues/6558>).
- Fixes the process for building macOS packages.
- Fixes a regression where excessive error messages are printed if Unicode
characters are emitted in non-Unicode-capable locales (#6584
<https://github.com/fish-shell/fish-shell/issues/6584>).
- Contains some improvements to the documentation and a small number of
completions.
If you are upgrading from version 3.0.0 or before, please also
review the release notes for 3.1b1 (included below).
----
Notable improvements and fixes
- A new $pipestatus variable contains a list of exit statuses of the
previous job, for each of the separate commands in a pipeline
(#5632
<https://github.com/fish-shell/fish-shell/issues/5632>).
- fish no longer buffers pipes to the last function in a pipeline, improving
many cases where pipes appeared to block or hang (#1396
<https://github.com/fish-shell/fish-shell/issues/1396>).
- An overhaul of error messages for builtin commands, including a removal of
the overwhelming usage summary, more readable stack traces (#3404
<https://github.com/fish-shell/fish-shell/issues/3404>,
#5434
<https://github.com/fish-shell/fish-shell/issues/5434>), and
stack traces for test (aka [) (#5771
<https://github.com/fish-shell/fish-shell/issues/5771>).
- fish’s debugging arguments have been significantly improved. The
--debug-level option has been removed, and a new --debug
option replaces it. This option accepts various categories, which may be
listed via fish --print-debug-categories (#5879
<https://github.com/fish-shell/fish-shell/issues/5879>). A
new --debug-output option allows for redirection of debug
output.
- string has a new collect subcommand for use in command
substitutions, producing a single output instead of splitting on new lines
(similar to "$(cmd)" in other shells) (#159
<https://github.com/fish-shell/fish-shell/issues/159>).
- The fish manual, tutorial and FAQ are now available in man format
as fish-doc, fish-tutorial and fish-faq respectively
(#5521
<https://github.com/fish-shell/fish-shell/issues/5521>).
- Like other shells, cd now always looks for its argument in the
current directory as a last resort, even if the CDPATH variable
does not include it or “.” (#4484
<https://github.com/fish-shell/fish-shell/issues/4484>).
- fish now correctly handles CDPATH entries that start with ..
(#6220
<https://github.com/fish-shell/fish-shell/issues/6220>) or
contain ./ (#5887
<https://github.com/fish-shell/fish-shell/issues/5887>).
- The fish_trace variable may be set to trace execution (#3427
<https://github.com/fish-shell/fish-shell/issues/3427>). This
performs a similar role as set -x in other shells.
- fish uses the temporary directory determined by the system, rather than
relying on /tmp (#3845
<https://github.com/fish-shell/fish-shell/issues/3845>).
- The fish Web configuration tool (fish_config) prints a list of
commands it is executing, to help understanding and debugging
(#5584
<https://github.com/fish-shell/fish-shell/issues/5584>).
- Major performance improvements when pasting (#5866
<https://github.com/fish-shell/fish-shell/issues/5866>),
executing lots of commands (#5905
<https://github.com/fish-shell/fish-shell/issues/5905>),
importing history from bash (#6295
<https://github.com/fish-shell/fish-shell/issues/6295>), and
when completing variables that might match $history (#6288
<https://github.com/fish-shell/fish-shell/issues/6288>).
Syntax changes and new commands
- A new builtin command, time, which allows timing of fish functions
and builtins as well as external commands (#117
<https://github.com/fish-shell/fish-shell/issues/117>).
- Brace expansion now only takes place if the braces include a
“,” or a variable expansion, meaning common commands such as
git reset HEAD@{0} do not require escaping (#5869
<https://github.com/fish-shell/fish-shell/issues/5869>).
- New redirections &> and &| may be used to
redirect or pipe stdout, and also redirect stderr to stdout (#6192
<https://github.com/fish-shell/fish-shell/issues/6192>).
- switch now allows arguments that expand to nothing, like empty
variables (#5677
<https://github.com/fish-shell/fish-shell/issues/5677>).
- The VAR=val cmd syntax can now be used to run a command in a
modified environment (#6287
<https://github.com/fish-shell/fish-shell/issues/6287>).
- and is no longer recognised as a command, so that nonsensical
constructs like and and and produce a syntax error (#6089
<https://github.com/fish-shell/fish-shell/issues/6089>).
- math‘s exponent operator,’^‘, was
previously left-associative, but now uses the more commonly-used
right-associative behaviour (#6280
<https://github.com/fish-shell/fish-shell/issues/6280>). This
means that math '3^0.5^2' was previously calculated
as’(30.5)2’, but is now calculated as
‘3(0.52)’.
- In fish 3.0, the variable used with for loops inside command
substitutions could leak into enclosing scopes; this was an inadvertent
behaviour change and has been reverted (#6480
<https://github.com/fish-shell/fish-shell/issues/6480>).
Scripting improvements
- string split0 now returns 0 if it split something (#5701
<https://github.com/fish-shell/fish-shell/issues/5701>).
- In the interest of consistency, builtin -q and command -q
can now be used to query if a builtin or command exists (#5631
<https://github.com/fish-shell/fish-shell/issues/5631>).
- math now accepts --scale=max for the maximum scale
(#5579
<https://github.com/fish-shell/fish-shell/issues/5579>).
- builtin $var now works correctly, allowing a variable as the
builtin name (#5639
<https://github.com/fish-shell/fish-shell/issues/5639>).
- cd understands the -- argument to make it possible to change
to directories starting with a hyphen (#6071
<https://github.com/fish-shell/fish-shell/issues/6071>).
- complete --do-complete now also does fuzzy matches (#5467
<https://github.com/fish-shell/fish-shell/issues/5467>).
- complete --do-complete can be used inside completions, allowing
limited recursion (#3474
<https://github.com/fish-shell/fish-shell/issues/3474>).
- count now also counts lines fed on standard input (#5744
<https://github.com/fish-shell/fish-shell/issues/5744>).
- eval produces an exit status of 0 when given no arguments, like
other shells (#5692
<https://github.com/fish-shell/fish-shell/issues/5692>).
- printf prints what it can when input hasn’t been fully
converted to a number, but still prints an error (#5532
<https://github.com/fish-shell/fish-shell/issues/5532>).
- complete -C foo now works as expected, rather than requiring
complete -Cfoo.
- complete has a new --force-files option, to re-enable file
completions. This allows sudo -E and pacman -Qo to complete
correctly (#5646
<https://github.com/fish-shell/fish-shell/issues/5646>).
- argparse now defaults to showing the current function name (instead
of argparse) in its errors, making --name often superfluous
(#5835
<https://github.com/fish-shell/fish-shell/issues/5835>).
- argparse has a new --ignore-unknown option to keep
unrecognized options, allowing multiple argparse passes to parse options
(#5367
<https://github.com/fish-shell/fish-shell/issues/5367>).
- argparse correctly handles flag value validation of options that
only have short names (#5864
<https://github.com/fish-shell/fish-shell/issues/5864>).
- read -S (short option of --shell) is recognised correctly
(#5660
<https://github.com/fish-shell/fish-shell/issues/5660>).
- read understands --list, which acts like --array in
reading all arguments into a list inside a single variable, but is better
named (#5846
<https://github.com/fish-shell/fish-shell/issues/5846>).
- read has a new option, --tokenize, which splits a string
into variables according to the shell’s tokenization rules,
considering quoting, escaping, and so on (#3823
<https://github.com/fish-shell/fish-shell/issues/3823>).
- read interacts more correctly with the deprecated $IFS
variable, in particular removing multiple separators when splitting a
variable into a list (#6406
<https://github.com/fish-shell/fish-shell/issues/6406>),
matching other shells.
- fish_indent now handles semicolons better, including leaving them
in place for ; and and ; or instead of breaking the line
(#5859
<https://github.com/fish-shell/fish-shell/issues/5859>).
- fish_indent --write now supports multiple file arguments, indenting
them in turn.
- The default read limit has been increased to 100MiB (#5267
<https://github.com/fish-shell/fish-shell/issues/5267>).
- math now also understands x for multiplication, provided it
is followed by whitespace (#5906
<https://github.com/fish-shell/fish-shell/issues/5906>).
- math reports the right error when incorrect syntax is used inside
parentheses (#6063
<https://github.com/fish-shell/fish-shell/issues/6063>), and
warns when unsupported logical operations are used (#6096
<https://github.com/fish-shell/fish-shell/issues/6096>).
- functions --erase now also prevents fish from autoloading a
function for the first time (#5951
<https://github.com/fish-shell/fish-shell/issues/5951>).
- jobs --last returns 0 to indicate success when a job is found
(#6104
<https://github.com/fish-shell/fish-shell/issues/6104>).
- commandline -p and commandline -j now split on
&& and || in addition to ; and &
(#6214
<https://github.com/fish-shell/fish-shell/issues/6214>).
- A bug where string split would drop empty strings if the output was
only empty strings has been fixed (#5987
<https://github.com/fish-shell/fish-shell/issues/5987>).
- eval no long creates a new local variable scope, but affects
variables in the scope it is called from (#4443
<https://github.com/fish-shell/fish-shell/issues/4443>).
source still creates a new local scope.
- abbr has a new --query option to check for the existence of
an abbreviation.
- Local values for fish_complete_path and fish_function_path
are now ignored; only their global values are respected.
- Syntax error reports now display a marker in the correct position
(#5812
<https://github.com/fish-shell/fish-shell/issues/5812>).
- Empty universal variables may now be exported (#5992
<https://github.com/fish-shell/fish-shell/issues/5992>).
- Exported universal variables are no longer imported into the global scope,
preventing shadowing. This makes it easier to change such variables for
all fish sessions and avoids breakage when the value is a list of multiple
elements (#5258
<https://github.com/fish-shell/fish-shell/issues/5258>).
- A bug where for could use invalid variable names has been fixed
(#5800
<https://github.com/fish-shell/fish-shell/issues/5800>).
- A bug where local variables would not be exported to functions has been
fixed (#6153
<https://github.com/fish-shell/fish-shell/issues/6153>).
- The null command (:) now always exits successfully, rather than
passing through the previous exit status (#6022
<https://github.com/fish-shell/fish-shell/issues/6022>).
- The output of functions FUNCTION matches the declaration of the
function, correctly including comments or blank lines (#5285
<https://github.com/fish-shell/fish-shell/issues/5285>), and
correctly includes any --wraps flags (#1625
<https://github.com/fish-shell/fish-shell/issues/1625>).
- type supports a new option, --short, which suppress function
expansion (#6403
<https://github.com/fish-shell/fish-shell/issues/6403>).
- type --path with a function argument will now output the path to
the file containing the definition of that function, if it exists.
- type --force-path with an argument that cannot be found now
correctly outputs nothing, as documented (#6411
<https://github.com/fish-shell/fish-shell/issues/6411>).
- The $hostname variable is no longer truncated to 32 characters
(#5758
<https://github.com/fish-shell/fish-shell/issues/5758>).
- Line numbers in function backtraces are calculated correctly (#6350
<https://github.com/fish-shell/fish-shell/issues/6350>).
- A new fish_cancel event is emitted when the command line is
cancelled, which is useful for terminal integration (#5973
<https://github.com/fish-shell/fish-shell/issues/5973>).
Interactive improvements
- New Base16 color options are available through the Web-based configuration
(#6504
<https://github.com/fish-shell/fish-shell/issues/6504>).
- fish only parses /etc/paths on macOS in login shells, matching the
bash implementation (#5637
<https://github.com/fish-shell/fish-shell/issues/5637>) and
avoiding changes to path ordering in child shells (#5456
<https://github.com/fish-shell/fish-shell/issues/5456>). It
now ignores blank lines like the bash implementation (#5809
<https://github.com/fish-shell/fish-shell/issues/5809>).
- The locale is now reloaded when the LOCPATH variable is changed
(#5815
<https://github.com/fish-shell/fish-shell/issues/5815>).
- read no longer keeps a history, making it suitable for operations
that shouldn’t end up there, like password entry (#5904
<https://github.com/fish-shell/fish-shell/issues/5904>).
- dirh outputs its stack in the correct order (#5477
<https://github.com/fish-shell/fish-shell/issues/5477>), and
behaves as documented when universal variables are used for its stack
(#5797
<https://github.com/fish-shell/fish-shell/issues/5797>).
- funced and the edit-commandline-in-buffer bindings did not work in
fish 3.0 when the $EDITOR variable contained spaces; this has been
corrected (#5625
<https://github.com/fish-shell/fish-shell/issues/5625>).
- Builtins now pipe their help output to a pager automatically (#6227
<https://github.com/fish-shell/fish-shell/issues/6227>).
- set_color now colors the --print-colors output in the
matching colors if it is going to a terminal.
- fish now underlines every valid entered path instead of just the last one
(#5872
<https://github.com/fish-shell/fish-shell/issues/5872>).
- When syntax highlighting a string with an unclosed quote, only the quote
itself will be shown as an error, instead of the whole argument.
- Syntax highlighting works correctly with variables as commands
(#5658
<https://github.com/fish-shell/fish-shell/issues/5658>) and
redirections to close file descriptors (#6092
<https://github.com/fish-shell/fish-shell/issues/6092>).
- help works properly on Windows Subsytem for Linux (#5759
<https://github.com/fish-shell/fish-shell/issues/5759>,
#6338
<https://github.com/fish-shell/fish-shell/issues/6338>).
- A bug where disown could crash the shell has been fixed
(#5720
<https://github.com/fish-shell/fish-shell/issues/5720>).
- fish will not autosuggest files ending with ~ unless there are no
other candidates, as these are generally backup files (#985
<https://github.com/fish-shell/fish-shell/issues/985>).
- Escape in the pager works correctly (#5818
<https://github.com/fish-shell/fish-shell/issues/5818>).
- Key bindings that call fg no longer leave the terminal in a broken
state (#2114
<https://github.com/fish-shell/fish-shell/issues/2114>).
- Brackets (#5831
<https://github.com/fish-shell/fish-shell/issues/5831>) and
filenames containing $ (#6060
<https://github.com/fish-shell/fish-shell/issues/6060>) are
completed with appropriate escaping.
- The output of complete and functions is now colorized in
interactive terminals.
- The Web-based configuration handles aliases that include single quotes
correctly (#6120
<https://github.com/fish-shell/fish-shell/issues/6120>), and
launches correctly under Termux (#6248
<https://github.com/fish-shell/fish-shell/issues/6248>) and
OpenBSD (#6522
<https://github.com/fish-shell/fish-shell/issues/6522>).
- function now correctly validates parameters for
--argument-names as valid variable names (#6147
<https://github.com/fish-shell/fish-shell/issues/6147>) and
correctly parses options following --argument-names, as in
“--argument-names foo --description bar”
(#6186
<https://github.com/fish-shell/fish-shell/issues/6186>).
- History newly imported from bash includes command lines using
&& or ||.
- The automatic generation of completions from manual pages is better
described in job and process listings, and no longer produces a warning
when exiting fish (#6269
<https://github.com/fish-shell/fish-shell/issues/6269>).
- In private mode, setting $fish_greeting to an empty string before
starting the private session will prevent the warning about history not
being saved from being printed (#6299
<https://github.com/fish-shell/fish-shell/issues/6299>).
- In the interactive editor, a line break (Enter) inside unclosed brackets
will insert a new line, rather than executing the command and producing an
error (#6316
<https://github.com/fish-shell/fish-shell/issues/6316>).
- Ctrl-C always repaints the prompt (#6394
<https://github.com/fish-shell/fish-shell/issues/6394>).
- When run interactively from another program (such as Python), fish will
correctly start a new process group, like other shells (#5909
<https://github.com/fish-shell/fish-shell/issues/5909>).
- Job identifiers (for example, for background jobs) are assigned more
logically (#6053
<https://github.com/fish-shell/fish-shell/issues/6053>).
- A bug where history would appear truncated if an empty command was
executed was fixed (#6032
<https://github.com/fish-shell/fish-shell/issues/6032>).
New or improved bindings
- Pasting strips leading spaces to avoid pasted commands being omitted from
the history (#4327
<https://github.com/fish-shell/fish-shell/issues/4327>).
- Shift-Left and Shift-Right now default to moving backwards and forwards by
one bigword (words separated by whitespace) (#1505
<https://github.com/fish-shell/fish-shell/issues/1505>).
- The default escape delay (to differentiate between the escape key and an
alt-combination) has been reduced to 30ms, down from 300ms for the default
mode and 100ms for Vi mode (#3904
<https://github.com/fish-shell/fish-shell/issues/3904>).
- The forward-bigword binding now interacts correctly with
autosuggestions (#5336
<https://github.com/fish-shell/fish-shell/issues/5336>).
- The fish_clipboard_* functions support Wayland by using
wl-clipboard <https://github.com/bugaevc/wl-clipboard>
(#5450
<https://github.com/fish-shell/fish-shell/issues/5450>).
- The nextd and prevd functions no longer print “Hit
end of history”, instead using a bell. They correctly store working
directories containing symbolic links (#6395
<https://github.com/fish-shell/fish-shell/issues/6395>).
- If a fish_mode_prompt function exists, Vi mode will only execute it
on mode-switch instead of the entire prompt. This should make it much more
responsive with slow prompts (#5783
<https://github.com/fish-shell/fish-shell/issues/5783>).
- The path-component bindings (like Ctrl-w) now also stop at
“:” and “@”, because those are used to denote
user and host in commands such as ssh (#5841
<https://github.com/fish-shell/fish-shell/issues/5841>).
- The NULL character can now be bound via bind -k nul. Terminals
often generate this character via control-space. (#3189
<https://github.com/fish-shell/fish-shell/issues/3189>).
- A new readline command expand-abbr can be used to trigger
abbreviation expansion (#5762
<https://github.com/fish-shell/fish-shell/issues/5762>).
- A new readline command, delete-or-exit, removes a character to the
right of the cursor or exits the shell if the command line is empty
(moving this functionality out of the delete-or-exit
function).
- The self-insert readline command will now insert the binding
sequence, if not empty.
- A new binding to prepend sudo, bound to Alt-S by default
(#6140
<https://github.com/fish-shell/fish-shell/issues/6140>).
- The Alt-W binding to describe a command should now work better with
multiline prompts (#6110
<https://github.com/fish-shell/fish-shell/issues/6110>)
- The Alt-H binding to open a command’s man page now tries to ignore
sudo (#6122
<https://github.com/fish-shell/fish-shell/issues/6122>).
- A new pair of bind functions, history-prefix-search-backward (and
forward), was introduced (#6143
<https://github.com/fish-shell/fish-shell/issues/6143>).
- Vi mode now supports R to enter replace mode (#6342
<https://github.com/fish-shell/fish-shell/issues/6342>), and
d0 to delete the current line (#6292
<https://github.com/fish-shell/fish-shell/issues/6292>).
- In Vi mode, hitting Enter in replace-one mode no longer erases the prompt
(#6298
<https://github.com/fish-shell/fish-shell/issues/6298>).
- Selections in Vi mode are inclusive, matching the actual behaviour of Vi
(#5770
<https://github.com/fish-shell/fish-shell/issues/5770>).
Improved prompts
- The Git prompt in informative mode now shows the number of stashes if
enabled.
- The Git prompt now has an option
($__fish_git_prompt_use_informative_chars) to use the (more modern)
informative characters without enabling informative mode.
- The default prompt now also features VCS integration and will color the
host if running via SSH (#6375
<https://github.com/fish-shell/fish-shell/issues/6375>).
- The default and example prompts print the pipe status if an earlier
command in the pipe fails.
- The default and example prompts try to resolve exit statuses to signal
names when appropriate.
- New fish_pager_color_ options have been added to control more
elements of the pager’s colors (#5524
<https://github.com/fish-shell/fish-shell/issues/5524>).
- Better detection and support for using fish from various system consoles,
where limited colors and special characters are supported (#5552
<https://github.com/fish-shell/fish-shell/issues/5552>).
- fish now tries to guess if the system supports Unicode 9 (and displays
emoji as wide), eliminating the need to set $fish_emoji_width in
most cases (#5722
<https://github.com/fish-shell/fish-shell/issues/5722>).
- Improvements to the display of wide characters, particularly Korean
characters and emoji (#5583
<https://github.com/fish-shell/fish-shell/issues/5583>,
#5729
<https://github.com/fish-shell/fish-shell/issues/5729>).
- The Vi mode cursor is correctly redrawn when regaining focus under
terminals that report focus (eg tmux) (#4788
<https://github.com/fish-shell/fish-shell/issues/4788>).
- Variables that control background colors (such as
fish_pager_color_search_match) can now use --reverse.
- •
- Added completions for
- aws
- bat (#6052
<https://github.com/fish-shell/fish-shell/issues/6052>)
- bosh (#5700
<https://github.com/fish-shell/fish-shell/issues/5700>)
- btrfs
- camcontrol
- cf (#5700
<https://github.com/fish-shell/fish-shell/issues/5700>)
- chronyc (#6496
<https://github.com/fish-shell/fish-shell/issues/6496>)
- code (#6205
<https://github.com/fish-shell/fish-shell/issues/6205>)
- cryptsetup (#6488
<https://github.com/fish-shell/fish-shell/issues/6488>)
- csc and csi (#6016
<https://github.com/fish-shell/fish-shell/issues/6016>)
- cwebp (#6034
<https://github.com/fish-shell/fish-shell/issues/6034>)
- cygpath and cygstart (#6239
<https://github.com/fish-shell/fish-shell/issues/6239>)
- epkginfo (#5829
<https://github.com/fish-shell/fish-shell/issues/5829>)
- ffmpeg, ffplay, and ffprobe (#5922
<https://github.com/fish-shell/fish-shell/issues/5922>)
- fsharpc and fsharpi (#6016
<https://github.com/fish-shell/fish-shell/issues/6016>)
- fzf (#6178
<https://github.com/fish-shell/fish-shell/issues/6178>)
- g++ (#6217
<https://github.com/fish-shell/fish-shell/issues/6217>)
- gpg1 (#6139
<https://github.com/fish-shell/fish-shell/issues/6139>)
- gpg2 (#6062
<https://github.com/fish-shell/fish-shell/issues/6062>)
- grub-mkrescue (#6182
<https://github.com/fish-shell/fish-shell/issues/6182>)
- hledger (#6043
<https://github.com/fish-shell/fish-shell/issues/6043>)
- hwinfo (#6496
<https://github.com/fish-shell/fish-shell/issues/6496>)
- irb (#6260
<https://github.com/fish-shell/fish-shell/issues/6260>)
- iw (#6232
<https://github.com/fish-shell/fish-shell/issues/6232>)
- kak
- keepassxc-cli (#6505
<https://github.com/fish-shell/fish-shell/issues/6505>)
- keybase (#6410
<https://github.com/fish-shell/fish-shell/issues/6410>)
- loginctl (#6501
<https://github.com/fish-shell/fish-shell/issues/6501>)
- lz4, lz4c and lz4cat (#6364
<https://github.com/fish-shell/fish-shell/issues/6364>)
- mariner (#5718
<https://github.com/fish-shell/fish-shell/issues/5718>)
- nethack (#6240
<https://github.com/fish-shell/fish-shell/issues/6240>)
- patool (#6083
<https://github.com/fish-shell/fish-shell/issues/6083>)
- phpunit (#6197
<https://github.com/fish-shell/fish-shell/issues/6197>)
- plutil (#6301
<https://github.com/fish-shell/fish-shell/issues/6301>)
- pzstd (#6364
<https://github.com/fish-shell/fish-shell/issues/6364>)
- qubes-gpg-client (#6067
<https://github.com/fish-shell/fish-shell/issues/6067>)
- resolvectl (#6501
<https://github.com/fish-shell/fish-shell/issues/6501>)
- rg
- rustup
- sfdx (#6149
<https://github.com/fish-shell/fish-shell/issues/6149>)
- speedtest and speedtest-cli (#5840
<https://github.com/fish-shell/fish-shell/issues/5840>)
- src (#6026
<https://github.com/fish-shell/fish-shell/issues/6026>)
- tokei (#6085
<https://github.com/fish-shell/fish-shell/issues/6085>)
- tsc (#6016
<https://github.com/fish-shell/fish-shell/issues/6016>)
- unlz4 (#6364
<https://github.com/fish-shell/fish-shell/issues/6364>)
- unzstd (#6364
<https://github.com/fish-shell/fish-shell/issues/6364>)
- vbc (#6016
<https://github.com/fish-shell/fish-shell/issues/6016>)
- zpaq (#6245
<https://github.com/fish-shell/fish-shell/issues/6245>)
- zstd, zstdcat, zstdgrep, zstdless and
zstdmt (#6364
<https://github.com/fish-shell/fish-shell/issues/6364>)
- Lots of improvements to completions.
- Selecting short options which also have a long name from the completion
pager is possible (#5634
<https://github.com/fish-shell/fish-shell/issues/5634>).
- Tab completion will no longer add trailing spaces if they already exist
(#6107
<https://github.com/fish-shell/fish-shell/issues/6107>).
- Completion of subcommands to builtins like and or not now
works correctly (#6249
<https://github.com/fish-shell/fish-shell/issues/6249>).
- Completion of arguments to short options works correctly when multiple
short options are used together (#332
<https://github.com/fish-shell/fish-shell/issues/332>).
- Activating completion in the middle of an invalid completion does not move
the cursor any more, making it easier to fix a mistake (#4124
<https://github.com/fish-shell/fish-shell/issues/4124>).
- Completion in empty commandlines now lists all available commands.
- Functions listed as completions could previously leak parts of the
function as other completions; this has been fixed.
Deprecations and removed features
- The vcs-prompt functions have been promoted to names without
double-underscore, so __fish_git_prompt is now fish_git_prompt,
__fish_vcs_prompt is now fish_vcs_prompt, __fish_hg_prompt is now
fish_hg_prompt and __fish_svn_prompt is now fish_svn_prompt. Shims at the
old names have been added, and the variables have kept their old names
(#5586
<https://github.com/fish-shell/fish-shell/issues/5586>).
- string replace has an additional round of escaping in the
replacement expression, so escaping backslashes requires many escapes (eg
string replace -ra '([ab])' '\\\\\\\$1' a). The new feature flag
regex-easyesc can be used to disable this, so that the same effect
can be achieved with string replace -ra '([ab])' '\\\\$1' a
(#5556
<https://github.com/fish-shell/fish-shell/issues/5556>). As a
reminder, the intention behind feature flags is that this will eventually
become the default and then only option, so scripts should be
updated.
- The fish_vi_mode function, deprecated in fish 2.3, has been
removed. Use fish_vi_key_bindings instead (#6372
<https://github.com/fish-shell/fish-shell/issues/6372>).
For distributors and developers
- fish 3.0 introduced a CMake-based build system. In fish 3.1, both the
Autotools-based build and legacy Xcode build system have been removed,
leaving only the CMake build system. All distributors and developers must
install CMake.
- fish now depends on the common tee external command, for the
psub process substitution function.
- The documentation is now built with Sphinx. The old Doxygen-based
documentation system has been removed. Developers, and distributors who
wish to rebuild the documentation, must install Sphinx.
- The INTERNAL_WCWIDTH build option has been removed, as fish now
always uses an internal wcwidth function. It has a number of
configuration options that make it more suitable for general use
(#5777
<https://github.com/fish-shell/fish-shell/issues/5777>).
- mandoc can now be used to format the output from --help if
nroff is not installed, reducing the number of external
dependencies on systems with mandoc installed (#5489
<https://github.com/fish-shell/fish-shell/issues/5489>).
- Some bugs preventing building on Solaris-derived systems such as Illumos
were fixed (#5458
<https://github.com/fish-shell/fish-shell/issues/5458>,
#5461
<https://github.com/fish-shell/fish-shell/issues/5461>,
#5611
<https://github.com/fish-shell/fish-shell/issues/5611>).
- Completions for npm, bower and yarn no longer require
the jq utility for full functionality, but will use Python instead
if it is available.
- The paths for completions, functions and configuration snippets have been
extended. On systems that define XDG_DATA_DIRS, each of the
directories in this variable are searched in the subdirectories
fish/vendor_completions.d, fish/vendor_functions.d, and
fish/vendor_conf.d respectively. On systems that do not define this
variable in the environment, the vendor directories are searched for in
both the installation prefix and the default “extra”
directory, which now defaults to /usr/local (#5029
<https://github.com/fish-shell/fish-shell/issues/5029>).
----
This release of fish fixes an issue discovered in fish 3.0.1.
Fixes and improvements
- •
- The PWD environment variable is now ignored if it does not resolve to the
true working directory, fixing strange behaviour in terminals started by
editors and IDEs (#5647
<https://github.com/fish-shell/fish-shell/issues/5647>).
If you are upgrading from version 2.7.1 or before, please also
review the release notes for 3.0.1, 3.0.0 and 3.0b1 (included below).
This release of fish fixes a number of major issues discovered in
fish 3.0.0.
Fixes and improvements
- exec does not complain about running foreground jobs when called
(#5449
<https://github.com/fish-shell/fish-shell/issues/5449>).
- while loops now evaluate to the last executed command in the loop body (or
zero if the body was empty), matching POSIX semantics (#4982
<https://github.com/fish-shell/fish-shell/issues/4982>).
- read --silent no longer echoes to the tty when run from a
non-interactive script (#5519
<https://github.com/fish-shell/fish-shell/issues/5519>).
- On macOS, path entries with spaces in /etc/paths and
/etc/paths.d now correctly set path entries with spaces. Likewise,
MANPATH is correctly set from /etc/manpaths and
/etc/manpaths.d (#5481
<https://github.com/fish-shell/fish-shell/issues/5481>).
- fish starts correctly under Cygwin/MSYS2 (#5426
<https://github.com/fish-shell/fish-shell/issues/5426>).
- The pager-toggle-search binding (Ctrl-S by default) will now
activate the search field, even when the pager is not focused.
- The error when a command is not found is now printed a single time,
instead of once per argument (#5588
<https://github.com/fish-shell/fish-shell/issues/5588>).
- Fixes and improvements to the git completions, including printing correct
paths with older git versions, fuzzy matching again, reducing unnecessary
offers of root paths (starting with :/) (#5578
<https://github.com/fish-shell/fish-shell/issues/5578>,
#5574
<https://github.com/fish-shell/fish-shell/issues/5574>,
#5476
<https://github.com/fish-shell/fish-shell/issues/5476>), and
ignoring shell aliases, so enterprising users can set up the wrapping
command (via set -g __fish_git_alias_$command $whatitwraps)
(#5412
<https://github.com/fish-shell/fish-shell/issues/5412>).
- Significant performance improvements to core shell functions (#5447
<https://github.com/fish-shell/fish-shell/issues/5447>) and
to the kill completions (#5541
<https://github.com/fish-shell/fish-shell/issues/5541>).
- Starting in symbolically-linked working directories works correctly
(#5525
<https://github.com/fish-shell/fish-shell/issues/5525>).
- The default fish_title function no longer contains extra spaces
(#5517
<https://github.com/fish-shell/fish-shell/issues/5517>).
- The nim prompt now works correctly when chosen in the Web-based
configuration (#5490
<https://github.com/fish-shell/fish-shell/issues/5490>).
- string now prints help to stdout, like other builtins (#5495
<https://github.com/fish-shell/fish-shell/issues/5495>).
- Killing the terminal while fish is in vi normal mode will no longer send
it spinning and eating CPU. (#5528
<https://github.com/fish-shell/fish-shell/issues/5528>)
- A number of crashes have been fixed (#5550
<https://github.com/fish-shell/fish-shell/issues/5550>,
#5548
<https://github.com/fish-shell/fish-shell/issues/5548>,
#5479
<https://github.com/fish-shell/fish-shell/issues/5479>,
#5453
<https://github.com/fish-shell/fish-shell/issues/5453>).
- Improvements to the documentation and certain completions.
Known issues
There is one significant known issue that was not corrected before
the release:
- •
- fish does not run correctly under Windows Services for Linux before
Windows 10 version 1809/17763, and the message warning of this may not be
displayed (#5619
<https://github.com/fish-shell/fish-shell/issues/5619>).
If you are upgrading from version 2.7.1 or before, please also
review the release notes for 3.0.0 and 3.0b1 (included below).
----
fish 3 is a major release, which introduces some breaking changes
alongside improved functionality. Although most existing scripts will
continue to work, they should be reviewed against the list contained in the
3.0b1 release notes below.
Compared to the beta release of fish 3.0b1, fish version
3.0.0:
- builds correctly against musl libc (#5407
<https://github.com/fish-shell/fish-shell/issues/5407>)
- handles huge numeric arguments to test correctly (#5414
<https://github.com/fish-shell/fish-shell/issues/5414>)
- removes the history colouring introduced in 3.0b1, which did not always
work correctly
There is one significant known issue which was not able to be
corrected before the release:
- •
- fish 3.0.0 builds on Cygwin (#5423
<https://github.com/fish-shell/fish-shell/issues/5423>), but
does not run correctly (#5426
<https://github.com/fish-shell/fish-shell/issues/5426>) and
will result in a hanging terminal when started. Cygwin users are
encouraged to continue using 2.7.1 until a release which corrects this is
available.
If you are upgrading from version 2.7.1 or before, please also
review the release notes for 3.0b1 (included below).
----
fish 3 is a major release, which introduces some breaking changes
alongside improved functionality. Although most existing scripts will
continue to work, they should be reviewed against the list below.
- Process and job expansion has largely been removed. % will no
longer perform these expansions, except for %self for the PID of
the current shell. Additionally, job management commands (disown,
wait, bg, fg and kill) will expand job
specifiers starting with % (#4230
<https://github.com/fish-shell/fish-shell/issues/4230>,
#1202
<https://github.com/fish-shell/fish-shell/issues/1202>).
- set x[1] x[2] a b, to set multiple elements of an array at once, is
no longer valid syntax (#4236
<https://github.com/fish-shell/fish-shell/issues/4236>).
- A literal {} now expands to itself, rather than nothing. This makes
working with find -exec easier (#1109
<https://github.com/fish-shell/fish-shell/issues/1109>,
#4632
<https://github.com/fish-shell/fish-shell/issues/4632>).
- Literally accessing a zero-index is now illegal syntax and is caught by
the parser (#4862
<https://github.com/fish-shell/fish-shell/issues/4862>).
(fish indices start at 1)
- Successive commas in brace expansions are handled in less surprising
manner. For example, {,,,} expands to four empty strings rather
than an empty string, a comma and an empty string again (#3002
<https://github.com/fish-shell/fish-shell/issues/3002>,
#4632
<https://github.com/fish-shell/fish-shell/issues/4632>).
- for loop control variables are no longer local to the for
block (#1935
<https://github.com/fish-shell/fish-shell/issues/1935>).
- Variables set in if and while conditions are available
outside the block (#4820
<https://github.com/fish-shell/fish-shell/issues/4820>).
- Local exported (set -lx) vars are now visible to functions
(#1091
<https://github.com/fish-shell/fish-shell/issues/1091>).
- The new math builtin (see below) does not support logical
expressions; test should be used instead (#4777
<https://github.com/fish-shell/fish-shell/issues/4777>).
- Range expansion will now behave sensibly when given a single positive and
negative index ($foo[5..-1] or $foo[-1..5]), clamping to the
last valid index without changing direction if the list has fewer elements
than expected.
- read now uses -s as short for --silent (à la
bash); --shell’s abbreviation (formerly -s) is
now -S instead (#4490
<https://github.com/fish-shell/fish-shell/issues/4490>).
- cd no longer resolves symlinks. fish now maintains a virtual path,
matching other shells (#3350
<https://github.com/fish-shell/fish-shell/issues/3350>).
- source now requires an explicit - as the filename to read
from the terminal (#2633
<https://github.com/fish-shell/fish-shell/issues/2633>).
- Arguments to end are now errors, instead of being silently
ignored.
- The names argparse, read, set, status,
test and [ are now reserved and not allowed as function
names. This prevents users unintentionally breaking stuff (#3000
<https://github.com/fish-shell/fish-shell/issues/3000>).
- The fish_user_abbreviations variable is no longer used;
abbreviations will be migrated to the new storage format
automatically.
- The FISH_READ_BYTE_LIMIT variable is now called
fish_byte_limit (#4414
<https://github.com/fish-shell/fish-shell/issues/4414>).
- Environment variables are no longer split into arrays based on the record
separator character on startup. Instead, variables are not split, unless
their name ends in PATH, in which case they are split on colons
(#436
<https://github.com/fish-shell/fish-shell/issues/436>).
- The history builtin’s --with-time option has been
removed; this has been deprecated in favor of --show-time since
2.7.0 (#4403
<https://github.com/fish-shell/fish-shell/issues/4403>).
- The internal variables __fish_datadir and __fish_sysconfdir
are now known as __fish_data_dir and __fish_sysconf_dir
respectively.
With the release of fish 3, a number of features have been marked
for removal in the future. All users are encouraged to explore alternatives.
A small number of these features are currently behind feature flags, which
are turned on at present but may be turned off by default in the future.
A new feature flags mechanism is added for staging deprecations
and breaking changes. Feature flags may be specified at launch with fish
--features ... or by setting the universal fish_features
variable. (#4940
<https://github.com/fish-shell/fish-shell/issues/4940>)
- The use of the IFS variable for read is deprecated;
IFS will be ignored in the future (#4156
<https://github.com/fish-shell/fish-shell/issues/4156>). Use
the read --delimiter option instead.
- The function --on-process-exit switch will be removed in future
(#4700
<https://github.com/fish-shell/fish-shell/issues/4700>). Use
the fish_exit event instead: function --on-event
fish_exit.
- $_ is deprecated and will removed in the future (#813
<https://github.com/fish-shell/fish-shell/issues/813>). Use
status current-command in a command substitution instead.
- ^ as a redirection deprecated and will be removed in the future.
(#4394
<https://github.com/fish-shell/fish-shell/issues/4394>). Use
2> to redirect stderr. This is controlled by the
stderr-nocaret feature flag.
- ? as a glob (wildcard) is deprecated and will be removed in the
future (#4520
<https://github.com/fish-shell/fish-shell/issues/4520>). This
is controlled by the qmark-noglob feature flag.
Notable fixes and improvements
Syntax changes and new commands
- fish now supports && (like and), || (like
or), and ! (like not), for better migration from
POSIX-compliant shells (#4620
<https://github.com/fish-shell/fish-shell/issues/4620>).
- Variables may be used as commands (#154
<https://github.com/fish-shell/fish-shell/issues/154>).
- fish may be started in private mode via fish --private. Private
mode fish sessions do not have access to the history file and any commands
evaluated in private mode are not persisted for future sessions. A session
variable $fish_private_mode can be queried to detect private mode
and adjust the behavior of scripts accordingly to respect the
user’s wish for privacy.
- A new wait command for waiting on backgrounded processes
(#4498
<https://github.com/fish-shell/fish-shell/issues/4498>).
- math is now a builtin rather than a wrapper around bc
(#3157
<https://github.com/fish-shell/fish-shell/issues/3157>).
Floating point computations is now used by default, and can be controlled
with the new --scale option (#4478
<https://github.com/fish-shell/fish-shell/issues/4478>).
- Setting $PATH no longer warns on non-existent directories, allowing
for a single $PATH to be shared across machines (eg via dotfiles)
(#2969
<https://github.com/fish-shell/fish-shell/issues/2969>).
- while sets $status to a non-zero value if the loop is not
executed (#4982
<https://github.com/fish-shell/fish-shell/issues/4982>).
- Command substitution output is now limited to 10 MB by default, controlled
by the fish_read_limit variable (#3822
<https://github.com/fish-shell/fish-shell/issues/3822>).
Notably, this is larger than most operating systems’ argument size
limit, so trying to pass argument lists this size to external commands has
never worked.
- The machine hostname, where available, is now exposed as the
$hostname reserved variable. This removes the dependency on the
hostname executable (#4422
<https://github.com/fish-shell/fish-shell/issues/4422>).
- Bare bind invocations in config.fish now work. The
fish_user_key_bindings function is no longer necessary, but will
still be executed if it exists (#5191
<https://github.com/fish-shell/fish-shell/issues/5191>).
- $fish_pid and $last_pid are available as replacements for
%self and %last.
- alias has a new --save option to save the generated function
immediately (#4878
<https://github.com/fish-shell/fish-shell/issues/4878>).
- bind has a new --silent option to ignore bind requests for
named keys not available under the current terminal (#4188
<https://github.com/fish-shell/fish-shell/issues/4188>,
#4431
<https://github.com/fish-shell/fish-shell/issues/4431>).
- complete has a new --keep-order option to show the provided
or dynamically-generated argument list in the same order as specified,
rather than alphabetically (#361
<https://github.com/fish-shell/fish-shell/issues/361>).
- exec prompts for confirmation if background jobs are running.
- funced has a new --save option to automatically save the
edited function after successfully editing (#4668
<https://github.com/fish-shell/fish-shell/issues/4668>).
- functions has a new --handlers option to show functions
registered as event handlers (#4694
<https://github.com/fish-shell/fish-shell/issues/4694>).
- history search supports globs for wildcard searching (#3136
<https://github.com/fish-shell/fish-shell/issues/3136>) and
has a new --reverse option to show entries from oldest to newest
(#4375
<https://github.com/fish-shell/fish-shell/issues/4375>).
- jobs has a new --quiet option to silence the output.
- read has a new --delimiter option for splitting input into
arrays (#4256
<https://github.com/fish-shell/fish-shell/issues/4256>).
- read writes directly to stdout if called without arguments
(#4407
<https://github.com/fish-shell/fish-shell/issues/4407>).
- read can now read individual lines into separate variables without
consuming the input in its entirety via the new /--line
option.
- set has new --append and --prepend options
(#1326
<https://github.com/fish-shell/fish-shell/issues/1326>).
- string match with an empty pattern and --entire in glob mode
now matches everything instead of nothing (#4971
<https://github.com/fish-shell/fish-shell/issues/4971>).
- string split supports a new --no-empty option to exclude
empty strings from the result (#4779
<https://github.com/fish-shell/fish-shell/issues/4779>).
- string has new subcommands split0 and join0 for
working with NUL-delimited output.
- string no longer stops processing text after NUL characters
(#4605
<https://github.com/fish-shell/fish-shell/issues/4605>)
- string escape has a new --style regex option for escaping
strings to be matched literally in string regex operations.
- test now supports floating point values in numeric
comparisons.
Interactive improvements
- A pipe at the end of a line now allows the job to continue on the next
line (#1285
<https://github.com/fish-shell/fish-shell/issues/1285>).
- Italics and dim support out of the box on macOS for Terminal.app and iTerm
(#4436
<https://github.com/fish-shell/fish-shell/issues/4436>).
- cd tab completions no longer descend into the deepest unambiguous
path (#4649
<https://github.com/fish-shell/fish-shell/issues/4649>).
- Pager navigation has been improved. Most notably, moving down now wraps
around, moving up from the commandline now jumps to the last element and
moving right and left now reverse each other even when wrapping around
(#4680
<https://github.com/fish-shell/fish-shell/issues/4680>).
- Typing normal characters while the completion pager is active no longer
shows the search field. Instead it enters them into the command line, and
ends paging (#2249
<https://github.com/fish-shell/fish-shell/issues/2249>).
- A new input binding pager-toggle-search toggles the search field in
the completions pager on and off. By default, this is bound to
Ctrl-S.
- Searching in the pager now does a full fuzzy search (#5213
<https://github.com/fish-shell/fish-shell/issues/5213>).
- The pager will now show the full command instead of just its last line if
the number of completions is large (#4702
<https://github.com/fish-shell/fish-shell/issues/4702>).
- Abbreviations can be tab-completed (#3233
<https://github.com/fish-shell/fish-shell/issues/3233>).
- Tildes in file names are now properly escaped in completions (#2274
<https://github.com/fish-shell/fish-shell/issues/2274>).
- Wrapping completions (from complete --wraps or function
--wraps) can now inject arguments. For example, complete gco
--wraps 'git checkout' now works properly (#1976
<https://github.com/fish-shell/fish-shell/issues/1976>). The
alias function has been updated to respect this behavior.
- Path completions now support expansions, meaning expressions like
python ~/<TAB> now provides file suggestions just like any
other relative or absolute path. (This includes support for other
expansions, too.)
- Autosuggestions try to avoid arguments that are already present in the
command line.
- Notifications about crashed processes are now always shown, even in
command substitutions (#4962
<https://github.com/fish-shell/fish-shell/issues/4962>).
- The screen is no longer reset after a BEL, fixing graphical glitches
(#3693
<https://github.com/fish-shell/fish-shell/issues/3693>).
- vi-mode now supports ‘;’ and ‘,’ motions. This
introduces new {forward,backward}-jump-till and repeat-jump{,-reverse}
bind functions (#5140
<https://github.com/fish-shell/fish-shell/issues/5140>).
- The *y vi-mode binding now works (#5100
<https://github.com/fish-shell/fish-shell/issues/5100>).
- True color is now enabled in neovim by default (#2792
<https://github.com/fish-shell/fish-shell/issues/2792>).
- Terminal size variables ($COLUMNS/$LINES) are now updated
before fish_prompt is called, allowing the prompt to react
(#904
<https://github.com/fish-shell/fish-shell/issues/904>).
- Multi-line prompts no longer repeat when the terminal is resized
(#2320
<https://github.com/fish-shell/fish-shell/issues/2320>).
- xclip support has been added to the clipboard integration
(#5020
<https://github.com/fish-shell/fish-shell/issues/5020>).
- The Alt-P keybinding paginates the last command if the command line is
empty.
- $cmd_duration is no longer reset when no command is executed
(#5011
<https://github.com/fish-shell/fish-shell/issues/5011>).
- Deleting a one-character word no longer erases the next word as well
(#4747
<https://github.com/fish-shell/fish-shell/issues/4747>).
- Token history search (Alt-Up) omits duplicate entries (#4795
<https://github.com/fish-shell/fish-shell/issues/4795>).
- The fish_escape_delay_ms timeout, allowing the use of the escape
key both on its own and as part of a control sequence, was applied to all
control characters; this has been reduced to just the escape key.
- Completing a function shows the description properly (#5206
<https://github.com/fish-shell/fish-shell/issues/5206>).
- commandline can now be used to set the commandline for the next
command, restoring a behavior in 3.4.1 (#8807
<https://github.com/fish-shell/fish-shell/issues/8807>).
- Added completions for
- ansible, including ansible-galaxy, ansible-playbook
and ansible-vault (#4697
<https://github.com/fish-shell/fish-shell/issues/4697>)
- bb-power (#4800
<https://github.com/fish-shell/fish-shell/issues/4800>)
- bd (#4472
<https://github.com/fish-shell/fish-shell/issues/4472>)
- bower
- clang and clang++ (#4174
<https://github.com/fish-shell/fish-shell/issues/4174>)
- conda (#4837
<https://github.com/fish-shell/fish-shell/issues/4837>)
- configure (for autoconf-generated files only)
- curl
- doas (#5196
<https://github.com/fish-shell/fish-shell/issues/5196>)
- ebuild (#4911
<https://github.com/fish-shell/fish-shell/issues/4911>)
- emaint (#4758
<https://github.com/fish-shell/fish-shell/issues/4758>)
- eopkg (#4600
<https://github.com/fish-shell/fish-shell/issues/4600>)
- exercism (#4495
<https://github.com/fish-shell/fish-shell/issues/4495>)
- hjson
- hugo (#4529
<https://github.com/fish-shell/fish-shell/issues/4529>)
- j (from autojump #4344
<https://github.com/fish-shell/fish-shell/issues/4344>)
- jbake (#4814
<https://github.com/fish-shell/fish-shell/issues/4814>)
- jhipster (#4472
<https://github.com/fish-shell/fish-shell/issues/4472>)
- kitty
- kldload
- kldunload
- makensis (#5242
<https://github.com/fish-shell/fish-shell/issues/5242>)
- meson
- mkdocs (#4906
<https://github.com/fish-shell/fish-shell/issues/4906>)
- ngrok (#4642
<https://github.com/fish-shell/fish-shell/issues/4642>)
- OpenBSD’s pkg_add, pkg_delete, pkg_info,
pfctl, rcctl, signify, and vmctl (#4584
<https://github.com/fish-shell/fish-shell/issues/4584>)
- openocd
- optipng
- opkg (#5168
<https://github.com/fish-shell/fish-shell/issues/5168>)
- pandoc (#2937
<https://github.com/fish-shell/fish-shell/issues/2937>)
- port (#4737
<https://github.com/fish-shell/fish-shell/issues/4737>)
- powerpill (#4800
<https://github.com/fish-shell/fish-shell/issues/4800>)
- pstack (#5135
<https://github.com/fish-shell/fish-shell/issues/5135>)
- serve (#5026
<https://github.com/fish-shell/fish-shell/issues/5026>)
- ttx
- unzip
- virsh (#5113
<https://github.com/fish-shell/fish-shell/issues/5113>)
- xclip (#5126
<https://github.com/fish-shell/fish-shell/issues/5126>)
- xsv
- zfs and zpool (#4608
<https://github.com/fish-shell/fish-shell/issues/4608>)
- Lots of improvements to completions (especially darcs (#5112
<https://github.com/fish-shell/fish-shell/issues/5112>),
git, hg and sudo).
- Completions for yarn and npm now require the
all-the-package-names NPM package for full functionality.
- Completions for bower and yarn now require the jq
utility for full functionality.
- Improved French translations.
- Significant performance improvements to abbr (#4048
<https://github.com/fish-shell/fish-shell/issues/4048>),
setting variables (#4200
<https://github.com/fish-shell/fish-shell/issues/4200>,
#4341
<https://github.com/fish-shell/fish-shell/issues/4341>),
executing functions, globs (#4579
<https://github.com/fish-shell/fish-shell/issues/4579>),
string reading from standard input (#4610
<https://github.com/fish-shell/fish-shell/issues/4610>), and
slicing history (in particular, $history[1] for the last executed
command).
- Fish’s internal wcwidth function has been updated to deal with
newer Unicode, and the width of some characters can be configured via the
fish_ambiguous_width (#5149
<https://github.com/fish-shell/fish-shell/issues/5149>) and
fish_emoji_width (#2652
<https://github.com/fish-shell/fish-shell/issues/2652>)
variables. Alternatively, a new build-time option INTERNAL_WCWIDTH can be
used to use the system’s wcwidth instead (#4816
<https://github.com/fish-shell/fish-shell/issues/4816>).
- functions correctly supports -d as the short form of
--description. (#5105
<https://github.com/fish-shell/fish-shell/issues/5105>)
- /etc/paths is now parsed like macOS’ bash
path_helper, fixing $PATH order (#4336
<https://github.com/fish-shell/fish-shell/issues/4336>,
#4852
<https://github.com/fish-shell/fish-shell/issues/4852>) on
macOS.
- Using a read-only variable in a for loop produces an error, rather
than silently producing incorrect results (#4342
<https://github.com/fish-shell/fish-shell/issues/4342>).
- The universal variables filename no longer contains the hostname or MAC
address. It is now at the fixed location
.config/fish/fish_variables (#1912
<https://github.com/fish-shell/fish-shell/issues/1912>).
- Exported variables in the global or universal scope no longer have their
exported status affected by local variables (#2611
<https://github.com/fish-shell/fish-shell/issues/2611>).
- Major rework of terminal and job handling to eliminate bugs (#3805
<https://github.com/fish-shell/fish-shell/issues/3805>,
#3952
<https://github.com/fish-shell/fish-shell/issues/3952>,
#4178
<https://github.com/fish-shell/fish-shell/issues/4178>,
#4235
<https://github.com/fish-shell/fish-shell/issues/4235>,
#4238
<https://github.com/fish-shell/fish-shell/issues/4238>,
#4540
<https://github.com/fish-shell/fish-shell/issues/4540>,
#4929
<https://github.com/fish-shell/fish-shell/issues/4929>,
#5210
<https://github.com/fish-shell/fish-shell/issues/5210>).
- Improvements to the manual page completion generator (#2937
<https://github.com/fish-shell/fish-shell/issues/2937>,
#4313
<https://github.com/fish-shell/fish-shell/issues/4313>).
- suspend --force now works correctly (#4672
<https://github.com/fish-shell/fish-shell/issues/4672>).
- Pressing Ctrl-C while running a script now reliably terminates fish
(#5253
<https://github.com/fish-shell/fish-shell/issues/5253>).
For distributors and developers
- fish ships with a new build system based on CMake. CMake 3.2 is the
minimum required version. Although the autotools-based Makefile and the
Xcode project are still shipped with this release, they will be removed in
the near future. All distributors and developers are encouraged to migrate
to the CMake build.
- Build scripts for most platforms no longer require bash, using the
standard sh instead.
- The hostname command is no longer required for fish to
operate.
–
This release of fish fixes an issue where iTerm 2 on macOS would
display a warning about paste bracketing being left on when starting a new
fish session (#4521
<https://github.com/fish-shell/fish-shell/issues/4521>).
If you are upgrading from version 2.6.0 or before, please also
review the release notes for 2.7.0 and 2.7b1 (included below).
–
There are no major changes between 2.7b1 and 2.7.0. If you are
upgrading from version 2.6.0 or before, please also review the release notes
for 2.7b1 (included below).
Xcode builds and macOS packages could not be produced with 2.7b1,
but this is fixed in 2.7.0.
–
- A new cdh (change directory using recent history) command provides
a more friendly alternative to prevd/nextd and pushd/popd (#2847
<https://github.com/fish-shell/fish-shell/issues/2847>).
- A new argparse command is available to allow fish script to parse
arguments with the same behavior as builtin commands. This also includes
the fish_opt helper command. (#4190
<https://github.com/fish-shell/fish-shell/issues/4190>).
- Invalid array indexes are now silently ignored (#826
<https://github.com/fish-shell/fish-shell/issues/826>,
#4127
<https://github.com/fish-shell/fish-shell/issues/4127>).
- Improvements to the debugging facility, including a prompt specific to the
debugger (fish_breakpoint_prompt) and a status is-breakpoint
subcommand (#1310
<https://github.com/fish-shell/fish-shell/issues/1310>).
- string supports new lower and upper subcommands, for
altering the case of strings (#4080
<https://github.com/fish-shell/fish-shell/issues/4080>). The
case changing is not locale-aware yet.- string escape has a new
--style=xxx flag where xxx can be script, var,
or url (#4150
<https://github.com/fish-shell/fish-shell/issues/4150>), and
can be reversed with string unescape (#3543
<https://github.com/fish-shell/fish-shell/issues/3543>).
- History can now be split into sessions with the fish_history
variable, or not saved to disk at all (#102
<https://github.com/fish-shell/fish-shell/issues/102>).
- Read history is now controlled by the fish_history variable rather
than the --mode-name flag (#1504
<https://github.com/fish-shell/fish-shell/issues/1504>).
- command now supports an --all flag to report all directories
with the command. which is no longer a runtime dependency
(#2778
<https://github.com/fish-shell/fish-shell/issues/2778>).
- fish can run commands before starting an interactive session using the new
--init-command/-C options (#4164
<https://github.com/fish-shell/fish-shell/issues/4164>).
- set has a new --show option to show lots of information
about variables (#4265
<https://github.com/fish-shell/fish-shell/issues/4265>).
Other significant changes
- The COLUMNS and LINES environment variables are now
correctly set the first time fish_prompt is run (#4141
<https://github.com/fish-shell/fish-shell/issues/4141>).
- complete’s --no-files option works as intended
(#112
<https://github.com/fish-shell/fish-shell/issues/112>).
- echo -h now correctly echoes -h in line with other shells
(#4120
<https://github.com/fish-shell/fish-shell/issues/4120>).
- The export compatibility function now returns zero on success,
rather than always returning 1 (#4435
<https://github.com/fish-shell/fish-shell/issues/4435>).
- Stop converting empty elements in MANPATH to “.”
(#4158
<https://github.com/fish-shell/fish-shell/issues/4158>). The
behavior being changed was introduced in fish 2.6.0.
- count -h and count --help now return 1 rather than produce
command help output (#4189
<https://github.com/fish-shell/fish-shell/issues/4189>).
- An attempt to read which stops because too much data is available
still defines the variables given as parameters (#4180
<https://github.com/fish-shell/fish-shell/issues/4180>).
- A regression in fish 2.4.0 which prevented pushd +1 from working
has been fixed (#4091
<https://github.com/fish-shell/fish-shell/issues/4091>).
- A regression in fish 2.6.0 where multiple read commands in
non-interactive scripts were broken has been fixed (#4206
<https://github.com/fish-shell/fish-shell/issues/4206>).
- A regression in fish 2.6.0 involving universal variables with side-effects
at startup such as set -U fish_escape_delay_ms 10 has been fixed
(#4196
<https://github.com/fish-shell/fish-shell/issues/4196>).
- Added completions for:
- as (#4130
<https://github.com/fish-shell/fish-shell/issues/4130>)
- cdh (#2847
<https://github.com/fish-shell/fish-shell/issues/2847>)
- dhcpd (#4115
<https://github.com/fish-shell/fish-shell/issues/4115>)
- ezjail-admin (#4324
<https://github.com/fish-shell/fish-shell/issues/4324>)
- Fabric’s fab (#4153
<https://github.com/fish-shell/fish-shell/issues/4153>)
- grub-file (#4119
<https://github.com/fish-shell/fish-shell/issues/4119>)
- grub-install (#4119
<https://github.com/fish-shell/fish-shell/issues/4119>)
- jest (#4142
<https://github.com/fish-shell/fish-shell/issues/4142>)
- kdeconnect-cli
- magneto (#4043
<https://github.com/fish-shell/fish-shell/issues/4043>,
#4108
<https://github.com/fish-shell/fish-shell/issues/4108>)
- mdadm (#4198
<https://github.com/fish-shell/fish-shell/issues/4198>)
- passwd (#4209
<https://github.com/fish-shell/fish-shell/issues/4209>)
- pip and pipenv (#4448
<https://github.com/fish-shell/fish-shell/issues/4448>)
- s3cmd (#4332
<https://github.com/fish-shell/fish-shell/issues/4332>)
- sbt (#4347
<https://github.com/fish-shell/fish-shell/issues/4347>)
- snap (#4215
<https://github.com/fish-shell/fish-shell/issues/4215>)
- Sublime Text 3’s subl (#4277
<https://github.com/fish-shell/fish-shell/issues/4277>)
- Lots of improvements to completions.
- Updated Chinese and French translations.
- Improved completions for:
- apt
- cd (#4061
<https://github.com/fish-shell/fish-shell/issues/4061>)
- composer (#4295
<https://github.com/fish-shell/fish-shell/issues/4295>)
- eopkg
- flatpak (#4456
<https://github.com/fish-shell/fish-shell/issues/4456>)
- git (#4117
<https://github.com/fish-shell/fish-shell/issues/4117>,
#4147
<https://github.com/fish-shell/fish-shell/issues/4147>,
#4329
<https://github.com/fish-shell/fish-shell/issues/4329>,
#4368
<https://github.com/fish-shell/fish-shell/issues/4368>)
- gphoto2
- killall (#4052
<https://github.com/fish-shell/fish-shell/issues/4052>)
- ln
- npm (#4241
<https://github.com/fish-shell/fish-shell/issues/4241>)
- ssh (#4377
<https://github.com/fish-shell/fish-shell/issues/4377>)
- tail
- xdg-mime (#4333
<https://github.com/fish-shell/fish-shell/issues/4333>)
- zypper (#4325
<https://github.com/fish-shell/fish-shell/issues/4325>)
Since the beta release of fish 2.6b1, fish version 2.6.0 contains
a number of minor fixes, new completions for magneto (#4043
<https://github.com/fish-shell/fish-shell/issues/4043>), and
improvements to the documentation.
Known issues
- •
- Apple macOS Sierra 10.12.5 introduced a problem with launching web
browsers from other programs using AppleScript. This affects the fish Web
configuration (fish_config); users on these platforms will need to
manually open the address displayed in the terminal, such as by copying
and pasting it into a browser. This problem will be fixed with macOS
10.12.6.
If you are upgrading from version 2.5.0 or before, please also
review the release notes for 2.6b1 (included below).
----
Notable fixes and improvements
- Jobs running in the background can now be removed from the list of jobs
with the new disown builtin, which behaves like the same command in
other shells (#2810
<https://github.com/fish-shell/fish-shell/issues/2810>).
- Command substitutions now have access to the terminal, like in other
shells. This allows tools like fzf to work properly (#1362
<https://github.com/fish-shell/fish-shell/issues/1362>,
#3922
<https://github.com/fish-shell/fish-shell/issues/3922>).
- In cases where the operating system does not report the size of the
terminal, the COLUMNS and LINES environment variables are
used; if they are unset, a default of 80x24 is assumed.
- New French (#3772
<https://github.com/fish-shell/fish-shell/issues/3772> &
#3788
<https://github.com/fish-shell/fish-shell/issues/3788>) and
improved German (#3834
<https://github.com/fish-shell/fish-shell/issues/3834>)
translations.
- fish no longer depends on the which external command.
Other significant changes
- Performance improvements in launching processes, including major
reductions in signal blocking. Although this has been heavily tested, it
may cause problems in some circumstances; set the
FISH_NO_SIGNAL_BLOCK variable to 0 in your fish configuration file
to return to the old behaviour (#2007
<https://github.com/fish-shell/fish-shell/issues/2007>).
- Performance improvements in prompts and functions that set lots of colours
(#3793
<https://github.com/fish-shell/fish-shell/issues/3793>).
- The Delete key no longer deletes backwards (a regression in 2.5.0).
- functions supports a new --details option, which identifies
where the function was loaded from (#3295
<https://github.com/fish-shell/fish-shell/issues/3295>), and
a --details --verbose option which includes the function
description (#597
<https://github.com/fish-shell/fish-shell/issues/597>).
- read will read up to 10 MiB by default, leaving the target variable
empty and exiting with status 122 if the line is too long. You can set a
different limit with the FISH_READ_BYTE_LIMIT variable.
- read supports a new --silent option to hide the characters
typed (#838
<https://github.com/fish-shell/fish-shell/issues/838>), for
when reading sensitive data from the terminal. read also now
accepts simple strings for the prompt (rather than scripts) with the new
-P and --prompt-str options (#802
<https://github.com/fish-shell/fish-shell/issues/802>).
- export and setenv now understand colon-separated
PATH, CDPATH and MANPATH variables.
- setenv is no longer a simple alias for set -gx and will
complain, just like the csh version, if given more than one value
(#4103
<https://github.com/fish-shell/fish-shell/issues/4103>).
- bind supports a new --list-modes option (#3872
<https://github.com/fish-shell/fish-shell/issues/3872>).
- bg will check all of its arguments before backgrounding any jobs;
any invalid arguments will cause a failure, but non-existent (eg recently
exited) jobs are ignored (#3909
<https://github.com/fish-shell/fish-shell/issues/3909>).
- funced warns if the function being edited has not been modified
(#3961
<https://github.com/fish-shell/fish-shell/issues/3961>).
- printf correctly outputs “long long” integers
(#3352
<https://github.com/fish-shell/fish-shell/issues/3352>).
- status supports a new current-function subcommand to print
the current function name (#1743
<https://github.com/fish-shell/fish-shell/issues/1743>).
- string supports a new repeat subcommand (#3864
<https://github.com/fish-shell/fish-shell/issues/3864>).
string match supports a new --entire option to emit the
entire line matched by a pattern (#3957
<https://github.com/fish-shell/fish-shell/issues/3957>).
string replace supports a new --filter option to only emit
lines which underwent a replacement (#3348
<https://github.com/fish-shell/fish-shell/issues/3348>).
- test supports the -k option to test for sticky bits
(#733
<https://github.com/fish-shell/fish-shell/issues/733>).
- umask understands symbolic modes (#738
<https://github.com/fish-shell/fish-shell/issues/738>).
- Empty components in the CDPATH, MANPATH and PATH
variables are now converted to “.” (#2106
<https://github.com/fish-shell/fish-shell/issues/2106>,
#3914
<https://github.com/fish-shell/fish-shell/issues/3914>).
- New versions of ncurses (6.0 and up) wipe terminal scrollback buffers with
certain commands; the C-l binding tries to avoid this (#2855
<https://github.com/fish-shell/fish-shell/issues/2855>).
- Some systems’ su implementations do not set the USER
environment variable; it is now reset for root users (#3916
<https://github.com/fish-shell/fish-shell/issues/3916>).
- Under terminals which support it, bracketed paste is enabled, escaping
problematic characters for security and convience (#3871
<https://github.com/fish-shell/fish-shell/issues/3871>).
Inside single quotes ('), single quotes and backslashes in pasted
text are escaped (#967
<https://github.com/fish-shell/fish-shell/issues/967>). The
fish_clipboard_paste function (bound to C-v by default) is
still the recommended pasting method where possible as it includes this
functionality and more.
- Processes in pipelines are no longer signalled as soon as one command in
the pipeline has completed (#1926
<https://github.com/fish-shell/fish-shell/issues/1926>). This
behaviour matches other shells mre closely.
- All functions requiring Python work with whichever version of Python is
installed (#3970
<https://github.com/fish-shell/fish-shell/issues/3970>).
Python 3 is preferred, but Python 2.6 remains the minimum version
required.
- The color of the cancellation character can be controlled by the
fish_color_cancel variable (#3963
<https://github.com/fish-shell/fish-shell/issues/3963>).
- Added completions for:
- caddy (#4008
<https://github.com/fish-shell/fish-shell/issues/4008>)
- castnow (#3744
<https://github.com/fish-shell/fish-shell/issues/3744>)
- climate (#3760
<https://github.com/fish-shell/fish-shell/issues/3760>)
- flatpak
- gradle (#3859
<https://github.com/fish-shell/fish-shell/issues/3859>)
- gsettings (#4001
<https://github.com/fish-shell/fish-shell/issues/4001>)
- helm (#3829
<https://github.com/fish-shell/fish-shell/issues/3829>)
- i3-msg (#3787
<https://github.com/fish-shell/fish-shell/issues/3787>)
- ipset (#3924
<https://github.com/fish-shell/fish-shell/issues/3924>)
- jq (#3804
<https://github.com/fish-shell/fish-shell/issues/3804>)
- light (#3752
<https://github.com/fish-shell/fish-shell/issues/3752>)
- minikube (#3778
<https://github.com/fish-shell/fish-shell/issues/3778>)
- mocha (#3828
<https://github.com/fish-shell/fish-shell/issues/3828>)
- mkdosfs (#4017
<https://github.com/fish-shell/fish-shell/issues/4017>)
- pv (#3773
<https://github.com/fish-shell/fish-shell/issues/3773>)
- setsid (#3791
<https://github.com/fish-shell/fish-shell/issues/3791>)
- terraform (#3960
<https://github.com/fish-shell/fish-shell/issues/3960>)
- usermod (#3775
<https://github.com/fish-shell/fish-shell/issues/3775>)
- xinput
- yarn (#3816
<https://github.com/fish-shell/fish-shell/issues/3816>)
- Improved completions for adb (#3853
<https://github.com/fish-shell/fish-shell/issues/3853>),
apt (#3771
<https://github.com/fish-shell/fish-shell/issues/3771>),
bzr (#3769
<https://github.com/fish-shell/fish-shell/issues/3769>),
dconf, git (including #3743
<https://github.com/fish-shell/fish-shell/issues/3743>),
grep (#3789
<https://github.com/fish-shell/fish-shell/issues/3789>),
go (#3789
<https://github.com/fish-shell/fish-shell/issues/3789>),
help (#3789
<https://github.com/fish-shell/fish-shell/issues/3789>),
hg (#3975
<https://github.com/fish-shell/fish-shell/issues/3975>),
htop (#3789
<https://github.com/fish-shell/fish-shell/issues/3789>),
killall (#3996
<https://github.com/fish-shell/fish-shell/issues/3996>),
lua, man (#3762
<https://github.com/fish-shell/fish-shell/issues/3762>),
mount (#3764
<https://github.com/fish-shell/fish-shell/issues/3764> &
#3841
<https://github.com/fish-shell/fish-shell/issues/3841>),
obnam (#3924
<https://github.com/fish-shell/fish-shell/issues/3924>),
perl (#3856
<https://github.com/fish-shell/fish-shell/issues/3856>),
portmaster (#3950
<https://github.com/fish-shell/fish-shell/issues/3950>),
python (#3840
<https://github.com/fish-shell/fish-shell/issues/3840>),
ssh (#3781
<https://github.com/fish-shell/fish-shell/issues/3781>),
scp (#3781
<https://github.com/fish-shell/fish-shell/issues/3781>),
systemctl (#3757
<https://github.com/fish-shell/fish-shell/issues/3757>) and
udisks (#3764
<https://github.com/fish-shell/fish-shell/issues/3764>).
----
There are no major changes between 2.5b1 and 2.5.0. If you are
upgrading from version 2.4.0 or before, please also review the release notes
for 2.5b1 (included below).
Notable fixes and improvements
- •
- The Home, End, Insert, Delete, Page Up and Page Down keys work in Vi-style
key bindings (#3731
<https://github.com/fish-shell/fish-shell/issues/3731>).
----
Starting with version 2.5, fish requires a more up-to-date version
of C++, specifically C++11 (from 2011). This affects some older
platforms:
For users building from source, GCC’s g++ 4.8 or later, or
LLVM’s clang 3.3 or later, are known to work. Older platforms may
require a newer compiler installed.
Unfortunately, because of the complexity of the toolchain, binary
packages are no longer published by the fish-shell developers for the
following platforms:
- Red Hat Enterprise Linux and CentOS 5 & 6 for 64-bit builds
- Ubuntu 12.04 (EoLTS April 2017)
- Debian 7 (EoLTS May 2018)
Installing newer version of fish on these systems will require
building from source.
Starting with version 2.5, fish requires a C++11 standard library
on OS X 10.6 (“SnowLeopard”). If this library is not
installed, you will see this error: dyld: Library not loaded:
/usr/lib/libc++.1.dylib
MacPorts is the easiest way to obtain this library. After
installing the SnowLeopard MacPorts release from the install page, run:
sudo port -v install libcxx
Now fish should launch successfully. (Please open an issue if it
does not.)
This is only necessary on 10.6. OS X 10.7 and later include the
required library by default.
Other significant changes
- Attempting to exit with running processes in the background produces a
warning, then signals them to terminate if a second attempt to exit is
made. This brings the behaviour for running background processes into line
with stopped processes. (#3497
<https://github.com/fish-shell/fish-shell/issues/3497>)
- random can now have start, stop and step values specified, or the
new choice subcommand can be used to pick an argument from a list
(#3619
<https://github.com/fish-shell/fish-shell/issues/3619>).
- A new key bindings preset, fish_hybrid_key_bindings, including all
the Emacs-style and Vi-style bindings, which behaves like
fish_vi_key_bindings in fish 2.3.0 (#3556
<https://github.com/fish-shell/fish-shell/issues/3556>).
- function now returns an error when called with invalid options,
rather than defining the function anyway (#3574
<https://github.com/fish-shell/fish-shell/issues/3574>). This
was a regression present in fish 2.3 and 2.4.0.
- fish no longer prints a warning when it identifies a running instance of
an old version (2.1.0 and earlier). Changes to universal variables may not
propagate between these old versions and 2.5b1.
- Improved compatiblity with Android (#3585
<https://github.com/fish-shell/fish-shell/issues/3585>),
MSYS/mingw (#2360
<https://github.com/fish-shell/fish-shell/issues/2360>), and
Solaris (#3456
<https://github.com/fish-shell/fish-shell/issues/3456>,
#3340
<https://github.com/fish-shell/fish-shell/issues/3340>).
- Like other shells, the test builting now returns an error for
numeric operations on invalid integers (#3346
<https://github.com/fish-shell/fish-shell/issues/3346>,
#3581
<https://github.com/fish-shell/fish-shell/issues/3581>).
- complete no longer recognises --authoritative and
--unauthoritative options, and they are marked as obsolete.
- status accepts subcommands, and should be used like status
is-interactive. The old options continue to be supported for the
foreseeable future (#3526
<https://github.com/fish-shell/fish-shell/issues/3526>),
although only one subcommand or option can be specified at a time.
- Selection mode (used with “begin-selection”) no longer
selects a character the cursor does not move over (#3684
<https://github.com/fish-shell/fish-shell/issues/3684>).
- List indexes are handled better, and a bit more liberally in some cases
(echo $PATH[1 .. 3] is now valid) (#3579
<https://github.com/fish-shell/fish-shell/issues/3579>).
- The fish_mode_prompt function is now simply a stub around
fish_default_mode_prompt, which allows the mode prompt to be
included more easily in customised prompt functions (#3641
<https://github.com/fish-shell/fish-shell/issues/3641>).
Notable fixes and improvements
- alias, run without options or arguments, lists all defined aliases,
and aliases now include a description in the function signature that
identifies them.
- complete accepts empty strings as descriptions (#3557
<https://github.com/fish-shell/fish-shell/issues/3557>).
- command accepts -q/--quiet in combination with
--search (#3591
<https://github.com/fish-shell/fish-shell/issues/3591>),
providing a simple way of checking whether a command exists in
scripts.
- Abbreviations can now be renamed with abbr --rename OLD_KEY NEW_KEY
(#3610
<https://github.com/fish-shell/fish-shell/issues/3610>).
- The command synopses printed by --help options work better with
copying and pasting (#2673
<https://github.com/fish-shell/fish-shell/issues/2673>).
- help launches the browser specified by the $fish_help_browser
variable if it is set (#3131
<https://github.com/fish-shell/fish-shell/issues/3131>).
- History merging could lose items under certain circumstances and is now
fixed (#3496
<https://github.com/fish-shell/fish-shell/issues/3496>).
- The $status variable is now set to 123 when a syntactically invalid
command is entered (#3616
<https://github.com/fish-shell/fish-shell/issues/3616>).
- Exiting fish now signals all background processes to terminate, not just
stopped jobs (#3497
<https://github.com/fish-shell/fish-shell/issues/3497>).
- A new prompt_hostname function which prints a hostname suitable for
use in prompts (#3482
<https://github.com/fish-shell/fish-shell/issues/3482>).
- The __fish_man_page function (bound to Alt-h by default) now tries
to recognize subcommands (e.g. git add will now open the
“git-add” man page) (#3678
<https://github.com/fish-shell/fish-shell/issues/3678>).
- A new function edit_command_buffer (bound to Alt-e & Alt-v by
default) to edit the command buffer in an external editor (#1215
<https://github.com/fish-shell/fish-shell/issues/1215>,
#3627
<https://github.com/fish-shell/fish-shell/issues/3627>).
- set_color now supports italics (--italics), dim
(--dim) and reverse (--reverse) modes (#3650
<https://github.com/fish-shell/fish-shell/issues/3650>).
- Filesystems with very slow locking (eg incorrectly-configured NFS) will no
longer slow fish down (#685
<https://github.com/fish-shell/fish-shell/issues/685>).
- Improved completions for apt (#3695
<https://github.com/fish-shell/fish-shell/issues/3695>),
fusermount (#3642
<https://github.com/fish-shell/fish-shell/issues/3642>),
make (#3628
<https://github.com/fish-shell/fish-shell/issues/3628>),
netctl-auto (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>),
nmcli (#3648
<https://github.com/fish-shell/fish-shell/issues/3648>),
pygmentize (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>), and
tar (#3719
<https://github.com/fish-shell/fish-shell/issues/3719>).
- Added completions for:
- VBoxHeadless (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- VBoxSDL (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- base64 (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- caffeinate (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- dconf (#3638
<https://github.com/fish-shell/fish-shell/issues/3638>)
- dig (#3495
<https://github.com/fish-shell/fish-shell/issues/3495>)
- dpkg-reconfigure (#3521
<https://github.com/fish-shell/fish-shell/issues/3521> &
#3522
<https://github.com/fish-shell/fish-shell/issues/3522>)
- feh (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- launchctl (#3682
<https://github.com/fish-shell/fish-shell/issues/3682>)
- lxc (#3554
<https://github.com/fish-shell/fish-shell/issues/3554> &
#3564
<https://github.com/fish-shell/fish-shell/issues/3564>),
- mddiagnose (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- mdfind (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- mdimport (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- mdls (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- mdutil (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- mkvextract (#3492
<https://github.com/fish-shell/fish-shell/issues/3492>)
- nvram (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
- objdump (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- sysbench (#3491
<https://github.com/fish-shell/fish-shell/issues/3491>)
- tmutil (#3524
<https://github.com/fish-shell/fish-shell/issues/3524>)
----
There are no major changes between 2.4b1 and 2.4.0.
Notable fixes and improvements
- The documentation is now generated properly and with the correct version
identifier.
- Automatic cursor changes are now only enabled on the subset of XTerm
versions known to support them, resolving a problem where older versions
printed garbage to the terminal before and after every prompt
(#3499
<https://github.com/fish-shell/fish-shell/issues/3499>).
- Improved the title set in Apple Terminal.app.
- Added completions for defaults and improved completions for
diskutil (#3478
<https://github.com/fish-shell/fish-shell/issues/3478>).
----
Significant changes
- The clipboard integration has been revamped with explicit bindings. The
killring commands no longer copy from, or paste to, the X11 clipboard -
use the new copy (C-x) and paste (C-v) bindings instead. The
clipboard is now available on OS X as well as systems using X11
(e.g. Linux). (#3061
<https://github.com/fish-shell/fish-shell/issues/3061>)
- history uses subcommands (history delete) rather than
options (history --delete) for its actions (#3367
<https://github.com/fish-shell/fish-shell/issues/3367>). You
can no longer specify multiple actions via flags (e.g., history
--delete --save something).
- New history options have been added, including --max=n to
limit the number of history entries, --show-time option to show
timestamps (#3175
<https://github.com/fish-shell/fish-shell/issues/3175>,
#3244
<https://github.com/fish-shell/fish-shell/issues/3244>), and
--null to null terminate history entries in the search output.
- history search is now case-insensitive by default (which also
affects history delete) (#3236
<https://github.com/fish-shell/fish-shell/issues/3236>).
- history delete now correctly handles multiline commands (#31
<https://github.com/fish-shell/fish-shell/issues/31>).
- Vi-style bindings no longer include all of the default emacs-style
bindings; instead, they share some definitions (#3068
<https://github.com/fish-shell/fish-shell/issues/3068>).
- If there is no locale set in the environment, various known system
configuration files will be checked for a default. If no locale can be
found, en_US-UTF.8 will be used (#277
<https://github.com/fish-shell/fish-shell/issues/277>).
- A number followed by a caret (e.g. 5^) is no longer treated
as a redirection (#1873
<https://github.com/fish-shell/fish-shell/issues/1873>).
- The $version special variable can be overwritten, so that it can be
used for other purposes if required.
Notable fixes and improvements
- The fish_realpath builtin has been renamed to realpath and
made compatible with GNU realpath when run without arguments
(#3400
<https://github.com/fish-shell/fish-shell/issues/3400>). It
is used only for systems without a realpath or grealpath
utility (#3374
<https://github.com/fish-shell/fish-shell/issues/3374>).
- Improved color handling on terminals/consoles with 8-16 colors,
particularly the use of bright named color (#3176
<https://github.com/fish-shell/fish-shell/issues/3176>,
#3260
<https://github.com/fish-shell/fish-shell/issues/3260>).
- fish_indent can now read from files given as arguments, rather than
just standard input (#3037
<https://github.com/fish-shell/fish-shell/issues/3037>).
- Fuzzy tab completions behave in a less surprising manner (#3090
<https://github.com/fish-shell/fish-shell/issues/3090>,
#3211
<https://github.com/fish-shell/fish-shell/issues/3211>).
- jobs should only print its header line once (#3127
<https://github.com/fish-shell/fish-shell/issues/3127>).
- Wildcards in redirections are highlighted appropriately (#2789
<https://github.com/fish-shell/fish-shell/issues/2789>).
- Suggestions will be offered more often, like after removing characters
(#3069
<https://github.com/fish-shell/fish-shell/issues/3069>).
- history --merge now correctly interleaves items in chronological
order (#2312
<https://github.com/fish-shell/fish-shell/issues/2312>).
- Options for fish_indent have been aligned with the other binaries -
in particular, -d now means --debug. The --dump
option has been renamed to --dump-parse-tree (#3191
<https://github.com/fish-shell/fish-shell/issues/3191>).
- The display of bindings in the Web-based configuration has been greatly
improved (#3325
<https://github.com/fish-shell/fish-shell/issues/3325>), as
has the rendering of prompts (#2924
<https://github.com/fish-shell/fish-shell/issues/2924>).
- fish should no longer hang using 100% CPU in the C locale (#3214
<https://github.com/fish-shell/fish-shell/issues/3214>).
- A bug in FreeBSD 11 & 12, Dragonfly BSD & illumos prevented fish
from working correctly on these platforms under UTF-8 locales; fish now
avoids the buggy behaviour (#3050
<https://github.com/fish-shell/fish-shell/issues/3050>).
- Prompts which show git repository information (via
__fish_git_prompt) are faster in large repositories (#3294
<https://github.com/fish-shell/fish-shell/issues/3294>) and
slow filesystems (#3083
<https://github.com/fish-shell/fish-shell/issues/3083>).
- fish 2.3.0 reintroduced a problem where the greeting was printed even when
using read; this has been corrected again (#3261
<https://github.com/fish-shell/fish-shell/issues/3261>).
- Vi mode changes the cursor depending on the current mode (#3215
<https://github.com/fish-shell/fish-shell/issues/3215>).
- Command lines with escaped space characters at the end tab-complete
correctly (#2447
<https://github.com/fish-shell/fish-shell/issues/2447>).
- Added completions for:
- arcanist (#3256
<https://github.com/fish-shell/fish-shell/issues/3256>)
- connmanctl (#3419
<https://github.com/fish-shell/fish-shell/issues/3419>)
- figlet (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- mdbook (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- ninja (#3415
<https://github.com/fish-shell/fish-shell/issues/3415>)
- p4, the Perforce client (#3314
<https://github.com/fish-shell/fish-shell/issues/3314>)
- pygmentize (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- ranger (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>)
- Improved completions for aura (#3297
<https://github.com/fish-shell/fish-shell/issues/3297>),
abbr (#3267
<https://github.com/fish-shell/fish-shell/issues/3267>),
brew (#3309
<https://github.com/fish-shell/fish-shell/issues/3309>),
chown (#3380
<https://github.com/fish-shell/fish-shell/issues/3380>,
#3383
<https://github.com/fish-shell/fish-shell/issues/3383>),cygport
(#3392
<https://github.com/fish-shell/fish-shell/issues/3392>),
git (#3274
<https://github.com/fish-shell/fish-shell/issues/3274>,
#3226
<https://github.com/fish-shell/fish-shell/issues/3226>,
#3225
<https://github.com/fish-shell/fish-shell/issues/3225>,
#3094
<https://github.com/fish-shell/fish-shell/issues/3094>,
#3087
<https://github.com/fish-shell/fish-shell/issues/3087>,
#3035
<https://github.com/fish-shell/fish-shell/issues/3035>,
#3021
<https://github.com/fish-shell/fish-shell/issues/3021>,
#2982
<https://github.com/fish-shell/fish-shell/issues/2982>,
#3230
<https://github.com/fish-shell/fish-shell/issues/3230>),
kill & pkill (#3200
<https://github.com/fish-shell/fish-shell/issues/3200>),
screen (#3271
<https://github.com/fish-shell/fish-shell/issues/3271>),
wget (#3470
<https://github.com/fish-shell/fish-shell/issues/3470>), and
xz (#3378
<https://github.com/fish-shell/fish-shell/issues/3378>).
- Distributors, packagers and developers will notice that the build process
produces more succinct output by default; use make V=1 to get
verbose output (#3248
<https://github.com/fish-shell/fish-shell/issues/3248>).
- Improved compatibility with minor platforms including musl (#2988
<https://github.com/fish-shell/fish-shell/issues/2988>),
Cygwin (#2993
<https://github.com/fish-shell/fish-shell/issues/2993>),
Android (#3441
<https://github.com/fish-shell/fish-shell/issues/3441>,
#3442
<https://github.com/fish-shell/fish-shell/issues/3442>),
Haiku (#3322
<https://github.com/fish-shell/fish-shell/issues/3322>) and
Solaris .
----
This is a functionality and bugfix release. This release does not
contain all the changes to fish since the last release, but fixes a number
of issues directly affecting users at present and includes a small number of
new features.
Significant changes
- A new fish_key_reader binary for decoding interactive keypresses
(#2991
<https://github.com/fish-shell/fish-shell/issues/2991>).
- fish_mode_prompt has been updated to reflect the changes in the way
the Vi input mode is set up (#3067
<https://github.com/fish-shell/fish-shell/issues/3067>),
making this more reliable.
- fish_config can now properly be launched from the OS X app bundle
(#3140
<https://github.com/fish-shell/fish-shell/issues/3140>).
Notable fixes and improvements
- Extra lines were sometimes inserted into the output under Windows (Cygwin
and Microsoft Windows Subsystem for Linux) due to TTY timestamps not being
updated (#2859
<https://github.com/fish-shell/fish-shell/issues/2859>).
- The string builtin’s match mode now handles the
combination of -rnv (match, invert and count) correctly
(#3098
<https://github.com/fish-shell/fish-shell/issues/3098>).
- Improvements to TTY special character handling (#3064
<https://github.com/fish-shell/fish-shell/issues/3064>),
locale handling (#3124
<https://github.com/fish-shell/fish-shell/issues/3124>) and
terminal environment variable handling (#3060
<https://github.com/fish-shell/fish-shell/issues/3060>).
- Work towards handling the terminal modes for external commands launched
from initialisation files (#2980
<https://github.com/fish-shell/fish-shell/issues/2980>).
- Ease the upgrade path from fish 2.2.0 and before by warning users to
restart fish if the string builtin is not available (#3057
<https://github.com/fish-shell/fish-shell/issues/3057>).
- type -a now syntax-colorizes function source output.
- Added completions for alsamixer, godoc, gofmt,
goimports, gorename, lscpu, mkdir,
modinfo, netctl-auto, poweroff, termite,
udisksctl and xz (#3123
<https://github.com/fish-shell/fish-shell/issues/3123>).
- Improved completions for apt (#3097
<https://github.com/fish-shell/fish-shell/issues/3097>),
aura (#3102
<https://github.com/fish-shell/fish-shell/issues/3102>),git
(#3114
<https://github.com/fish-shell/fish-shell/issues/3114>),
npm (#3158
<https://github.com/fish-shell/fish-shell/issues/3158>),
string and suspend (#3154
<https://github.com/fish-shell/fish-shell/issues/3154>).
----
There are no significant changes between 2.3.0 and 2.3b2.
Other notable fixes and improvements
- abbr now allows non-letter keys (#2996
<https://github.com/fish-shell/fish-shell/issues/2996>).
- Define a few extra colours on first start (#2987
<https://github.com/fish-shell/fish-shell/issues/2987>).
- Multiple documentation updates.
- Added completions for rmmod (#3007
<https://github.com/fish-shell/fish-shell/issues/3007>).
- Improved completions for git (#2998
<https://github.com/fish-shell/fish-shell/issues/2998>).
Known issues
- •
- Interactive commands started from fish configuration files or from the
-c option may, under certain circumstances, be started with
incorrect terminal modes and fail to behave as expected. A fix is planned
but requires further testing (#2619
<https://github.com/fish-shell/fish-shell/issues/2619>).
----
Significant changes
- A new fish_realpath builtin and associated function to allow the
use of realpath even on those platforms that don’t ship an
appropriate command (#2932
<https://github.com/fish-shell/fish-shell/issues/2932>).
- Alt-# toggles the current command line between commented and uncommented
states, making it easy to save a command in history without executing
it.
- The fish_vi_mode function is now deprecated in favour of
fish_vi_key_bindings.
Other notable fixes and improvements
- Fix the build on Cygwin (#2952
<https://github.com/fish-shell/fish-shell/issues/2952>) and
RedHat Enterprise Linux/CentOS 5 (#2955
<https://github.com/fish-shell/fish-shell/issues/2955>).
- Avoid confusing the terminal line driver with non-printing characters in
fish_title (#2453
<https://github.com/fish-shell/fish-shell/issues/2453>).
- Improved completions for busctl, git (#2585
<https://github.com/fish-shell/fish-shell/issues/2585>,
#2879
<https://github.com/fish-shell/fish-shell/issues/2879>,
#2984
<https://github.com/fish-shell/fish-shell/issues/2984>), and
netctl.
----
Significant Changes
- A new string builtin to handle… strings! This builtin will
measure, split, search and replace text strings, including using regular
expressions. It can also be used to turn lists into plain strings using
join. string can be used in place of sed,
grep, tr, cut, and awk in many situations.
(#2296
<https://github.com/fish-shell/fish-shell/issues/2296>)
- Allow using escape as the Meta modifier key, by waiting after seeing an
escape character wait up to 300ms for an additional character. This is
consistent with readline (e.g. bash) and can be configured via the
fish_escape_delay_ms variable. This allows using escape as the Meta
modifier. (#1356
<https://github.com/fish-shell/fish-shell/issues/1356>)
- Add new directories for vendor functions and configuration snippets
(#2500
<https://github.com/fish-shell/fish-shell/issues/2500>)
- A new fish_realpath builtin and associated realpath function
should allow scripts to resolve path names via realpath regardless
of whether there is an external command of that name; albeit with some
limitations. See the associated documentation.
Backward-incompatible changes
- Unmatched globs will now cause an error, except when used with for,
set or count (#2719
<https://github.com/fish-shell/fish-shell/issues/2719>)
- and and or will now bind to the closest if or
while, allowing compound conditions without begin and
end (#1428
<https://github.com/fish-shell/fish-shell/issues/1428>)
- set -ql now searches up to function scope for variables
(#2502
<https://github.com/fish-shell/fish-shell/issues/2502>)
- status -f will now behave the same when run as the main script or
using source (#2643
<https://github.com/fish-shell/fish-shell/issues/2643>)
- source no longer puts the file name in $argv if no arguments
are given (#139
<https://github.com/fish-shell/fish-shell/issues/139>)
- History files are stored under the XDG_DATA_HOME hierarchy (by
default, in ~/.local/share), and existing history will be moved on
first use (#744
<https://github.com/fish-shell/fish-shell/issues/744>)
Other notable fixes and improvements
- Fish no longer silences errors in config.fish (#2702
<https://github.com/fish-shell/fish-shell/issues/2702>)
- Directory autosuggestions will now descend as far as possible if there is
only one child directory (#2531
<https://github.com/fish-shell/fish-shell/issues/2531>)
- Add support for bright colors (#1464
<https://github.com/fish-shell/fish-shell/issues/1464>)
- Allow Ctrl-J (\cj) to be bound separately from Ctrl-M (\cm)
(#217
<https://github.com/fish-shell/fish-shell/issues/217>)
- psub now has a “-s”/“–suffix” option to
name the temporary file with that suffix
- Enable 24-bit colors on select terminals (#2495
<https://github.com/fish-shell/fish-shell/issues/2495>)
- Support for SVN status in the prompt (#2582
<https://github.com/fish-shell/fish-shell/issues/2582>)
- Mercurial and SVN support have been added to the Classic + Git (now
Classic + VCS) prompt (via the new __fish_vcs_prompt function)
(#2592
<https://github.com/fish-shell/fish-shell/issues/2592>)
- export now handles variables with a “=” in the value
(#2403
<https://github.com/fish-shell/fish-shell/issues/2403>)
- New completions for:
- alsactl
- Archlinux’s asp, makepkg
- Atom’s apm (#2390
<https://github.com/fish-shell/fish-shell/issues/2390>)
- entr - the “Event Notify Test Runner” (#2265
<https://github.com/fish-shell/fish-shell/issues/2265>)
- Fedora’s dnf (#2638
<https://github.com/fish-shell/fish-shell/issues/2638>)
- OSX diskutil (#2738
<https://github.com/fish-shell/fish-shell/issues/2738>)
- pkgng (#2395
<https://github.com/fish-shell/fish-shell/issues/2395>)
- pulseaudio’s pacmd and pactl
- rust’s rustc and cargo (#2409
<https://github.com/fish-shell/fish-shell/issues/2409>)
- sysctl (#2214
<https://github.com/fish-shell/fish-shell/issues/2214>)
- systemd’s machinectl (#2158
<https://github.com/fish-shell/fish-shell/issues/2158>),
busctl (#2144
<https://github.com/fish-shell/fish-shell/issues/2144>),
systemd-nspawn, systemd-analyze, localectl, timedatectl
- and more
- Fish no longer has a function called sgrep, freeing it for user
customization (#2245
<https://github.com/fish-shell/fish-shell/issues/2245>)
- A rewrite of the completions for cd, fixing a few bugs (#2299
<https://github.com/fish-shell/fish-shell/issues/2299>,
#2300
<https://github.com/fish-shell/fish-shell/issues/2300>,
#562
<https://github.com/fish-shell/fish-shell/issues/562>)
- Linux VTs now run in a simplified mode to avoid issues (#2311
<https://github.com/fish-shell/fish-shell/issues/2311>)
- The vi-bindings now inherit from the emacs bindings
- Fish will also execute fish_user_key_bindings when in vi-mode
- funced will now also check $VISUAL (#2268
<https://github.com/fish-shell/fish-shell/issues/2268>)
- A new suspend function (#2269
<https://github.com/fish-shell/fish-shell/issues/2269>)
- Subcommand completion now works better with split /usr (#2141
<https://github.com/fish-shell/fish-shell/issues/2141>)
- The command-not-found-handler can now be overridden by defining a function
called __fish_command_not_found_handler in config.fish
(#2332
<https://github.com/fish-shell/fish-shell/issues/2332>)
- A few fixes to the Sorin theme
- PWD shortening in the prompt can now be configured via the
fish_prompt_pwd_dir_length variable, set to the length per path
component (#2473
<https://github.com/fish-shell/fish-shell/issues/2473>)
- fish no longer requires /etc/fish/config.fish to correctly start,
and now ships a skeleton file that only contains some documentation
(#2799
<https://github.com/fish-shell/fish-shell/issues/2799>)
----
Significant changes
- Abbreviations: the new abbr command allows for
interactively-expanded abbreviations, allowing quick access to
frequently-used commands (#731
<https://github.com/fish-shell/fish-shell/issues/731>).
- Vi mode: run fish_vi_mode to switch fish into the key bindings and
prompt familiar to users of the Vi editor (#65
<https://github.com/fish-shell/fish-shell/issues/65>).
- New inline and interactive pager, which will be familiar to users of zsh
(#291
<https://github.com/fish-shell/fish-shell/issues/291>).
- Underlying architectural changes: the fishd universal variable
server has been removed as it was a source of many bugs and security
problems. Notably, old fish sessions will not be able to communicate
universal variable changes with new fish sessions. For best results,
restart all running instances of fish.
- The web-based configuration tool has been redesigned, featuring a prompt
theme chooser and other improvements.
- New German, Brazilian Portuguese, and Chinese translations.
Backward-incompatible changes
These are kept to a minimum, but either change undocumented
features or are too hard to use in their existing forms. These changes may
break existing scripts.
- commandline no longer interprets functions “in
reverse”, instead behaving as expected (#1567
<https://github.com/fish-shell/fish-shell/issues/1567>).
- The previously-undocumented CMD_DURATION variable is now set for
all commands and contains the execution time of the last command in
milliseconds (#1585
<https://github.com/fish-shell/fish-shell/issues/1585>). It
is no longer exported to other commands (#1896
<https://github.com/fish-shell/fish-shell/issues/1896>).
- if / else conditional statements now return values
consistent with the Single Unix Specification, like other shells
(#1443
<https://github.com/fish-shell/fish-shell/issues/1443>).
- A new “top-level” local scope has been added, allowing local
variables declared on the commandline to be visible to subsequent
commands. (#1908
<https://github.com/fish-shell/fish-shell/issues/1908>)
Other notable fixes and improvements
- New documentation design (#1662
<https://github.com/fish-shell/fish-shell/issues/1662>),
which requires a Doxygen version 1.8.7 or newer to build.
- Fish now defines a default directory for other packages to provide
completions. By default this is
/usr/share/fish/vendor-completions.d; on systems with
pkgconfig installed this path is discoverable with pkg-config
--variable completionsdir fish.
- A new parser removes many bugs; all existing syntax should keep
working.
- New fish_preexec and fish_postexec events are fired before
and after job execution respectively (#1549
<https://github.com/fish-shell/fish-shell/issues/1549>).
- Unmatched wildcards no longer prevent a job from running. Wildcards used
interactively will still print an error, but the job will proceed and the
wildcard will expand to zero arguments (#1482
<https://github.com/fish-shell/fish-shell/issues/1482>).
- The . command is deprecated and the source command is
preferred (#310
<https://github.com/fish-shell/fish-shell/issues/310>).
- bind supports “bind modes”, which allows bindings to
be set for a particular named mode, to support the implementation of Vi
mode.
- A new export alias, which behaves like other shells (#1833
<https://github.com/fish-shell/fish-shell/issues/1833>).
- command has a new --search option to print the name of the
disk file that would be executed, like other shells’ command
-v (#1540
<https://github.com/fish-shell/fish-shell/issues/1540>).
- commandline has a new --paging-mode option to support the
new pager.
- complete has a new --wraps option, which allows a command to
(recursively) inherit the completions of a wrapped command (#393
<https://github.com/fish-shell/fish-shell/issues/393>), and
complete -e now correctly erases completions (#380
<https://github.com/fish-shell/fish-shell/issues/380>).
- Completions are now generated from manual pages by default on the first
run of fish (#997
<https://github.com/fish-shell/fish-shell/issues/997>).
- fish_indent can now produce colorized (--ansi) and HTML
(--html) output (#1827
<https://github.com/fish-shell/fish-shell/issues/1827>).
- functions --erase now prevents autoloaded functions from being
reloaded in the current session.
- history has a new --merge option, to incorporate history
from other sessions into the current session (#825
<https://github.com/fish-shell/fish-shell/issues/825>).
- jobs returns 1 if there are no active jobs (#1484
<https://github.com/fish-shell/fish-shell/issues/1484>).
- read has several new options:
- --array to break input into an array (#1540
<https://github.com/fish-shell/fish-shell/issues/1540>)
- --null to break lines on NUL characters rather than newlines
(#1694
<https://github.com/fish-shell/fish-shell/issues/1694>)
- --nchars to read a specific number of characters (#1616
<https://github.com/fish-shell/fish-shell/issues/1616>)
- --right-prompt to display a right-hand-side prompt during
interactive read (#1698
<https://github.com/fish-shell/fish-shell/issues/1698>).
- type has a new -q option to suppress output (#1540
<https://github.com/fish-shell/fish-shell/issues/1540> and,
like other shells, type -a now prints all matches for a command
(#261
<https://github.com/fish-shell/fish-shell/issues/261>).
- Pressing f1 now shows the manual page for the current command
(#1063
<https://github.com/fish-shell/fish-shell/issues/1063>).
- fish_title functions have access to the arguments of the currently
running argument as $argv[1] (#1542
<https://github.com/fish-shell/fish-shell/issues/1542>).
- The OS command-not-found handler is used on Arch Linux (#1925
<https://github.com/fish-shell/fish-shell/issues/1925>),
nixOS (#1852
<https://github.com/fish-shell/fish-shell/issues/1852>),
openSUSE and Fedora (#1280
<https://github.com/fish-shell/fish-shell/issues/1280>).
- Alt+. searches backwards in the token history, mapping to
the same behavior as inserting the last argument of the previous command,
like other shells (#89
<https://github.com/fish-shell/fish-shell/issues/89>).
- The SHLVL environment variable is incremented correctly
(#1634
<https://github.com/fish-shell/fish-shell/issues/1634> &
#1693
<https://github.com/fish-shell/fish-shell/issues/1693>).
- Added completions for adb (#1165
<https://github.com/fish-shell/fish-shell/issues/1165> &
#1211
<https://github.com/fish-shell/fish-shell/issues/1211>),
apt (#2018
<https://github.com/fish-shell/fish-shell/issues/2018>),
aura (#1292
<https://github.com/fish-shell/fish-shell/issues/1292>),
composer (#1607
<https://github.com/fish-shell/fish-shell/issues/1607>),
cygport (#1841
<https://github.com/fish-shell/fish-shell/issues/1841>),
dropbox (#1533
<https://github.com/fish-shell/fish-shell/issues/1533>),
elixir (#1167
<https://github.com/fish-shell/fish-shell/issues/1167>),
fossil, heroku (#1790
<https://github.com/fish-shell/fish-shell/issues/1790>),
iex (#1167
<https://github.com/fish-shell/fish-shell/issues/1167>),
kitchen (#2000
<https://github.com/fish-shell/fish-shell/issues/2000>),
nix (#1167
<https://github.com/fish-shell/fish-shell/issues/1167>),
node/npm (#1566
<https://github.com/fish-shell/fish-shell/issues/1566>),
opam (#1615
<https://github.com/fish-shell/fish-shell/issues/1615>),
setfacl (#1752
<https://github.com/fish-shell/fish-shell/issues/1752>),
tmuxinator (#1863
<https://github.com/fish-shell/fish-shell/issues/1863>), and
yast2 (#1739
<https://github.com/fish-shell/fish-shell/issues/1739>).
- Improved completions for brew (#1090
<https://github.com/fish-shell/fish-shell/issues/1090> &
#1810
<https://github.com/fish-shell/fish-shell/issues/1810>),
bundler (#1779
<https://github.com/fish-shell/fish-shell/issues/1779>),
cd (#1135
<https://github.com/fish-shell/fish-shell/issues/1135>),
emerge (#1840
<https://github.com/fish-shell/fish-shell/issues/1840>),git
(#1680
<https://github.com/fish-shell/fish-shell/issues/1680>,
#1834
<https://github.com/fish-shell/fish-shell/issues/1834> &
#1951
<https://github.com/fish-shell/fish-shell/issues/1951>),
man (#960
<https://github.com/fish-shell/fish-shell/issues/960>),
modprobe (#1124
<https://github.com/fish-shell/fish-shell/issues/1124>),
pacman (#1292
<https://github.com/fish-shell/fish-shell/issues/1292>),
rpm (#1236
<https://github.com/fish-shell/fish-shell/issues/1236>),
rsync (#1872
<https://github.com/fish-shell/fish-shell/issues/1872>),
scp (#1145
<https://github.com/fish-shell/fish-shell/issues/1145>),
ssh (#1234
<https://github.com/fish-shell/fish-shell/issues/1234>),
sshfs (#1268
<https://github.com/fish-shell/fish-shell/issues/1268>),
systemctl (#1462
<https://github.com/fish-shell/fish-shell/issues/1462>,
#1950
<https://github.com/fish-shell/fish-shell/issues/1950> &
#1972
<https://github.com/fish-shell/fish-shell/issues/1972>),
tmux (#1853
<https://github.com/fish-shell/fish-shell/issues/1853>),
vagrant (#1748
<https://github.com/fish-shell/fish-shell/issues/1748>),
yum (#1269
<https://github.com/fish-shell/fish-shell/issues/1269>), and
zypper (#1787
<https://github.com/fish-shell/fish-shell/issues/1787>).
----
fish 2.1.2 contains a workaround for a filesystem bug in Mac OS X
Yosemite. #1859
<https://github.com/fish-shell/fish-shell/issues/1859>
Specifically, after installing fish 2.1.1 and then rebooting,
“Verify Disk” in Disk Utility will report “Invalid
number of hard links.” We don’t have any reports of data loss
or other adverse consequences. fish 2.1.2 avoids triggering the bug, but
does not repair an already affected filesystem. To repair the filesystem,
you can boot into Recovery Mode and use Repair Disk from Disk Utility. Linux
and versions of OS X prior to Yosemite are believed to be unaffected.
There are no other changes in this release.
----
Important: if you are upgrading, stop all running instances
of fishd as soon as possible after installing this release; it will
be restarted automatically. On most systems, there will be no further action
required. Note that some environments (where XDG_RUNTIME_DIR is set),
such as Fedora 20, will require a restart of all running fish processes
before universal variables work as intended.
Distributors are highly encouraged to call killall fishd,
pkill fishd or similar in installation scripts, or to warn their
users to do so.
- The fish_config web interface now uses an authentication token to protect
requests and only responds to requests from the local machine with this
token, preventing a remote code execution attack. (closing CVE-2014-2914).
#1438
<https://github.com/fish-shell/fish-shell/issues/1438>
- psub and funced are no longer vulnerable to attacks which
allow local privilege escalation and data tampering (closing CVE-2014-2906
and CVE-2014-3856). #1437
<https://github.com/fish-shell/fish-shell/issues/1437>
- fishd uses a secure path for its socket, preventing a local
privilege escalation attack (closing CVE-2014-2905). #1436
<https://github.com/fish-shell/fish-shell/issues/1436>
- __fish_print_packages is no longer vulnerable to attacks which
would allow local privilege escalation and data tampering (closing
CVE-2014-3219). #1440
<https://github.com/fish-shell/fish-shell/issues/1440>
- •
- fishd now ignores SIGPIPE, fixing crashes using tools like GNU
Parallel and which occurred more often as a result of the other
fishd changes. #1084
<https://github.com/fish-shell/fish-shell/issues/1084> &
#1690
<https://github.com/fish-shell/fish-shell/issues/1690>
----
Significant Changes
- Tab completions will fuzzy-match files. #568
<https://github.com/fish-shell/fish-shell/issues/568>
When tab-completing a file, fish will first attempt prefix
matches (foo matches foobar), then substring matches
(ooba matches foobar), and lastly subsequence matches
(fbr matches foobar). For example, in a directory with
files foo1.txt, foo2.txt, foo3.txt…, you can type only the
numeric part and hit tab to fill in the rest.
This feature is implemented for files and executables. It is
not yet implemented for options (like --foobar), and not yet
implemented across path components (like /u/l/b to match
/usr/local/bin).
- Redirections now work better across pipelines. #110
<https://github.com/fish-shell/fish-shell/issues/110>,
#877
<https://github.com/fish-shell/fish-shell/issues/877>
In particular, you can pipe stderr and stdout together, for
example, with cmd ^&1 | tee log.txt, or the more familiar
cmd 2>&1 | tee log.txt.
- A single ``%`` now expands to the last job backgrounded.
#1008
<https://github.com/fish-shell/fish-shell/issues/1008>
Previously, a single % would pid-expand to either all
backgrounded jobs, or all jobs owned by your user. Now it expands to the
last job backgrounded. If no job is in the background, it will fail to
expand. In particular, fg % can be used to put the most recent
background job in the foreground.
Other Notable Fixes
- alt-U and alt+C now uppercase and capitalize words, respectively.
#995
<https://github.com/fish-shell/fish-shell/issues/995>
- VTE based terminals should now know the working directory. #906
<https://github.com/fish-shell/fish-shell/issues/906>
- The autotools build now works on Mavericks. #968
<https://github.com/fish-shell/fish-shell/issues/968>
- The end-of-line binding (ctrl+E) now accepts autosuggestions. #932
<https://github.com/fish-shell/fish-shell/issues/932>
- Directories in /etc/paths (used on OS X) are now prepended instead
of appended, similar to other shells. #927
<https://github.com/fish-shell/fish-shell/issues/927>
- Option-right-arrow (used for partial autosuggestion completion) now works
on iTerm2. #920
<https://github.com/fish-shell/fish-shell/issues/920>
- Tab completions now work properly within nested subcommands. #913
<https://github.com/fish-shell/fish-shell/issues/913>
- printf supports \e, the escape character. #910
<https://github.com/fish-shell/fish-shell/issues/910>
- fish_config history no longer shows duplicate items. #900
<https://github.com/fish-shell/fish-shell/issues/900>
- $fish_user_paths is now prepended to $PATH instead of appended.
#888
<https://github.com/fish-shell/fish-shell/issues/888>
- Jobs complete when all processes complete. #876
<https://github.com/fish-shell/fish-shell/issues/876>
For example, in previous versions of fish, sleep 10 | echo
Done returns control immediately, because echo does not read from
stdin. Now it does not complete until sleep exits (presumably after 10
seconds).
- Better error reporting for square brackets. #875
<https://github.com/fish-shell/fish-shell/issues/875>
- fish no longer tries to add /bin to $PATH unless PATH is
totally empty. #852
<https://github.com/fish-shell/fish-shell/issues/852>
- History token substitution (alt-up) now works correctly inside subshells.
#833
<https://github.com/fish-shell/fish-shell/issues/833>
- Flow control is now disabled, freeing up ctrl-S and ctrl-Q for other uses.
#814
<https://github.com/fish-shell/fish-shell/issues/814>
- sh-style variable setting like foo=bar now produces better error
messages. #809
<https://github.com/fish-shell/fish-shell/issues/809>
- Commands with wildcards no longer produce autosuggestions. #785
<https://github.com/fish-shell/fish-shell/issues/785>
- funced no longer freaks out when supplied with no arguments. #780
<https://github.com/fish-shell/fish-shell/issues/780>
- fish.app now works correctly in a directory containing spaces. #774
<https://github.com/fish-shell/fish-shell/issues/774>
- Tab completion cycling no longer occasionally fails to repaint.
#765
<https://github.com/fish-shell/fish-shell/issues/765>
- Comments now work in eval’d strings. #684
<https://github.com/fish-shell/fish-shell/issues/684>
- History search (up-arrow) now shows the item matching the autosuggestion,
if that autosuggestion was truncated. #650
<https://github.com/fish-shell/fish-shell/issues/650>
- Ctrl-T now transposes characters, as in other shells. #128
<https://github.com/fish-shell/fish-shell/issues/128>
----
Significant Changes
- •
- Command substitutions now modify ``$status`` :issue:`547`.
Previously the exit status of command substitutions (like (pwd))
was ignored; however now it modifies $status. Furthermore, the set
command now only sets $status on failure; it is untouched on success. This
allows for the following pattern:
if set python_path (which python)
...
end
Because set does not modify $status on success, the if branch
effectively tests whether which succeeded, and if so, whether the
set also succeeded.
- •
- Improvements to PATH handling. There is a new variable, fish_user_paths,
which can be set universally, and whose contents are appended to $PATH
#527
<https://github.com/fish-shell/fish-shell/issues/527>
- /etc/paths and /etc/paths.d are now respected on OS X
- fish no longer modifies $PATH to find its own binaries
- Long lines no longer use ellipsis for line breaks, and copy and
paste should no longer include a newline even if the line was broken
#300
<https://github.com/fish-shell/fish-shell/issues/300>
- New syntax for index ranges (sometimes known as
“slices”) #212
<https://github.com/fish-shell/fish-shell/issues/212>
- fish now supports an ``else if`` statement #134
<https://github.com/fish-shell/fish-shell/issues/134>
- Process and pid completion now works on OS X #129
<https://github.com/fish-shell/fish-shell/issues/129>
- fish is now relocatable, and no longer depends on compiled-in paths
#125
<https://github.com/fish-shell/fish-shell/issues/125>
- fish now supports a right prompt (RPROMPT) through the
fish_right_prompt function #80
<https://github.com/fish-shell/fish-shell/issues/80>
- fish now uses posix_spawn instead of fork when possible, which is
much faster on BSD and OS X #11
<https://github.com/fish-shell/fish-shell/issues/11>
Other Notable Fixes
- Updated VCS completions (darcs, cvs, svn, etc.)
- Avoid calling getcwd on the main thread, as it can hang #696
<https://github.com/fish-shell/fish-shell/issues/696>
- Control-D (forward delete) no longer stops at a period #667
<https://github.com/fish-shell/fish-shell/issues/667>
- Completions for many new commands
- fish now respects rxvt’s unique keybindings #657
<https://github.com/fish-shell/fish-shell/issues/657>
- xsel is no longer built as part of fish. It will still be invoked if
installed separately #633
<https://github.com/fish-shell/fish-shell/issues/633>
- __fish_filter_mime no longer spews #628
<https://github.com/fish-shell/fish-shell/issues/628>
- The –no-execute option to fish no longer falls over when reaching
the end of a block #624
<https://github.com/fish-shell/fish-shell/issues/624>
- fish_config knows how to find fish even if it’s not in the $PATH
#621
<https://github.com/fish-shell/fish-shell/issues/621>
- A leading space now prevents writing to history, as is done in bash and
zsh #615
<https://github.com/fish-shell/fish-shell/issues/615>
- Hitting enter after a backslash only goes to a new line if it is followed
by whitespace or the end of the line #613
<https://github.com/fish-shell/fish-shell/issues/613>
- printf is now a builtin #611
<https://github.com/fish-shell/fish-shell/issues/611>
- Event handlers should no longer fire if signals are blocked #608
<https://github.com/fish-shell/fish-shell/issues/608>
- set_color is now a builtin #578
<https://github.com/fish-shell/fish-shell/issues/578>
- man page completions are now located in a new generated_completions
directory, instead of your completions directory #576
<https://github.com/fish-shell/fish-shell/issues/576>
- tab now clears autosuggestions #561
<https://github.com/fish-shell/fish-shell/issues/561>
- tab completion from within a pair of quotes now attempts to
“appropriate” the closing quote #552
<https://github.com/fish-shell/fish-shell/issues/552>
- $EDITOR can now be a list: for example, set EDITOR gvim -f)
#541
<https://github.com/fish-shell/fish-shell/issues/541>
- case bodies are now indented #530
<https://github.com/fish-shell/fish-shell/issues/530>
- The profile switch -p no longer crashes #517
<https://github.com/fish-shell/fish-shell/issues/517>
- You can now control-C out of read #516
<https://github.com/fish-shell/fish-shell/issues/516>
- umask is now functional on OS X #515
<https://github.com/fish-shell/fish-shell/issues/515>
- Avoid calling getpwnam on the main thread, as it can hang #512
<https://github.com/fish-shell/fish-shell/issues/512>
- Alt-F or Alt-right-arrow (Option-F or option-right-arrow) now accepts one
word of an autosuggestion #435
<https://github.com/fish-shell/fish-shell/issues/435>
- Setting fish as your login shell no longer kills OpenSUSE #367
<https://github.com/fish-shell/fish-shell/issues/367>
- Backslashes now join lines, instead of creating multiple commands
#347
<https://github.com/fish-shell/fish-shell/issues/347>
- echo now implements the -e flag to interpret escapes #337
<https://github.com/fish-shell/fish-shell/issues/337>
- When the last token in the user’s input contains capital letters,
use its case in preference to that of the autosuggestion #335
<https://github.com/fish-shell/fish-shell/issues/335>
- Descriptions now have their own muted color #279
<https://github.com/fish-shell/fish-shell/issues/279>
- Wildcards beginning with a . (for example, ls .*) no longer match .
and .. #270
<https://github.com/fish-shell/fish-shell/issues/270>
- Recursive wildcards now handle symlink loops #268
<https://github.com/fish-shell/fish-shell/issues/268>
- You can now delete history items from the fish_config web interface
#250
<https://github.com/fish-shell/fish-shell/issues/250>
- The OS X build now weak links wcsdup and wcscasecmp
#240
<https://github.com/fish-shell/fish-shell/issues/240>
- fish now saves and restores the process group, which prevents certain
processes from being erroneously reported as stopped #197
<https://github.com/fish-shell/fish-shell/issues/197>
- funced now takes an editor option #187
<https://github.com/fish-shell/fish-shell/issues/187>
- Alternating row colors are available in fish pager through
fish_pager_color_secondary #186
<https://github.com/fish-shell/fish-shell/issues/186>
- Universal variable values are now stored based on your MAC address, not
your hostname #183
<https://github.com/fish-shell/fish-shell/issues/183>
- The caret ^ now only does a stderr redirection if it is the first
character of a token, making git users happy #168
<https://github.com/fish-shell/fish-shell/issues/168>
- Autosuggestions will no longer cause line wrapping #167
<https://github.com/fish-shell/fish-shell/issues/167>
- Better handling of Unicode combining characters #155
<https://github.com/fish-shell/fish-shell/issues/155>
- fish SIGHUPs processes more often #138
<https://github.com/fish-shell/fish-shell/issues/138>
- fish no longer causes sudo to ask for a password every time
- fish behaves better under Midnight Commander #121
<https://github.com/fish-shell/fish-shell/issues/121>
- set -e no longer crashes #100
<https://github.com/fish-shell/fish-shell/issues/100>
- fish now will automatically import history from bash, if there is no fish
history #66
<https://github.com/fish-shell/fish-shell/issues/66>
- Backslashed-newlines inside quoted strings now behave more intuitively
#52
<https://github.com/fish-shell/fish-shell/issues/52>
- Tab titles should be shown correctly in iTerm2 #47
<https://github.com/fish-shell/fish-shell/issues/47>
- scp remote path completion now sometimes works #42
<https://github.com/fish-shell/fish-shell/issues/42>
- The read builtin no longer shows autosuggestions #29
<https://github.com/fish-shell/fish-shell/issues/29>
- Custom key bindings can now be set via the fish_user_key_bindings
function #21
<https://github.com/fish-shell/fish-shell/issues/21>
- All Python scripts now run correctly under both Python 2 and Python 3
#14
<https://github.com/fish-shell/fish-shell/issues/14>
- The “accept autosuggestion” key can now be configured
#19
<https://github.com/fish-shell/fish-shell/issues/19>
- Autosuggestions will no longer suggest invalid commands #6
<https://github.com/fish-shell/fish-shell/issues/6>
----
- Implicit cd is back, for paths that start with one or two dots, a
slash, or a tilde.
- Overrides of default functions should be fixed. The
“internalized scripts” feature is disabled for now.
- Disabled delayed suspend. This is a strange job-control feature of
BSD systems, including OS X. Disabling it frees up Control Y for other
purposes; in particular, for yank, which now works on OS X.
- fish_indent is fixed. In particular, the funced and
funcsave functions work again.
- A SIGTERM now ends the whole execution stack again (resolving #13
<https://github.com/fish-shell/fish-shell/issues/13>).
- Bumped the __fish_config_interactive version number so the default
fish_color_autosuggestion kicks in.
- fish_config better handles combined term256 and classic colors like
“555 yellow”.
New Features
- •
- A history builtin, and associated interactive function that enables
deleting history items. Example usage: * Print all history items beginning
with echo: history --prefix echo * Print all history items
containing foo: history --contains foo * Interactively delete some
items containing foo: history --delete --contains foo
Credit to @siteshwar for implementation. Thanks @siteshwar!
----
- •
- No changes! All existing fish scripts, config files, completions, etc.
from trunk should continue to work.
New Features
- Autosuggestions. Think URL fields in browsers. When you type a
command, fish will suggest the rest of the command after the cursor, in a
muted gray when possible. You can accept the suggestion with the right
arrow key or Ctrl-F. Suggestions come from command history, completions,
and some custom code for cd; there’s a lot of potential for
improvement here. The suggestions are computed on a background pthread, so
they never slow down your typing. The autosuggestion feature is
incredible. I miss it dearly every time I use anything else.
- term256 support where available, specifically modern xterms and OS
X Lion. You can specify colors the old way (‘set_color
cyan’) or by specifying RGB hex values (‘set_color
FF3333’); fish will pick the closest supported color. Some xterms
do not advertise term256 support either in the $TERM or terminfo
max_colors field, but nevertheless support it. For that reason, fish will
default into using it on any xterm (but it can be disabled with an
environment variable).
- Web-based configuration page. There is a new function
‘fish_config’. This spins up a simple Python web server and
opens a browser window to it. From this web page, you can set your shell
colors and view your functions, variables, and history; all changes apply
immediately to all running shells. Eventually all configuration ought to
be supported via this mechanism (but in addition to, not instead of,
command line mechanisms).
- Man page completions. There is a new function
‘fish_update_completions’. This function reads all the man1
files from your manpath, removes the roff formatting, parses them to find
the commands and options, and outputs fish completions into
~/.config/fish/completions. It won’t overwrite existing completion
files (except ones that it generated itself).
- fish is now entirely in C++. I have no particular love for C++, but it
provides a ready memory-model to replace halloc. We’ve made an
effort to keep it to a sane and portable subset (no C++11, no boost, no
going crazy with templates or smart pointers), but we do use the STL and a
little tr1.
- halloc is entirely gone, replaced by normal C++ ownership semantics. If
you don’t know what halloc is, well, now you have two reasons to be
happy.
- All the crufty C data structures are entirely gone. array_list_t,
priority_queue_t, hash_table_t, string_buffer_t have been removed and
replaced by STL equivalents like std::vector, std::map, and std::wstring.
A lot of the string handling now uses std::wstring instead of wchar_t
*
- fish now spawns pthreads for tasks like syntax highlighting that require
blocking I/O.
- History has been completely rewritten. History files now use an extensible
YAML-style syntax. History “merging” (multiple shells
writing to the same history file) now works better. There is now a maximum
history length of about 250k items (256 * 1024).
- The parser has been “instanced,” so you can now create more
than one.
- Total #LoC has shrunk slightly even with the new features.
- fish now runs syntax highlighting in a background thread, so typing
commands is always responsive even on slow filesystems.
- echo, test, and pwd are now builtins, which eliminates many forks.
- The files in share/functions and share/completions now get
‘internalized’ into C strings that get compiled in with
fish. This substantially reduces the number of files touched at startup. A
consequence is that you cannot change these functions without recompiling,
but often other functions depend on these “standard”
functions, so changing them is perhaps not a good idea anyways.
Here are some system call counts for launching and then exiting
fish with the default configuration, on OS X. The first column is fish
trunk, the next column is with our changes, and the last column is bash for
comparison. This data was collected via dtrace.
before
after
bash
open
9
4
5
fork
28
14
0
stat
131
85
11
lstat
670
0
0
read
332
80
4
write
172
149
0
The large number of forks relative to bash are due to
fish’s insanely expensive default prompt, which is unchanged in my
version. If we switch to a prompt comparable to bash’s (lame)
default, the forks drop to 16 with trunk, 4 after our changes.
The large reduction in lstat() numbers is due to fish no longer
needing to call ttyname() on OS X.
We’ve got some work to do to be as lean as bash, but
we’re on the right track.
2024, fish-shell developers
Visit the GSP FreeBSD Man Page Interface. Output converted with ManDoc.
|