Merge remote-tracking branch 'upstream/master'

This commit is contained in:
ridiculousfish 2012-04-18 13:21:03 -07:00
commit 71bff26607
36 changed files with 209 additions and 54 deletions

3
CHANGELOG Normal file
View file

@ -0,0 +1,3 @@
24-01-2012 Jan Kanis
* Added a changelog file
* removed unescaping if the 'commandline' builtin is called without the -o (tokenise) flag

View file

@ -188,7 +188,7 @@ static void write_part( const wchar_t *begin,
}
else
{
wchar_t *buff, *esc;
wchar_t *buff;
if( cut_at_cursor )
{
@ -196,14 +196,12 @@ static void write_part( const wchar_t *begin,
}
buff = wcsndup( begin, end-begin );
esc = unescape( buff, UNESCAPE_INCOMPLETE );
// debug( 0, L"woot2 %ls -> %ls", buff, esc );
sb_append( sb_out, esc );
sb_append( sb_out, buff );
sb_append( sb_out, L"\n" );
free( esc );
free( buff );
}

View file

@ -5,7 +5,8 @@
# have been hand edited since.
#
complete -c adduser -l conf --description 'Specify config file" -r
complete -x -c adduser -a "(__fish_complete_users; __fish_complete_groups)"
complete -c adduser -l conf --description 'Specify config file' -r
complete -c adduser -l disabled-login --description 'Do not run passwd to set the password'
complete -c adduser -l disabled-password --description 'Like --disabled-login, but logins are still possible (for example using SSH RSA keys) but not using password authentication'
complete -c adduser -l force-badname --description 'By default, user and group names are checked against the configurable regular expression NAME_REGEX (or NAME_REGEX if --system is specified) specified in the configuration file'
@ -13,10 +14,10 @@ complete -c adduser -l gecos --description 'Set the gecos field for the new entr
complete -c adduser -l gid --description 'When creating a group, this option forces the new groupid to be the given number' -r
complete -c adduser -l group --description 'When combined with --system, a group with the same name and ID as the system user is created'
complete -c adduser -l help --description 'Display brief instructions'
complete -c adduser -l home --description 'Use specified directory as the user's home directory' -x -a '(__fish_complete_directories)'
complete -c adduser -l shell --description 'Use shell as the user's login shell, rather than the default specified by the configuration file' -x -a '(cat /etc/shells)'
complete -c adduser -l home --description 'Use specified directory as the user\'s home directory' -x -a '(__fish_complete_directories)'
complete -c adduser -l shell --description 'Use shell as the user\'s login shell, rather than the default specified by the configuration file' -x -a '(cat /etc/shells)'
complete -c adduser -l ingroup --description 'Add the new user to GROUP instead of a usergroup or the default group defined by USERS_GID in the configuration file' -x -a '(cat /etc/group|cut -d : -f 1)'
complete -c adduser -l no-create-home --description 'Do not create the home directory, even if it doesn't exist'
complete -c adduser -l no-create-home --description 'Do not create the home directory, even if it doesni\'t exist'
complete -c adduser -l quiet --description 'Suppress informational messages, only show warnings and errors'
complete -c adduser -l debug --description 'Be verbose, most useful if you want to nail down a problem with adduser'
complete -c adduser -l system --description 'Create a system user or group'

View file

@ -0,0 +1,3 @@
complete -c djview -x -a "(__fish_complete_suffix .djvu)"

View file

@ -0,0 +1,3 @@
complete -c djview3 -x -a "(__fish_complete_suffix .djvu)"

View file

@ -0,0 +1,3 @@
complete -c djview4 -x -a "(__fish_complete_suffix .djvu)"

View file

@ -0,0 +1,6 @@
complete -c dlocate -s S -x -d 'List records that match filenames'
complete -c dlocate -s L -d 'List all files in the package' -xa '(__fish_print_packages)'
complete -c dlocate -o ls -d 'ls -ldF all files in the package' -xa '(__fish_print_packages)'
complete -c dlocate -o du -d 'du -sck all files in the package' -xa '(__fish_print_packages)'

View file

@ -0,0 +1,6 @@
complete -c dpkg -s i -l install -d 'Install .deb package' -xa '(__fish_complete_suffix .deb)'
complete -c dpkg -s r -l remove -d 'Remove package' -xa '(__fish_print_packages)'
complete -c dpkg -s P -l purge -d 'Purge package' -xa '(__fish_print_packages)'
complete -c dpkg -l force-all -d 'Continue on all problems'

View file

@ -37,6 +37,7 @@ complete -c find -o cnewer --description "File status last changed more recently
complete -c find -o ctime --description "File status last changed specified number of days ago" -r
complete -c find -o empty --description "File is empty and is either a regular file or a directory"
complete -c find -o executable --description "File is executable"
complete -c find -o false --description "Always false"
complete -c find -o fstype --description "File is on filesystem of specified type" -a "(__fish_print_filesystems)" -r
complete -c find -o gid --description "Numeric group id of file" -r

View file

@ -0,0 +1 @@
complete -c funced -xa "(functions -na)" --description "Save function"

View file

@ -0,0 +1 @@
complete -c funcsave -xa "(functions -na)" --description "Save function"

View file

@ -197,10 +197,23 @@ complete -f -c git -n '__fish_git_needs_command' -a revert -d 'Revert an existin
### rm
complete -c git -n '__fish_git_needs_command' -a rm -d 'Remove files from the working tree and from the index'
complete -c git -n '__fish_git_using_command rm' -f
complete -c git -n '__fish_git_using_command rm' -l cached -d 'Keep local copies'
complete -c git -n '__fish_git_using_command rm' -l ignore-unmatch -d 'Exit with a zero status even if no files matched'
complete -c git -n '__fish_git_using_command rm' -s r -d 'Allow recursive removal'
complete -c git -n '__fish_git_using_command rm' -s q -l quiet -d 'Suppress the output'
complete -c git -n '__fish_git_using_command rm' -s f -l force -d 'Override the up-to-date check'
complete -c git -n '__fish_git_using_command rm' -s n -l dry-run -d 'Dry run'
# TODO options
### status
complete -f -c git -n '__fish_git_needs_command' -a status -d 'Show the working tree status'
complete -f -c git -n '__fish_git_using_command status' -s s -l short -d 'Give the output in the short-format'
complete -f -c git -n '__fish_git_using_command status' -s b -l branch -d 'Show the branch and tracking info even in short-format'
complete -f -c git -n '__fish_git_using_command status' -l porcelain -d 'Give the output in a stable, easy-to-parse format'
complete -f -c git -n '__fish_git_using_command status' -s z -d 'Terminate entries with NUL character'
complete -f -c git -n '__fish_git_using_command status' -s u -l untracked-files -x -a 'no normal all' -d 'The untracked files handling mode'
complete -f -c git -n '__fish_git_using_command status' -l ignore-submodules -x -a 'none untracked dirty all' -d 'Ignore changes to submodules'
# TODO options
### tag

View file

@ -0,0 +1,4 @@
complete -c gv -x -a "(__fish_complete_suffix .ps)"
complete -c gv -x -a "(__fish_complete_suffix .ps.gz)"
complete -c gv -x -a "(__fish_complete_suffix .eps)"
complete -c gv -x -a "(__fish_complete_suffix .pdf)"

View file

@ -0,0 +1,5 @@
# Completions for top
complete -c htop -s d --description "Update interval" -x
complete -c htop -s u --description "Monitor effective UID" -x -a "(__fish_complete_users)"
complete -c htop -l sort-key -d 'Sort column' -xa "(htop --sort-key '')"

View file

@ -0,0 +1,2 @@
complete -x -c ifdown -a "(__fish_print_interfaces)" --description "Network interface"
complete -c ifdown -l force --description "force"

View file

@ -0,0 +1,2 @@
complete -x -c ifup -a "(__fish_print_interfaces)" --description "Network interface"
complete -c ifup -l force --description "force"

View file

@ -1,30 +1,6 @@
# Completions for the kill command
__fish_make_completion_signals
set -l signals
if kill -L ^/dev/null >/dev/null
# Debian and some related systems use 'kill -L' to write out a numbered list
# of signals. Use this to complete on both number _and_ on signal name.
complete -c kill -s L --description "List codes and names of available signals"
set signals (kill -L | sed -e 's/\([0-9][0-9]*\) *\([A-Z,0-9][A-Z,0-9]*\)/\1 \2\n/g;s/ +/ /g' | sed -e 's/^ //' | sgrep -E '^[^ ]+')
else
# Posix systems print out the name of a signal using 'kill -l
# SIGNUM', so we use this instead.
complete -c kill -s l --description "List names of available signals"
for i in (seq 31)
set signals $signals $i" "(kill -l $i)
end
end
for i in $signals
for i in $__kill_signals
set number (echo $i | cut -d " " -f 1)
set name (echo $i | cut -d " " -f 2)
complete -c kill -o $number -d $name
@ -33,6 +9,5 @@ for i in $signals
complete -c kill -o s -x -a \"$name\tSend\ $name\ signal\"
end
complete -c kill -xa '(__fish_complete_pids)'

View file

@ -0,0 +1,20 @@
__fish_make_completion_signals
for i in $__kill_signals
set number (echo $i | cut -d " " -f 1)
set name (echo $i | cut -d " " -f 2)
complete -c killall -o $number -d $name
complete -c killall -o $name -d $name
complete -c killall -o s -x -a \"$number\tSend\ $name\ signal\"
complete -c killall -o s -x -a \"$name\tSend\ $name\ signal\"
end
complete -c killall -xa '(__fish_complete_proc)'
complete -c killall -s e -l exact -d 'Require an exact match for very long names'
complete -c killall -s I -l ignore-case -d 'Do case insensitive process name match'
complete -c killall -s g -l process-group -d 'Kill the process group to which the process belongs. The kill signal is only sent once per group, even if multiple processes belonging to the same process group were found'
complete -c killall -s i -l interactive -d 'Interactively ask for confirmation before killing'
complete -c killall -s u -l user -d 'Kill only processes the specified user owns. Command names are optional'
complete -c killall -s w -l wait -d 'Wait for all killed processes to die. killall checks once per second if any of the killed processes still exist and only returns if none are left. Note that killall may wait forever if the signal was ignored, had no effect, or if the process stays in zombie state'

View file

@ -0,0 +1,7 @@
complete -c latexmk -x -a "(__fish_complete_suffix (commandline -ct) .tex '(La)TeX file')"
complete -c latexmk -o dvi -d "Make dvi"
complete -c latexmk -o ps -d "Make ps dvi->ps"
complete -c latexmk -o pdf -d "Make pdf"
complete -c latexmk -o pdfps -d "Make pdf dvi->ps->pdf"
complete -c latexmk -o pdfdvi -d "Make pdf dvi->pdf"

18
share/completions/ln.fish Normal file
View file

@ -0,0 +1,18 @@
# completions for ln
# Author: SanskritFritz (gmail)
complete -c ln -f -s s -l symbolic -d 'make symbolic links instead of hard links'
complete -c ln -f -l backup=CONTROL -d 'make a backup of each existing destination file'
complete -c ln -f -s b -d 'like --backup but does not accept an argument'
complete -c ln -f -s d -l directory -d 'allow the superuser to attempt to hard link directories'
complete -c ln -f -s f -l force -d 'remove existing destination files'
complete -c ln -f -s i -l interactive -d 'prompt whether to remove destinations'
complete -c ln -f -s L -l logical -d 'make hard links to symbolic link references'
complete -c ln -f -s n -l no-dereference -d 'treat destination that is a symlink to a directory as if it were a normal file'
complete -c ln -f -s P -l physical -d 'make hard links directly to symbolic links'
complete -c ln -f -s S -l suffix=SUFFIX -d 'override the usual backup suffix'
complete -c ln -f -s t -l target-directory=DIRECTORY -d 'specify the DIRECTORY in which to create the links'
complete -c ln -f -s T -l no-target-directory -d 'treat LINK_NAME as a normal file'
complete -c ln -f -s v -l verbose -d 'print name of each linked file'
complete -c ln -f -l help -d 'display this help and exit'
complete -c ln -f -l version -d 'output version information and exit'

View file

@ -0,0 +1,2 @@
__fish_complete_tex lualatex

View file

@ -0,0 +1,2 @@
complete -c mupdf -x -a "(__fish_complete_suffix .pdf)"

29
share/completions/nm.fish Normal file
View file

@ -0,0 +1,29 @@
complete -c nm -s a -l debug-syms -d 'Display debugger-only symbols'
complete -c nm -s A -l print-file-name -d 'Print name of the input file before every symbol'
#complete -c nm -C -l demangle[=STYLE] Decode low-level symbol names into user-level names
# Same as --format=bsd
# The STYLE, if specified, can be `auto' (the default),
# `gnu', `lucid', `arm', `hp', `edg', `gnu-v3', `java' or `gnat'
complete -c nm -l no-demangle -d 'Do not demangle low-level symbol names'
complete -c nm -s D -l dynamic -d 'Display dynamic symbols instead of normal symbols'
complete -c nm -l defined-only -d 'Display only defined symbols'
complete -c nm -s f -l format=FORMAT -d 'Use the output format FORMAT. FORMAT can be "bsd", "sysv" or "posix". The default is "bsd"'
complete -c nm -s g -l extern-only -d 'Display only external symbols'
complete -c nm -s l -l line-numbers -d 'Use debugging information to find a filename and line number for each symbol'
complete -c nm -s n -l numeric-sort -d 'Sort symbols numerically by address'
complete -c nm -s o -d 'Print name of the input file before every symbol'
complete -c nm -s p -l no-sort -d 'Do not sort the symbols'
complete -c nm -s P -l portability -d 'Same as --format=posix'
complete -c nm -s r -l reverse-sort -d 'Reverse the sense of the sort'
complete -c nm -l plugin -d 'Load the specified plugin'
complete -c nm -s S -l print-size -d 'Print size of defined symbols'
complete -c nm -s s -l print-armap -d 'Include index for symbols from archive members'
complete -c nm -l size-sort -d 'Sort symbols by size'
complete -c nm -l special-syms -d 'Include special symbols in the output'
complete -c nm -l synthetic -d 'Display synthetic symbols as well'
complete -c nm -s t -l radix=RADIX -d 'Use RADIX for printing symbol values'
complete -c nm -l target=BFDNAME -d 'Specify the target object format as BFDNAME'
complete -c nm -s u -l undefined-only -d 'Display only undefined symbols'
complete -c nm -s h -l help -d 'Display this information'
complete -c nm -s V -l version -d "Display this program's version number"

View file

@ -15,9 +15,9 @@ complete -x -c ssh -d Hostname -a "
"
complete -x -c ssh -d User -a "
(__fish_print_users)@
"
complete -c ssh --description "Command to run" -x -a '(__fish_complete_subcommand --fcs-skip=2)'
complete -c ssh -s a --description "Disables forwarding of the authentication agent"
complete -c ssh -s A --description "Enables forwarding of the authentication agent"
@ -46,3 +46,6 @@ complete -c ssh -s X --description "Enable X11 forwarding"
complete -c ssh -s L --description "Locally forwarded ports"
complete -c ssh -s R --description "Remotely forwarded ports"
complete -c ssh -s D --description "Dynamic port forwarding"
# Since ssh runs subcommands, it can accept any switches
complete -c ssh -u

View file

@ -2,10 +2,16 @@
# Completion for sudo
#
complete -c sudo --description "Command to run" -x -a '(__fish_complete_subcommand_root)'
complete -c sudo -s h -n "__fish_no_arguments" --description "Display help and exit"
complete -c sudo -s v -n "__fish_no_arguments" --description "Validate"
complete -c sudo -s u -a "(__fish_complete_users)" -x -d "Run command as user"
complete -c sudo -s g -a "(__fish_complete_groups)" -x -d "Run command as group"
complete -c sudo -s E -d "Preserve environment"
complete -c sudo -s P -d "Preserve group vector"
complete -c sudo -s S -d "Read password from stdin"
complete -c sudo -s H -d "Set home"
complete -c sudo -s e -r -d "Edit"
complete -c sudo --description "Command to run" -x -a "(__fish_complete_subcommand_root -u -g)"
# Since sudo runs subcommands, it can accept any switches
complete -c sudo -u

View file

@ -0,0 +1 @@
complete -x -c wvdial -a "(cat ~/.wvdialrc | grep '\[Dialer' | sed 's/\[Dialer \(.\+\)\]/\1/')" --description "wvdial connections"

View file

@ -0,0 +1 @@
complete -c xdvi -x -a "(__fish_complete_suffix .dvi)"

View file

@ -0,0 +1,2 @@
__fish_complete_tex xelatex

View file

@ -2,6 +2,7 @@
# Completions for the xpdf command
# Vikas Gorur <vikas@80x25.org>
#
complete -c xpdf -x -a "(__fish_complete_suffix .pdf)"
complete -c xpdf -s g --description "Set the initial window geometry"
complete -c xpdf -o title --description "Set the window title"

View file

@ -0,0 +1,3 @@
function __fish_complete_proc --description 'Complete by list of running processes'
ps a --no-headers --format comm | sort -u
end

View file

@ -1,14 +1,20 @@
function __fish_complete_subcommand -d "Complete subcommand"
set -l skip_next 1
switch "$argv[1]"
case '--fcs-skip=*'
set -l rest
echo $argv[1] | tr = ' ' | read test skip_next
set -e argv[1]
end
set -l res ""
set -l had_cmd 0
set -l cmd (commandline -cop) (commandline -ct)
set -l skip_next 1
for i in $cmd
if test "$skip_next" = 1
set skip_next 0
if test $skip_next -gt 0
set skip_next (expr $skip_next - 1)
continue
end
@ -17,15 +23,15 @@ function __fish_complete_subcommand -d "Complete subcommand"
else
if contains -- $i $argv
set skip_next 1
set skip_next (expr $skip_next + 1)
continue
end
switch $i
case '-*'
case '*=*'
case '*'
set had_cmd 1
set res $i
end

View file

@ -1,8 +1,6 @@
function __fish_complete_subcommand_root -d "Run the __fish_complete_subcommand function using a PATH containing /sbin and /usr/sbin"
set -l PATH_OLD $PATH
set PATH /sbin /usr/sbin $PATH
__fish_complete_subcommand
set PATH $PATH_OLD
set -lx PATH /sbin /usr/sbin $PATH
__fish_complete_subcommand $argv
end

View file

@ -26,10 +26,10 @@ function __fish_complete_suffix -d "Complete using files"
set suff $argv[2]
set desc (mimedb -d $suff)
case 2
case 3
set comp $argv[1]
set suff $argv[2]
set desc $argv[2]
set desc $argv[3]
end

View file

@ -7,4 +7,15 @@ function __fish_complete_tex -d "Common completions for all tex commands"
__fish_complete_suffix (commandline -ct) .tex '(La)TeX file'
)"
complete -c $argv -o file-line-error -d "Show errors in style file:line"
complete -c $argv -o no-file-line-error -d "Show errors not in style file:line"
complete -c $argv -o halt-on-error -d "Stop processing at the first error"
complete -c $argv -o interaction=batchmode -d "Set interation mode"
complete -c $argv -o interaction=nonstopmode -d "Set interation mode"
complete -c $argv -o interaction=scrollmode -d "Set interation mode"
complete -c $argv -o interaction=errorstopmode -d "Set interation mode"
complete -c $argv -o output-directory= -x -a "(__fish_complete_directories (commandline -ct))" -d "Output directory"
complete -c $argv -o shell-escape -d "Enable \write18{SHELL COMMAND}"
complete -c $argv -o no-shell-escape -d "Disable \write18{SHELL COMMAND}"
complete -c $argv -o src-specials -d "Insert source specials into the DVI file"
end

View file

@ -0,0 +1,17 @@
function __fish_make_completion_signals --description 'Make list of kill signals for copmletion'
set -q __kill_signals; and return 0
if kill -L ^/dev/null >/dev/null
# Debian and some related systems use 'kill -L' to write out a numbered list
# of signals. Use this to complete on both number _and_ on signal name.
complete -c kill -s L --description "List codes and names of available signals"
set -g __kill_signals (kill -L | sed -e 's/\([0-9][0-9]*\) *\([A-Z,0-9][A-Z,0-9]*\)/\1 \2\n/g;s/ +/ /g' | sed -e 's/^ \+//' | sgrep -E '^[^ ]+')
else
# Posix systems print out the name of a signal using 'kill -l
# SIGNUM', so we use this instead.
complete -c kill -s l --description "List names of available signals"
for i in (seq 31)
set -g __kill_signals $signals $i" "(kill -l $i)
end
end
end

1
util.c
View file

@ -7,6 +7,7 @@
#include "config.h"
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <wchar.h>