mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-13 21:44:16 +00:00
reformat all fish scripts
I hate doing this but I am tired of touching a fish script as part of some change and having `make style` radically change it. Which makes editing fish scripts more painful than it needs to be. It is time to do a wholesale reformatting of these scripts to conform to the documented style as implemented by the `fish_indent` program.
This commit is contained in:
parent
54a76bb9e5
commit
11a60c8374
161 changed files with 2638 additions and 2587 deletions
|
@ -8,7 +8,8 @@ function __fish_complete_ant_targets -d "Print list of targets from build.xml an
|
||||||
set files (sed -n "s/^.*<import[^>]* file=[\"']\([^\"']*\)[\"'].*\$/\1/p" < $buildfile)
|
set files (sed -n "s/^.*<import[^>]* file=[\"']\([^\"']*\)[\"'].*\$/\1/p" < $buildfile)
|
||||||
|
|
||||||
# iterate through files and display their targets
|
# iterate through files and display their targets
|
||||||
for file in $files;
|
for file in $files
|
||||||
|
|
||||||
__fish_filter_ant_targets $file
|
__fish_filter_ant_targets $file
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -4,11 +4,13 @@ function __fish_complete_cd -d "Completions for the cd command"
|
||||||
if string match -qr '^\.?\.?/.*' -- $token
|
if string match -qr '^\.?\.?/.*' -- $token
|
||||||
for d in $token*/
|
for d in $token*/
|
||||||
# Check if it's accessible - the glob only matches directories
|
# Check if it's accessible - the glob only matches directories
|
||||||
[ -x $d ]; and printf "%s\n" $d
|
[ -x $d ]
|
||||||
|
and printf "%s\n" $d
|
||||||
end
|
end
|
||||||
else # Relative path - check $CDPATH and use that as description
|
else # Relative path - check $CDPATH and use that as description
|
||||||
set -l cdpath $CDPATH
|
set -l cdpath $CDPATH
|
||||||
[ -z "$cdpath" ]; and set cdpath "."
|
[ -z "$cdpath" ]
|
||||||
|
and set cdpath "."
|
||||||
# Remove the real path to "." (i.e. $PWD) from cdpath if we're in it
|
# Remove the real path to "." (i.e. $PWD) from cdpath if we're in it
|
||||||
# so it doesn't get printed in the descriptions
|
# so it doesn't get printed in the descriptions
|
||||||
if set -l ind (contains -i -- $PWD $cdpath)
|
if set -l ind (contains -i -- $PWD $cdpath)
|
||||||
|
@ -21,11 +23,13 @@ function __fish_complete_cd -d "Completions for the cd command"
|
||||||
set -l desc
|
set -l desc
|
||||||
# Don't show description for current directory
|
# Don't show description for current directory
|
||||||
# and replace $HOME with "~"
|
# and replace $HOME with "~"
|
||||||
[ $i = "." ]; or set -l desc (string replace -r -- "^$HOME" "~" "$i")
|
[ $i = "." ]
|
||||||
|
or set -l desc (string replace -r -- "^$HOME" "~" "$i")
|
||||||
# This assumes the CDPATH component itself is cd-able
|
# This assumes the CDPATH component itself is cd-able
|
||||||
for d in $i/$token*/
|
for d in $i/$token*/
|
||||||
# Remove the cdpath component again
|
# Remove the cdpath component again
|
||||||
[ -x $d ]; and printf "%s\t%s\n" (string replace -r "^$i/" "" -- $d) $desc
|
[ -x $d ]
|
||||||
|
and printf "%s\t%s\n" (string replace -r "^$i/" "" -- $d) $desc
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -234,7 +234,8 @@ function __fish_config_interactive -d "Initializations that should be performed
|
||||||
# Suppress duplicative title display on Terminal.app
|
# Suppress duplicative title display on Terminal.app
|
||||||
if not functions -q fish_title
|
if not functions -q fish_title
|
||||||
echo -n \e\]0\;\a # clear existing title
|
echo -n \e\]0\;\a # clear existing title
|
||||||
function fish_title -d 'no-op terminal title'; end
|
function fish_title -d 'no-op terminal title'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
__update_cwd_osc # Run once because we might have already inherited a PWD from an old tab
|
__update_cwd_osc # Run once because we might have already inherited a PWD from an old tab
|
||||||
|
|
|
@ -484,7 +484,8 @@ function __fish_git_prompt_informative_status
|
||||||
|
|
||||||
# If `math` fails for some reason, assume the state is clean - it's the simpler path
|
# If `math` fails for some reason, assume the state is clean - it's the simpler path
|
||||||
set -l state (math $dirtystate + $invalidstate + $stagedstate + $untrackedfiles ^/dev/null)
|
set -l state (math $dirtystate + $invalidstate + $stagedstate + $untrackedfiles ^/dev/null)
|
||||||
if test -z "$state"; or test "$state" = 0
|
if test -z "$state"
|
||||||
|
or test "$state" = 0
|
||||||
set info $___fish_git_prompt_color_cleanstate$___fish_git_prompt_char_cleanstate$___fish_git_prompt_color_cleanstate_done
|
set info $___fish_git_prompt_color_cleanstate$___fish_git_prompt_char_cleanstate$___fish_git_prompt_color_cleanstate_done
|
||||||
else
|
else
|
||||||
for i in $___fish_git_prompt_status_order
|
for i in $___fish_git_prompt_status_order
|
||||||
|
|
|
@ -69,12 +69,18 @@ function __fish_hg_prompt --description 'Write out the hg prompt'
|
||||||
|
|
||||||
# Add a character for each file status if we have one
|
# Add a character for each file status if we have one
|
||||||
switch $line
|
switch $line
|
||||||
case 'A ' ; set hg_statuses $hg_statuses added
|
case 'A '
|
||||||
case 'M ' ' M' ; set hg_statuses $hg_statuses modified
|
set hg_statuses $hg_statuses added
|
||||||
case 'C ' ; set hg_statuses $hg_statuses copied
|
case 'M ' ' M'
|
||||||
case 'D ' ' D' ; set hg_statuses $hg_statuses deleted
|
set hg_statuses $hg_statuses modified
|
||||||
case '\? ' ; set hg_statuses $hg_statuses untracked
|
case 'C '
|
||||||
case 'U*' '*U' 'DD' 'AA'; set hg_statuses $hg_statuses unmerged
|
set hg_statuses $hg_statuses copied
|
||||||
|
case 'D ' ' D'
|
||||||
|
set hg_statuses $hg_statuses deleted
|
||||||
|
case '\? '
|
||||||
|
set hg_statuses $hg_statuses untracked
|
||||||
|
case 'U*' '*U' 'DD' 'AA'
|
||||||
|
set hg_statuses $hg_statuses unmerged
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,8 @@ function __fish_is_first_token -d 'Test if no non-switch argument has been speci
|
||||||
case '-*'
|
case '-*'
|
||||||
|
|
||||||
case '*'
|
case '*'
|
||||||
return 1;
|
return 1
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return 0
|
return 0
|
||||||
|
|
|
@ -11,7 +11,8 @@ function __fish_make_completion_signals --description 'Make list of kill signals
|
||||||
# The procps `kill -L` produces a more compact table. We can distinguish the two cases by
|
# The procps `kill -L` produces a more compact table. We can distinguish the two cases by
|
||||||
# testing whether it supports `kill -t`; in which case it is the coreutils `kill` command.
|
# testing whether it supports `kill -t`; in which case it is the coreutils `kill` command.
|
||||||
# Darwin doesn't have kill -t or kill -L
|
# Darwin doesn't have kill -t or kill -L
|
||||||
if kill -t ^/dev/null >/dev/null; or not kill -L ^/dev/null >/dev/null
|
if kill -t ^/dev/null >/dev/null
|
||||||
|
or not kill -L ^/dev/null >/dev/null
|
||||||
# Posix systems print out the name of a signal using 'kill -l SIGNUM'.
|
# Posix systems print out the name of a signal using 'kill -l SIGNUM'.
|
||||||
complete -c kill -s l --description "List names of available signals"
|
complete -c kill -s l --description "List names of available signals"
|
||||||
for i in (seq 31)
|
for i in (seq 31)
|
||||||
|
|
|
@ -4,16 +4,14 @@ function __fish_print_hostnames -d "Print a list of known hostnames"
|
||||||
|
|
||||||
# Print all hosts from /etc/hosts
|
# Print all hosts from /etc/hosts
|
||||||
# use 'getent hosts' on OSes that support it (OpenBSD and Cygwin do not)
|
# use 'getent hosts' on OSes that support it (OpenBSD and Cygwin do not)
|
||||||
if type -q getent; and getent hosts > /dev/null 2>&1 # test if 'getent hosts' works and redirect output so errors don't print
|
if type -q getent
|
||||||
|
and getent hosts >/dev/null 2>&1 # test if 'getent hosts' works and redirect output so errors don't print
|
||||||
# Ignore zero ips
|
# Ignore zero ips
|
||||||
getent hosts | string match -r -v '^0.0.0.0' \
|
getent hosts | string match -r -v '^0.0.0.0' | string replace -r '[0-9.]*\s*' '' | string split " "
|
||||||
| string replace -r '[0-9.]*\s*' '' | string split " "
|
|
||||||
else if test -r /etc/hosts
|
else if test -r /etc/hosts
|
||||||
# Ignore commented lines and functionally empty lines
|
# Ignore commented lines and functionally empty lines
|
||||||
string match -r -v '^\s*0.0.0.0|^\s*#|^\s*$' < /etc/hosts \
|
string match -r -v '^\s*0.0.0.0|^\s*#|^\s*$' </etc/hosts # Strip comments
|
||||||
# Strip comments
|
| string replace -ra '#.*$' '' | string replace -r '[0-9.]*\s*' '' | string trim | string replace -ra '\s+' '\n'
|
||||||
| string replace -ra '#.*$' '' \
|
|
||||||
| string replace -r '[0-9.]*\s*' '' | string trim | string replace -ra '\s+' '\n'
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Print nfs servers from /etc/fstab
|
# Print nfs servers from /etc/fstab
|
||||||
|
@ -27,15 +25,15 @@ function __fish_print_hostnames -d "Print a list of known hostnames"
|
||||||
if test -r $file
|
if test -r $file
|
||||||
# Print hosts from system wide ssh configuration file
|
# Print hosts from system wide ssh configuration file
|
||||||
# Note the non-capturing group to avoid printing "name"
|
# Note the non-capturing group to avoid printing "name"
|
||||||
string match -ri '\s*Host(?:name)?(?:\s+|\s*=\s*)\w.*' < $file | string replace -ri '^\s*Host(?:name)?\s*(\S+)' '$1' \
|
string match -ri '\s*Host(?:name)?(?:\s+|\s*=\s*)\w.*' <$file | string replace -ri '^\s*Host(?:name)?\s*(\S+)' '$1' | string replace -r '\s+' ' ' | string split ' '
|
||||||
| string replace -r '\s+' ' ' | string split ' '
|
|
||||||
set known_hosts $known_hosts (string match -ri '^\s*UserKnownHostsFile|^\s*GlobalKnownHostsFile' < $file \
|
set known_hosts $known_hosts (string match -ri '^\s*UserKnownHostsFile|^\s*GlobalKnownHostsFile' < $file \
|
||||||
| string replace -ri '.*KnownHostsFile\s*' '')
|
| string replace -ri '.*KnownHostsFile\s*' '')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
for file in $known_hosts
|
for file in $known_hosts
|
||||||
# Ignore hosts that are hashed, commented or have custom ports (like [localhost]:2200)
|
# Ignore hosts that are hashed, commented or have custom ports (like [localhost]:2200)
|
||||||
test -r $file; and string replace -ra '(\S+) .*' '$1' < $file | string match -r '^[^#|[=]+$' | string split ","
|
test -r $file
|
||||||
|
and string replace -ra '(\S+) .*' '$1' <$file | string match -r '^[^#|[=]+$' | string split ","
|
||||||
end
|
end
|
||||||
return 0
|
return 0
|
||||||
end
|
end
|
||||||
|
|
|
@ -5,8 +5,7 @@ function __fish_print_mounted --description 'Print mounted devices'
|
||||||
# \011 encodes a tab, \012 encodes a newline and \\ encodes a backslash
|
# \011 encodes a tab, \012 encodes a newline and \\ encodes a backslash
|
||||||
# This will probably break on newlines because of our splitting, though
|
# This will probably break on newlines because of our splitting, though
|
||||||
# and tabs because of descriptions
|
# and tabs because of descriptions
|
||||||
string replace -r '\S+ (\S+) .*' '$1' </etc/mtab | string replace -a "\040" " " \
|
string replace -r '\S+ (\S+) .*' '$1' </etc/mtab | string replace -a "\040" " " | string replace -a "\011" \t | string replace -a "\012" \n | string replace -a "\\\\" "\\"
|
||||||
| string replace -a "\011" \t | string replace -a "\012" \n | string replace -a "\\\\" "\\"
|
|
||||||
else
|
else
|
||||||
mount | cut -d " " -f 1-3 | tr " " \n | sed -e "s/[0-9\.]*:\//\//" | __fish_sgrep "^/"
|
mount | cut -d " " -f 1-3 | tr " " \n | sed -e "s/[0-9\.]*:\//\//" | __fish_sgrep "^/"
|
||||||
end
|
end
|
||||||
|
|
|
@ -97,7 +97,8 @@ function __fish_svn_prompt --description "Prompt function for svn"
|
||||||
|
|
||||||
# make sure that this is a svn repo
|
# make sure that this is a svn repo
|
||||||
set -l checkout_info (command svn info ^/dev/null)
|
set -l checkout_info (command svn info ^/dev/null)
|
||||||
if [ $status -ne 0 ];
|
if [ $status -ne 0 ]
|
||||||
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -122,7 +123,8 @@ function __fish_svn_prompt --description "Prompt function for svn"
|
||||||
set -l column_status (printf '%s\n' $svn_status_lines | cut -c $col | tr -d ' \n')
|
set -l column_status (printf '%s\n' $svn_status_lines | cut -c $col | tr -d ' \n')
|
||||||
|
|
||||||
# check that the character count is not zero (this would indicate that there are status flags in this column)
|
# check that the character count is not zero (this would indicate that there are status flags in this column)
|
||||||
if [ (count $column_status) -ne 0 ];
|
if [ (count $column_status) -ne 0 ]
|
||||||
|
|
||||||
# we only want to display unique status flags (eg: if there are 5 modified files, the prompt should only show the modified status once)
|
# we only want to display unique status flags (eg: if there are 5 modified files, the prompt should only show the modified status once)
|
||||||
set -l column_unique_status (echo $column_status | sort | uniq)
|
set -l column_unique_status (echo $column_status | sort | uniq)
|
||||||
# parse the status flags for this column and create the formatting by calling out to the helper function
|
# parse the status flags for this column and create the formatting by calling out to the helper function
|
||||||
|
|
|
@ -1,5 +1,7 @@
|
||||||
# Like for running machines, I'm assuming machinectl doesn't allow spaces in image names
|
# Like for running machines, I'm assuming machinectl doesn't allow spaces in image names
|
||||||
# This does not include the special image ".host" since it isn't valid for most operations
|
# This does not include the special image ".host" since it isn't valid for most operations
|
||||||
function __fish_systemd_machine_images
|
function __fish_systemd_machine_images
|
||||||
machinectl --no-legend --no-pager list-images | while read -l a b; echo $a; end
|
machinectl --no-legend --no-pager list-images | while read -l a b
|
||||||
|
echo $a
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
# It seems machinectl will eliminate spaces from machine names so we don't need to handle that
|
# It seems machinectl will eliminate spaces from machine names so we don't need to handle that
|
||||||
function __fish_systemd_machines
|
function __fish_systemd_machines
|
||||||
machinectl --no-legend --no-pager list --all | while read -l a b; echo $a; end
|
machinectl --no-legend --no-pager list --all | while read -l a b
|
||||||
|
echo $a
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -13,5 +13,6 @@ function __fish_toggle_comment_commandline --description 'Comment/uncomment the
|
||||||
end
|
end
|
||||||
set -l cmdlines (printf '%s\n' '#'$cmdlines | string replace -r '^##' '')
|
set -l cmdlines (printf '%s\n' '#'$cmdlines | string replace -r '^##' '')
|
||||||
commandline -r $cmdlines
|
commandline -r $cmdlines
|
||||||
string match -q '#*' $cmdlines[1]; and commandline -f execute
|
string match -q '#*' $cmdlines[1]
|
||||||
|
and commandline -f execute
|
||||||
end
|
end
|
||||||
|
|
|
@ -2,7 +2,11 @@ function __fish_urlencode --description "URL-encode stdin"
|
||||||
set -l join ''
|
set -l join ''
|
||||||
set -l chars
|
set -l chars
|
||||||
# Set locale to C and IFS to "" in order to split a line into bytes.
|
# Set locale to C and IFS to "" in order to split a line into bytes.
|
||||||
while begin; set -lx LC_ALL C; set -lx IFS ''; read -az chars; end
|
while begin
|
||||||
|
set -lx LC_ALL C
|
||||||
|
set -lx IFS ''
|
||||||
|
read -az chars
|
||||||
|
end
|
||||||
printf '%s' $join
|
printf '%s' $join
|
||||||
# chomp off a trailing newline
|
# chomp off a trailing newline
|
||||||
if test "$chars[-1]" = \n
|
if test "$chars[-1]" = \n
|
||||||
|
|
|
@ -51,13 +51,20 @@ function __terlar_git_prompt --description 'Write out the git prompt'
|
||||||
end
|
end
|
||||||
|
|
||||||
switch $i
|
switch $i
|
||||||
case 'A ' ; set gs $gs added
|
case 'A '
|
||||||
case 'M ' ' M' ; set gs $gs modified
|
set gs $gs added
|
||||||
case 'R ' ; set gs $gs renamed
|
case 'M ' ' M'
|
||||||
case 'C ' ; set gs $gs copied
|
set gs $gs modified
|
||||||
case 'D ' ' D' ; set gs $gs deleted
|
case 'R '
|
||||||
case '\?\?' ; set gs $gs untracked
|
set gs $gs renamed
|
||||||
case 'U*' '*U' 'DD' 'AA'; set gs $gs unmerged
|
case 'C '
|
||||||
|
set gs $gs copied
|
||||||
|
case 'D ' ' D'
|
||||||
|
set gs $gs deleted
|
||||||
|
case '\?\?'
|
||||||
|
set gs $gs untracked
|
||||||
|
case 'U*' '*U' 'DD' 'AA'
|
||||||
|
set gs $gs unmerged
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -74,12 +74,14 @@ function abbr --description "Manage abbreviations"
|
||||||
case 'add'
|
case 'add'
|
||||||
# Convert from old "key=value" syntax
|
# Convert from old "key=value" syntax
|
||||||
# TODO: This should be removed later
|
# TODO: This should be removed later
|
||||||
if not set -q mode_arg[2]; and string match -qr '^[^ ]+=' -- $mode_arg
|
if not set -q mode_arg[2]
|
||||||
|
and string match -qr '^[^ ]+=' -- $mode_arg
|
||||||
set mode_arg (string split "=" -- $mode_arg)
|
set mode_arg (string split "=" -- $mode_arg)
|
||||||
end
|
end
|
||||||
|
|
||||||
# Bail out early if the exact abbr is already in
|
# Bail out early if the exact abbr is already in
|
||||||
contains -- "$mode_arg" $fish_user_abbreviations; and return 0
|
contains -- "$mode_arg" $fish_user_abbreviations
|
||||||
|
and return 0
|
||||||
set -l key $mode_arg[1]
|
set -l key $mode_arg[1]
|
||||||
set -e mode_arg[1]
|
set -e mode_arg[1]
|
||||||
set -l value "$mode_arg"
|
set -l value "$mode_arg"
|
||||||
|
@ -122,7 +124,8 @@ function abbr --description "Manage abbreviations"
|
||||||
|
|
||||||
# Check to see if either key or value has a leading dash
|
# Check to see if either key or value has a leading dash
|
||||||
# If so, we need to write --
|
# If so, we need to write --
|
||||||
string match -q -- '-*' $key $value; and set opt_double_dash '--'
|
string match -q -- '-*' $key $value
|
||||||
|
and set opt_double_dash '--'
|
||||||
echo abbr $opt_double_dash (string escape -- $key $value)
|
echo abbr $opt_double_dash (string escape -- $key $value)
|
||||||
end
|
end
|
||||||
return 0
|
return 0
|
||||||
|
|
|
@ -69,7 +69,10 @@ function funced --description 'Edit function definition'
|
||||||
set editor fish
|
set editor fish
|
||||||
end
|
end
|
||||||
|
|
||||||
if begin; set -q interactive[1]; or test "$editor" = fish; end
|
if begin
|
||||||
|
set -q interactive[1]
|
||||||
|
or test "$editor" = fish
|
||||||
|
end
|
||||||
set -l IFS
|
set -l IFS
|
||||||
if functions -q -- $funcname
|
if functions -q -- $funcname
|
||||||
# Shadow IFS here to avoid array splitting in command substitution
|
# Shadow IFS here to avoid array splitting in command substitution
|
||||||
|
@ -89,7 +92,8 @@ function funced --description 'Edit function definition'
|
||||||
|
|
||||||
# OSX mktemp is rather restricted - no suffix, no way to automatically use TMPDIR
|
# OSX mktemp is rather restricted - no suffix, no way to automatically use TMPDIR
|
||||||
# Create a directory so we can use a ".fish" suffix for the file - makes editors pick up that it's a fish file
|
# Create a directory so we can use a ".fish" suffix for the file - makes editors pick up that it's a fish file
|
||||||
set -q TMPDIR; or set -l TMPDIR /tmp
|
set -q TMPDIR
|
||||||
|
or set -l TMPDIR /tmp
|
||||||
set -l tmpdir (mktemp -d $TMPDIR/fish.XXXXXX)
|
set -l tmpdir (mktemp -d $TMPDIR/fish.XXXXXX)
|
||||||
set -l tmpname $tmpdir/$funcname.fish
|
set -l tmpname $tmpdir/$funcname.fish
|
||||||
|
|
||||||
|
|
|
@ -7,7 +7,8 @@ function man --description "Format and display the on-line manual pages"
|
||||||
# Notice local but exported variable
|
# Notice local but exported variable
|
||||||
set -lx MANPATH (string join : $MANPATH)
|
set -lx MANPATH (string join : $MANPATH)
|
||||||
if test -z "$MANPATH"
|
if test -z "$MANPATH"
|
||||||
type -q manpath; and set MANPATH (command manpath)
|
type -q manpath
|
||||||
|
and set MANPATH (command manpath)
|
||||||
end
|
end
|
||||||
set -l fish_manpath (dirname $__fish_datadir)/fish/man
|
set -l fish_manpath (dirname $__fish_datadir)/fish/man
|
||||||
if test -d "$fish_manpath" -a -n "$MANPATH"
|
if test -d "$fish_manpath" -a -n "$MANPATH"
|
||||||
|
|
|
@ -38,7 +38,8 @@ function nextd --description "Move forward in the directory history"
|
||||||
if count $times >/dev/null
|
if count $times >/dev/null
|
||||||
for i in (seq $times)
|
for i in (seq $times)
|
||||||
# Try one step backward
|
# Try one step backward
|
||||||
if __fish_move_last dirnext dirprev;
|
if __fish_move_last dirnext dirprev
|
||||||
|
|
||||||
# We consider it a success if we were able to do at least 1 step
|
# We consider it a success if we were able to do at least 1 step
|
||||||
# (low expectations are the key to happiness ;)
|
# (low expectations are the key to happiness ;)
|
||||||
set code 0
|
set code 0
|
||||||
|
|
|
@ -38,7 +38,8 @@ function prevd --description "Move back in the directory history"
|
||||||
if count $times >/dev/null
|
if count $times >/dev/null
|
||||||
for i in (seq $times)
|
for i in (seq $times)
|
||||||
# Try one step backward
|
# Try one step backward
|
||||||
if __fish_move_last dirprev dirnext;
|
if __fish_move_last dirprev dirnext
|
||||||
|
|
||||||
# We consider it a success if we were able to do at least 1 step
|
# We consider it a success if we were able to do at least 1 step
|
||||||
# (low expectations are the key to happiness ;)
|
# (low expectations are the key to happiness ;)
|
||||||
set code 0
|
set code 0
|
||||||
|
|
|
@ -1,12 +1,14 @@
|
||||||
function prompt_pwd --description "Print the current working directory, shortened to fit the prompt"
|
function prompt_pwd --description "Print the current working directory, shortened to fit the prompt"
|
||||||
set -q argv[1]; and switch $argv[1]
|
set -q argv[1]
|
||||||
|
and switch $argv[1]
|
||||||
case -h --help
|
case -h --help
|
||||||
__fish_print_help prompt_pwd
|
__fish_print_help prompt_pwd
|
||||||
return 0
|
return 0
|
||||||
end
|
end
|
||||||
|
|
||||||
# This allows overriding fish_prompt_pwd_dir_length from the outside (global or universal) without leaking it
|
# This allows overriding fish_prompt_pwd_dir_length from the outside (global or universal) without leaking it
|
||||||
set -q fish_prompt_pwd_dir_length; or set -l fish_prompt_pwd_dir_length 1
|
set -q fish_prompt_pwd_dir_length
|
||||||
|
or set -l fish_prompt_pwd_dir_length 1
|
||||||
|
|
||||||
# Replace $HOME with "~"
|
# Replace $HOME with "~"
|
||||||
set realhome ~
|
set realhome ~
|
||||||
|
|
|
@ -60,7 +60,8 @@ function psub --description "Read from stdin into a file and output the filename
|
||||||
# Write output to pipe. This needs to be done in the background so
|
# Write output to pipe. This needs to be done in the background so
|
||||||
# that the command substitution exits without needing to wait for
|
# that the command substitution exits without needing to wait for
|
||||||
# all the commands to exit
|
# all the commands to exit
|
||||||
set dirname (mktemp -d "$TMPDIR[1]"/.psub.XXXXXXXXXX); or return
|
set dirname (mktemp -d "$TMPDIR[1]"/.psub.XXXXXXXXXX)
|
||||||
|
or return
|
||||||
set filename $dirname/psub.fifo"$suffix"
|
set filename $dirname/psub.fifo"$suffix"
|
||||||
mkfifo $filename
|
mkfifo $filename
|
||||||
cat >$filename &
|
cat >$filename &
|
||||||
|
@ -78,9 +79,11 @@ function psub --description "Read from stdin into a file and output the filename
|
||||||
|
|
||||||
# Find unique function name
|
# Find unique function name
|
||||||
while true
|
while true
|
||||||
set funcname __fish_psub_(random);
|
set funcname __fish_psub_(random)
|
||||||
|
|
||||||
if not functions $funcname >/dev/null ^/dev/null
|
if not functions $funcname >/dev/null ^/dev/null
|
||||||
break;
|
break
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
function suspend -d "Suspend the current shell."
|
function suspend -d "Suspend the current shell."
|
||||||
if contains -- $argv --help; or contains -- $argv -h
|
if contains -- $argv --help
|
||||||
|
or contains -- $argv -h
|
||||||
__fish_print_help suspend
|
__fish_print_help suspend
|
||||||
and return 0
|
and return 0
|
||||||
end
|
end
|
||||||
|
|
|
@ -143,7 +143,10 @@ function type --description "Print the type of a command"
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if begin; test $found = 0; and test $mode != quiet; end
|
if begin
|
||||||
|
test $found = 0
|
||||||
|
and test $mode != quiet
|
||||||
|
end
|
||||||
printf (_ "%s: Could not find '%s'\n") type $i >&2
|
printf (_ "%s: Could not find '%s'\n") type $i >&2
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,9 @@ function __fish_umask_parse -d "Internal umask function"
|
||||||
# Test if already a valid octal mask, and pad it with zeros
|
# Test if already a valid octal mask, and pad it with zeros
|
||||||
if echo $argv | __fish_sgrep -E '^0?[0-7]{1,3}$' >/dev/null
|
if echo $argv | __fish_sgrep -E '^0?[0-7]{1,3}$' >/dev/null
|
||||||
set -l char_count (echo $argv| wc -c)
|
set -l char_count (echo $argv| wc -c)
|
||||||
for i in (seq (math 5 - $char_count)); set argv 0$argv; end
|
for i in (seq (math 5 - $char_count))
|
||||||
|
set argv 0$argv
|
||||||
|
end
|
||||||
echo $argv
|
echo $argv
|
||||||
else
|
else
|
||||||
# Test if argument really is a valid symbolic mask
|
# Test if argument really is a valid symbolic mask
|
||||||
|
|
Loading…
Reference in a new issue