mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
Migrate abbrs from =-separated to space-separated
We silently upgrade existing abbreviations and change the separator when saving. This does not yet warn when the user is using the old syntax. Resolves #2051
This commit is contained in:
parent
fbd53f2da1
commit
0e8a8a7c80
3 changed files with 23 additions and 15 deletions
|
@ -2,7 +2,7 @@
|
||||||
|
|
||||||
\subsection abbr-synopsis Synopsis
|
\subsection abbr-synopsis Synopsis
|
||||||
\fish{synopsis}
|
\fish{synopsis}
|
||||||
abbr -a word="phrase"
|
abbr -a word phrase...
|
||||||
abbr -s
|
abbr -s
|
||||||
abbr -l
|
abbr -l
|
||||||
abbr -e word
|
abbr -e word
|
||||||
|
@ -26,6 +26,8 @@ The following parameters are available:
|
||||||
|
|
||||||
- `-e WORD` or `--erase WORD` Erase the abbreviation WORD.
|
- `-e WORD` or `--erase WORD` Erase the abbreviation WORD.
|
||||||
|
|
||||||
|
Note: fish version 2.1 supported `-a WORD=PHRASE`. This syntax is now deprecated but will still be converted.
|
||||||
|
|
||||||
\subsection abbr-example Examples
|
\subsection abbr-example Examples
|
||||||
|
|
||||||
\fish
|
\fish
|
||||||
|
|
|
@ -165,3 +165,14 @@ for file in $configdir/fish/conf.d/* $__fish_sysconfdir/conf.d/* $__fish_datadir
|
||||||
# This allows one to use e.g. symlinks to /dev/null to "mask" something (like in systemd)
|
# This allows one to use e.g. symlinks to /dev/null to "mask" something (like in systemd)
|
||||||
[ -f $file -a -r $file ]; and source $file
|
[ -f $file -a -r $file ]; and source $file
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# Upgrade pre-existing abbreviations from the old "key=value" to the new "key value" syntax
|
||||||
|
# This needs to be in share/config.fish because __fish_config_interactive is called after sourcing config.fish, which might contain abbr calls
|
||||||
|
if not set -q __fish_init_2_3_0
|
||||||
|
set -l fab
|
||||||
|
for abb in $fish_user_abbreviations
|
||||||
|
set fab $fab (string replace -r '^([^ =]+)=(.*)$' '$1 $2' -- $abb)
|
||||||
|
end
|
||||||
|
set fish_user_abbreviations $fab
|
||||||
|
set -U __fish_init_2_3_0
|
||||||
|
end
|
||||||
|
|
|
@ -72,8 +72,12 @@ function abbr --description "Manage abbreviations"
|
||||||
|
|
||||||
switch $mode
|
switch $mode
|
||||||
case 'add'
|
case 'add'
|
||||||
|
# Convert from old "key=value" to new "key value" syntax
|
||||||
|
if string match -qr '^[^ ]+=' -- $mode_arg
|
||||||
|
set mode_arg (string replace "=" " " -- $mode_arg)
|
||||||
|
end
|
||||||
|
|
||||||
# Bail out early if the exact abbr is already in
|
# Bail out early if the exact abbr is already in
|
||||||
# This depends on the separator staying the same, but that's the common case (config.fish)
|
|
||||||
contains -- $mode_arg $fish_user_abbreviations; and return 0
|
contains -- $mode_arg $fish_user_abbreviations; and return 0
|
||||||
set -l key
|
set -l key
|
||||||
set -l value
|
set -l value
|
||||||
|
@ -141,13 +145,9 @@ function __fish_abbr_get_by_key
|
||||||
# Going through all entries is still quicker than calling `seq`
|
# Going through all entries is still quicker than calling `seq`
|
||||||
set -l keys
|
set -l keys
|
||||||
for kv in $fish_user_abbreviations
|
for kv in $fish_user_abbreviations
|
||||||
if string match -qr '^[^ ]+=' -- $kv
|
# If this does not match, we have screwed up before and the error should be reported
|
||||||
# No need for bounds-checking because we already matched before
|
|
||||||
set keys $keys (string split "=" -m 1 -- $kv)[1]
|
|
||||||
else if string match -qr '^[^ ]+ .*' -- $kv
|
|
||||||
set keys $keys (string split " " -m 1 -- $kv)[1]
|
set keys $keys (string split " " -m 1 -- $kv)[1]
|
||||||
end
|
end
|
||||||
end
|
|
||||||
if set -l idx (contains -i -- $argv[1] $keys)
|
if set -l idx (contains -i -- $argv[1] $keys)
|
||||||
echo $idx
|
echo $idx
|
||||||
return 0
|
return 0
|
||||||
|
@ -156,11 +156,6 @@ function __fish_abbr_get_by_key
|
||||||
end
|
end
|
||||||
|
|
||||||
function __fish_abbr_split -a input
|
function __fish_abbr_split -a input
|
||||||
if string match -qr '^[^ ]+=' -- $input
|
# Because we always save space-separated, we can be certain that this will match
|
||||||
string split "=" -m 1 -- $input
|
|
||||||
else if string match -qr '^[^ ]+ .*' -- $input
|
|
||||||
string split " " -m 1 -- $input
|
string split " " -m 1 -- $input
|
||||||
else
|
|
||||||
echo $input
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue