2006-10-19 21:50:23 +10:00
#
# Main file for fish command completions. This file contains various
# common helper functions for the command completions. All actual
# completions are located in the completions subdirectory.
#
2007-04-23 04:49:56 +10:00
#
# Set default field separators
#
set -g IFS \n \ \t
2014-02-20 10:26:57 -08:00
#
# Create the default command_not_found handler
#
function __fish_default_command_not_found_handler
echo " fish: Unknown command ' $argv ' " > & 2
end
#
# Hook up the default as the principal command_not_found handler
2015-08-31 18:39:15 +02:00
# for starting up since finding and executing a real one is not cheap
# This will be erased in __fish_command_not_found_setup once we're interactive
2014-02-20 10:26:57 -08:00
#
2015-08-31 18:39:15 +02:00
function __fish_startup_command_not_found_handler --on-event fish_command_not_found
2014-02-20 10:26:57 -08:00
__fish_default_command_not_found_handler $argv
end
2006-10-19 21:50:23 +10:00
#
# Set default search paths for completions and shellscript functions
# unless they already exist
#
set -l configdir ~/.config
2007-10-28 19:08:40 +10:00
2006-10-19 21:50:23 +10:00
if set -q XDG_CONFIG_HOME
set configdir $XDG_CONFIG_HOME
end
2014-09-29 19:39:36 +08:00
set -l userdatadir ~/.local/share
if set -q XDG_DATA_HOME
set userdatadir $XDG_DATA_HOME
end
2012-07-08 15:20:39 -07:00
# __fish_datadir, __fish_sysconfdir, __fish_help_dir, __fish_bin_dir
# are expected to have been set up by read_init from fish.cpp
2006-10-19 21:50:23 +10:00
2007-10-28 19:08:40 +10:00
# Set up function and completion paths. Make sure that the fish
# default functions/completions are included in the respective path.
2010-09-18 10:18:26 +08:00
if not set -q fish_function_path
2012-07-08 15:20:39 -07:00
set fish_function_path $configdir /fish /functions $__fish_sysconfdir /functions $__fish_datadir /functions
2006-10-19 21:50:23 +10:00
end
2012-07-08 15:20:39 -07:00
if not contains $__fish_datadir /functions $fish_function_path
2014-08-20 18:43:17 -07:00
set fish_function_path $fish_function_path $__fish_datadir /functions
2007-10-28 19:10:42 +10:00
end
2010-09-18 10:18:26 +08:00
if not set -q fish_complete_path
2014-10-01 07:01:24 +08:00
set fish_complete_path $configdir /fish /completions $__fish_sysconfdir /completions $__fish_datadir /vendor_completions.d $__fish_datadir /completions $userdatadir /fish /generated_completions
2006-10-19 21:50:23 +10:00
end
2012-07-08 15:20:39 -07:00
if not contains $__fish_datadir /completions $fish_complete_path
2014-08-20 18:43:17 -07:00
set fish_complete_path $fish_complete_path $__fish_datadir /completions
2007-10-28 19:10:42 +10:00
end
2007-10-28 19:08:40 +10:00
#
2006-10-19 21:50:23 +10:00
# This is a Solaris-specific test to modify the PATH so that
2007-10-28 19:08:40 +10:00
# Posix-conformant tools are used by default. It is separate from the
# other PATH code because this directory needs to be prepended, not
# appended, since it contains POSIX-compliant replacements for various
# system utilities.
#
2006-10-19 21:50:23 +10:00
if test -d /usr/xpg4/bin
if not contains /usr/xpg4/bin $PATH
2010-09-18 10:18:26 +08:00
set PATH /usr/xpg4/bin $PATH
2006-10-19 21:50:23 +10:00
end
2010-09-18 10:18:26 +08:00
end
2006-10-19 21:50:23 +10:00
2013-02-22 14:01:17 -08:00
# OS X-ism: Load the path files out of /etc/paths and /etc/paths.d/*
2013-08-25 13:25:24 -07:00
set -g __fish_tmp_path $PATH
2013-02-22 14:01:17 -08:00
function __fish_load_path_helper_paths
2013-08-25 14:00:56 -07:00
# We want to rearrange the path to reflect this order. Delete that path component if it exists and then prepend it.
# Since we are prepending but want to preserve the order of the input file, we reverse the array, append, and then reverse it again
set __fish_tmp_path $__fish_tmp_path [ - 1 .. 1 ]
2013-02-22 14:01:17 -08:00
while read -l new_path_comp
2013-08-25 14:00:56 -07:00
set -l where ( contains -i $new_path_comp $__fish_tmp_path )
2013-08-25 13:25:24 -07:00
and set -e __fish_tmp_path [ $where ]
set __fish_tmp_path $new_path_comp $__fish_tmp_path
2013-02-22 14:01:17 -08:00
end
2013-08-25 14:00:56 -07:00
set __fish_tmp_path $__fish_tmp_path [ - 1 .. 1 ]
2013-02-22 14:01:17 -08:00
end
2013-08-25 13:25:24 -07:00
test -r /etc/paths ; and __fish_load_path_helper_paths < /etc/paths
2013-02-22 14:01:17 -08:00
for pathfile in /etc/paths.d/* ; __fish_load_path_helper_paths < $pathfile ; end
2013-08-25 13:25:24 -07:00
set -xg PATH $__fish_tmp_path
set -e __fish_tmp_path
2013-02-22 14:01:17 -08:00
functions -e __fish_load_path_helper_paths
2013-08-25 13:25:24 -07:00
# Add a handler for when fish_user_path changes, so we can apply the same changes to PATH
# Invoke it immediately to apply the current value of fish_user_path
function __fish_reconstruct_path -d "Update PATH when fish_user_paths changes" --on-variable fish_user_paths
set -l local_path $PATH
set -l x
for x in $__fish_added_user_paths
set -l idx ( contains --index $x $local_path )
and set -e local_path [ $idx ]
end
set -e __fish_added_user_paths
for x in $fish_user_paths [ - 1 .. 1 ]
2013-12-10 12:52:04 -05:00
if set -l idx ( contains --index $x $local_path )
set -e local_path [ $idx ]
else
2013-08-25 13:25:24 -07:00
set -g __fish_added_user_paths $__fish_added_user_paths $x
end
2013-12-10 12:52:04 -05:00
set local_path $x $local_path
2013-08-25 13:25:24 -07:00
end
set -xg PATH $local_path
end
__fish_reconstruct_path
2007-08-20 02:42:30 +10:00
#
2007-04-24 07:10:26 +10:00
# Launch debugger on SIGTRAP
2007-08-20 02:42:30 +10:00
#
2013-02-19 17:48:51 -08:00
function fish_sigtrap_handler --on-signal TRAP --no-scope-shadowing --description "Signal handler for the TRAP signal. Launches a debug prompt."
2007-04-24 07:10:26 +10:00
breakpoint
end
2006-10-19 21:50:23 +10:00
2007-08-20 02:42:30 +10:00
#
# Whenever a prompt is displayed, make sure that interactive
# mode-specific initializations have been performed.
2007-10-28 19:11:17 +10:00
# This handler removes itself after it is first called.
2007-08-20 02:42:30 +10:00
#
function __fish_on_interactive --on-event fish_prompt
__fish_config_interactive
2007-10-28 19:11:17 +10:00
functions -e __fish_on_interactive
2006-10-19 21:50:23 +10:00
end
2007-08-20 02:42:30 +10:00
2013-08-14 18:43:09 +03:00
# "." command for compatibility with old fish versions.
2013-08-17 17:04:16 -07:00
function . --description 'Evaluate contents of file (deprecated, see "source")' --no-scope-shadowing
2013-08-14 18:43:09 +03:00
if begin
test ( count $argv ) -eq 0
# Uses tty directly, as isatty depends on "."
and tty 0 > & 0 > /dev/null
end
echo "source: '.' command is deprecated, and doesn't work with STDIN anymore. Did you mean 'source' or './'?" > & 2
return 1
else
source $argv
end
end