make 'alias' check for recursive calls and insert 'command'; update docs, fix #486

This commit is contained in:
Jan Kanis 2013-01-01 22:56:08 +01:00
parent 1ae0e5d7cb
commit a4c646f75c
4 changed files with 16 additions and 5 deletions

View file

@ -44,7 +44,7 @@ will run the \c ls command, using the \c -l option, while passing on any additio
<pre> <pre>
function mkdir -d "Create a directory and set CWD" function mkdir -d "Create a directory and set CWD"
mkdir $argv command mkdir $argv
if test $status = 0 if test $status = 0
switch $argv[(count $argv)] switch $argv[(count $argv)]
case '-*' case '-*'

View file

@ -284,7 +284,7 @@ turning on colors on GNU systems is \c '--color=auto'. A wrapper
around \c ls might look like this: around \c ls might look like this:
<pre>function ls <pre>function ls
ls --color=auto $argv command ls --color=auto $argv
end end
</pre> </pre>
@ -292,7 +292,7 @@ There are a few important things that need to be noted about wrapper
functions: functions:
- Wrappers should always take care to add the $argv variable to the list of parameters to the wrapped command. This makes sure that if the user specifies any additional parameters to the function, they are passed on to the underlying command. - Wrappers should always take care to add the $argv variable to the list of parameters to the wrapped command. This makes sure that if the user specifies any additional parameters to the function, they are passed on to the underlying command.
- If the wrapped command is not the first command to be called by the wrapper, it is necessary to prefix the call to the command with the word 'command' in order to tell fish that the function should not call itself, but rather a command with the same name. Failing to do so will cause infinite recursion bugs. - If the wrapper has the same name as the wrapped command, it is necessary to prefix the call to the command with the word 'command' in order to tell fish that the function should not call itself, but rather a command with the same name. Failing to do so will cause infinite recursion bugs.
\subsubsection syntax-function-autoloading Autoloading functions \subsubsection syntax-function-autoloading Autoloading functions

View file

@ -10,7 +10,7 @@ With no options, indicate how each name would be interpreted if used as a comman
- \c -h or \c --help print this message - \c -h or \c --help print this message
- \c -a or \c --all print all of possible definitions of the specified names - \c -a or \c --all print all of possible definitions of the specified names
- \c -f or \c --no-functions suppresses function and builtin lookup - \c -f or \c --no-functions suppresses function and builtin lookup
- \c -t or \c --type print a string which is one of alias, keyword, function, builtin, or file if name is an alias, shell reserved word, function, builtin, or disk file, respectively - \c -t or \c --type print a string which is one of keyword, function, builtin, or file if name is a shell reserved word, function, builtin, or disk file, respectively
- \c -p or \c --path either return the name of the disk file that would be executed if name were specified as a command name, or nothing if 'type -t name' would not return 'file' - \c -p or \c --path either return the name of the disk file that would be executed if name were specified as a command name, or nothing if 'type -t name' would not return 'file'
- \c -P or \c --force-path either return the name of the disk file that would be executed if name were specified as a command name, or nothing no file with the specified name could be found in the PATH - \c -P or \c --force-path either return the name of the disk file that would be executed if name were specified as a command name, or nothing no file with the specified name could be found in the PATH

View file

@ -11,6 +11,7 @@ function alias --description "Legacy function for creating shellscript functions
set -l name set -l name
set -l body set -l body
set -l prefix
switch (count $argv) switch (count $argv)
case 0 case 0
@ -34,5 +35,15 @@ function alias --description "Legacy function for creating shellscript functions
return 1 return 1
end end
eval "function $name; $body \$argv; end" switch (type -t $name)
case file
set prefix command
case builtin
set prefix builtin
case function
printf ( _ "%s: A function with the name '%s' already exists. Use the 'functions' or 'funced' commands to edit it.") alias "$name"
return 1
end
eval "function $name; $prefix $body \$argv; end"
end end