2009-05-21 01:40:30 +02:00
|
|
|
# bash completion for GNU find. This makes heavy use of ksh style extended
|
|
|
|
# globs and contains Linux specific code for completing the parameter
|
|
|
|
# to the -fstype option.
|
|
|
|
|
2009-06-08 21:22:43 +03:00
|
|
|
have find &&
|
2009-05-21 01:40:30 +02:00
|
|
|
_find()
|
|
|
|
{
|
2011-02-10 23:55:16 +02:00
|
|
|
local cur prev i onlyonce
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
COMPREPLY=()
|
2010-02-08 17:25:08 +01:00
|
|
|
_get_comp_words_by_ref cur prev
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-12-30 00:39:59 +01:00
|
|
|
case $prev in
|
2010-04-21 00:29:45 +03:00
|
|
|
-maxdepth|-mindepth)
|
|
|
|
COMPREPLY=( $( compgen -W '0 1 2 3 4 5 6 7 8 9' -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-newer|-anewer|-cnewer|-fls|-fprint|-fprint0|-fprintf|-name|-iname|\
|
2010-05-08 00:10:07 +03:00
|
|
|
-lname|-ilname|-wholename|-iwholename|-samefile)
|
2010-04-21 00:29:45 +03:00
|
|
|
_filedir
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-fstype)
|
2010-04-21 19:07:17 +03:00
|
|
|
_fstypes
|
|
|
|
if [[ "$( uname -s )" == *BSD ]] ; then
|
|
|
|
COMPREPLY=( "${COMPREPLY[@]}" \
|
|
|
|
$( compgen -W 'local rdonly' -- "$cur" ) )
|
|
|
|
fi
|
2010-04-21 00:29:45 +03:00
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-gid)
|
|
|
|
_gids
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-group)
|
|
|
|
COMPREPLY=( $( compgen -g -- "$cur" 2>/dev/null) )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-xtype|-type)
|
|
|
|
COMPREPLY=( $( compgen -W 'b c d p f l s' -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-uid)
|
|
|
|
_uids
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-user)
|
|
|
|
COMPREPLY=( $( compgen -u -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
2010-05-08 00:10:07 +03:00
|
|
|
-exec|-execdir|-ok|-okdir)
|
2010-04-21 00:29:45 +03:00
|
|
|
COMP_WORDS=(COMP_WORDS[0] "$cur")
|
|
|
|
COMP_CWORD=1
|
|
|
|
_command
|
|
|
|
return 0
|
|
|
|
;;
|
|
|
|
-[acm]min|-[acm]time|-iname|-lname|-wholename|-iwholename|-lwholename|\
|
|
|
|
-ilwholename|-inum|-path|-ipath|-regex|-iregex|-links|-perm|-size|\
|
2010-05-08 00:18:40 +03:00
|
|
|
-used|-printf|-context)
|
2010-04-21 00:29:45 +03:00
|
|
|
# do nothing, just wait for a parameter to be given
|
|
|
|
return 0
|
|
|
|
;;
|
2010-05-08 00:10:07 +03:00
|
|
|
-regextype)
|
|
|
|
COMPREPLY=( $( compgen -W 'emacs posix-awk posix-basic \
|
|
|
|
posix-egrep posix-extended' -- "$cur" ) )
|
|
|
|
return 0
|
|
|
|
;;
|
2009-10-04 19:42:50 +02:00
|
|
|
esac
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
_expand || return 0
|
2011-02-10 23:55:16 +02:00
|
|
|
|
|
|
|
local exprfound=false
|
|
|
|
# set exprfound to true if there is already an expression present
|
2009-10-04 19:42:50 +02:00
|
|
|
for i in ${COMP_WORDS[@]}; do
|
2011-02-10 23:55:16 +02:00
|
|
|
[[ "$i" = [-\(\),\!]* ]] && exprfound=true && break
|
2009-10-04 19:42:50 +02:00
|
|
|
done
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
# handle case where first parameter is not a dash option
|
2011-02-10 23:55:16 +02:00
|
|
|
if ! $exprfound && [[ "$cur" != [-\(\),\!]* ]]; then
|
2009-10-04 19:42:50 +02:00
|
|
|
_filedir -d
|
|
|
|
return 0
|
|
|
|
fi
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
# complete using basic options
|
2010-05-08 00:10:07 +03:00
|
|
|
COMPREPLY=( $( compgen -W '-daystart -depth -follow -help \
|
|
|
|
-ignore_readdir_race -maxdepth -mindepth -mindepth -mount \
|
|
|
|
-noignore_readdir_race -noleaf -regextype -version -warn -nowarn \
|
|
|
|
-xdev \
|
|
|
|
-amin -anewer -atime -cmin -cnewer -ctime -empty -executable -false \
|
|
|
|
-fstype -gid -group -ilname -iname -inum -ipath -iregex -iwholename \
|
|
|
|
-links -lname -mmin -mtime -name -newer -nogroup -nouser -path -perm \
|
|
|
|
-readable -regex -samefile -size -true -type -uid -used -user \
|
2010-05-08 00:18:40 +03:00
|
|
|
-wholename -writable -xtype -context \
|
2010-05-08 00:10:07 +03:00
|
|
|
-delete -exec -execdir -fls -fprint -fprint0 -fprintf -ls -ok -okdir \
|
|
|
|
-print -print0 -printf -prune -quit' -- "$cur" ) )
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
# this removes any options from the list of completions that have
|
|
|
|
# already been specified somewhere on the command line, as long as
|
|
|
|
# these options can only be used once (in a word, "options", in
|
|
|
|
# opposition to "tests" and "actions", as in the find(1) manpage).
|
2010-05-08 00:10:07 +03:00
|
|
|
onlyonce=' -daystart -depth -follow -help -ignore_readdir_race -maxdepth \
|
|
|
|
-mindepth -mount -noignore_readdir_race -noleaf -nowarn -regextype \
|
|
|
|
-version -warn -xdev '
|
2009-12-09 22:46:09 +02:00
|
|
|
COMPREPLY=( $( \
|
2009-10-04 19:42:50 +02:00
|
|
|
(while read -d ' ' i; do
|
2009-11-23 20:08:52 +02:00
|
|
|
[[ -z "$i" || "${onlyonce/ ${i%% *} / }" == "$onlyonce" ]] &&
|
2009-10-04 19:42:50 +02:00
|
|
|
continue
|
|
|
|
# flatten array with spaces on either side,
|
|
|
|
# otherwise we cannot grep on word boundaries of
|
|
|
|
# first and last word
|
|
|
|
COMPREPLY=" ${COMPREPLY[@]} "
|
|
|
|
# remove word from list of completions
|
|
|
|
COMPREPLY=( ${COMPREPLY/ ${i%% *} / } )
|
|
|
|
done
|
2009-12-21 00:09:02 +02:00
|
|
|
printf '%s ' "${COMPREPLY[@]}") <<<"${COMP_WORDS[@]}"
|
2009-10-04 19:42:50 +02:00
|
|
|
) )
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
_filedir
|
2009-05-21 01:40:30 +02:00
|
|
|
|
2009-10-04 19:42:50 +02:00
|
|
|
return 0
|
2009-06-08 21:22:43 +03:00
|
|
|
} &&
|
2010-11-01 19:26:53 +02:00
|
|
|
complete -F _find find
|
2009-10-01 20:54:51 +03:00
|
|
|
|
|
|
|
# Local variables:
|
|
|
|
# mode: shell-script
|
2009-10-04 19:42:50 +02:00
|
|
|
# sh-basic-offset: 4
|
2009-10-01 20:54:51 +03:00
|
|
|
# sh-indent-comment: t
|
2009-10-04 19:42:50 +02:00
|
|
|
# indent-tabs-mode: nil
|
2009-10-01 20:54:51 +03:00
|
|
|
# End:
|
2009-10-04 19:42:50 +02:00
|
|
|
# ex: ts=4 sw=4 et filetype=sh
|