[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