[Bash-completion-commits] [SCM] bash-completion branch, master, updated. c1d3cdad70523552e63688cb053a960b64e97b16
Ville Skyttä
ville.skytta at iki.fi
Sun Nov 21 18:37:56 UTC 2010
The following commit has been merged in the master branch:
commit 96908c87f1ea2fb3b0356a03168aaea365d04902
Author: Ville Skyttä <ville.skytta at iki.fi>
Date: Sun Nov 21 19:59:38 2010 +0200
Add lsof(8) completion.
diff --git a/CHANGES b/CHANGES
index c53ae2f..66ec729 100644
--- a/CHANGES
+++ b/CHANGES
@@ -9,7 +9,7 @@ bash-completion (2.x)
[ Ville Skyttä ]
* Activate hping2 completion also for hping and hping3.
* Add badblocks, compgen, crontab, dumpe2fs, e2freefrag, e2label, ether-wake,
- filefrag, growisofs, iftop, ip (Debian: #600617), lrzip, POSIX sh,
+ filefrag, growisofs, iftop, ip (Debian: #600617), lrzip, lsof, POSIX sh,
sha{,224,256,384,512}sum, sysbench, tune2fs, xmodmap, and xrdb completions.
* Add *.gif (Alioth: #312512), *.m2t (Alioth: #312770), *.3gpp, *.3gpp2,
*.awb, and *.iso (Alioth: #311420) to mplayer filename completions.
diff --git a/completions/Makefile.am b/completions/Makefile.am
index 2071564..fb42325 100644
--- a/completions/Makefile.am
+++ b/completions/Makefile.am
@@ -79,6 +79,7 @@ bashcomp_DATA = abook \
lintian \
lisp \
lrzip \
+ lsof \
lvm \
lzma \
lzop \
diff --git a/completions/lsof b/completions/lsof
new file mode 100644
index 0000000..ac010da
--- /dev/null
+++ b/completions/lsof
@@ -0,0 +1,64 @@
+# lsof(8) completion
+
+have lsof &&
+_lsof()
+{
+ COMPREPLY=()
+ local cur prev
+ _get_comp_words_by_ref cur prev
+
+ case $prev in
+ -'?'|-h|+c|-c|-d|-F|-i|+r|-r|-s|-S|-T)
+ return 0
+ ;;
+ -A|-k|-m|+m|-o)
+ _filedir
+ return 0
+ ;;
+ +d|+D)
+ _filedir -d
+ return 0
+ ;;
+ -D)
+ COMPREPLY=( $( compgen -W '? b i r u' -- "$cur" ) )
+ return 0
+ ;;
+ -f)
+ COMPREPLY=( $( compgen -W 'c f g G n' -- "$cur" ) )
+ return 0
+ ;;
+ -g)
+ # TODO: handle ^foo exclusions, comma separated lists
+ _pgids
+ return 0
+ ;;
+ -p)
+ # TODO: handle ^foo exclusions, comma separated lists
+ _pids
+ return 0
+ ;;
+ -u)
+ # TODO: handle ^foo exclusions, comma separated lists
+ COMPREPLY=( $( compgen -u -- "$cur" ) )
+ return 0
+ ;;
+ esac
+
+ if [[ "$cur" == [-+]* ]]; then
+ COMPREPLY=( $( compgen -W '-h -a -A -b -c +c -C +d -d +D -D +f -f -F -g
+ -i -k -l +L -L +m -m +M -M -n -N -o -O -p -P +r -r -R -s -S -T -t
+ -u -U -v -V +w -w -x -X -z -Z' -- "$cur" ) )
+ return 0
+ fi
+
+ _filedir
+} &&
+complete -F _lsof lsof
+
+# Local variables:
+# mode: shell-script
+# sh-basic-offset: 4
+# sh-indent-comment: t
+# indent-tabs-mode: nil
+# End:
+# ex: ts=4 sw=4 et filetype=sh
diff --git a/test/completion/lsof.exp b/test/completion/lsof.exp
new file mode 100644
index 0000000..98baab0
--- /dev/null
+++ b/test/completion/lsof.exp
@@ -0,0 +1 @@
+assert_source_completions lsof
diff --git a/test/lib/completions/kill.exp b/test/lib/completions/lsof.exp
similarity index 64%
copy from test/lib/completions/kill.exp
copy to test/lib/completions/lsof.exp
index 1e80fe6..551bde2 100644
--- a/test/lib/completions/kill.exp
+++ b/test/lib/completions/lsof.exp
@@ -11,15 +11,10 @@ proc teardown {} {
setup
-assert_complete_any "kill 1"
-
-
+assert_complete_any "lsof "
sync_after_int
-
-assert_complete [get_signals] "kill -"
-
-
+assert_complete_any "lsof -"
sync_after_int
--
bash-completion
More information about the Bash-completion-commits
mailing list