[Bash-completion-commits] [SCM] bash-completion branch, master, updated. d15c096f0b5e4711e50b6aeb4692494c5d4cfacc

Ville Skyttä ville.skytta at iki.fi
Mon Dec 28 21:45:39 UTC 2009


The following commit has been merged in the master branch:
commit d15c096f0b5e4711e50b6aeb4692494c5d4cfacc
Author: Ville Skyttä <ville.skytta at iki.fi>
Date:   Mon Dec 28 23:30:32 2009 +0200

    Add cvsps completion.

diff --git a/CHANGES b/CHANGES
index bdaf8da..3634f81 100644
--- a/CHANGES
+++ b/CHANGES
@@ -29,8 +29,8 @@ bash-completion (2.x)
     mysqladmin, rsync, screen, service, scp, ssh, sshfs, update-alternatives,
     vncviewer, and general hostname completions.
   * Add abook and wtf completion, based on work by Raphaël Droz.
-  * Add fusermount, jarsigner, k3b, lftpget, pm-utils, pack200 and unpack200
-    completions.
+  * Add cvsps, fusermount, jarsigner, k3b, lftpget, pm-utils, pack200 and
+    unpack200 completions.
   * Don't overwrite other host completions when completing from multiple
     SSH known hosts files.
   * Speed up installed rpm package completion on SUSE, based on work by
diff --git a/Makefile.am b/Makefile.am
index 95cd96c..fc38afd 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -30,6 +30,7 @@ bashcomp_DATA = contrib/abook \
 		contrib/cpio \
 		contrib/cups \
 		contrib/cvs \
+		contrib/cvsps \
 		contrib/dd \
 		contrib/dhclient \
 		contrib/dict \
diff --git a/contrib/cvsps b/contrib/cvsps
new file mode 100644
index 0000000..d629574
--- /dev/null
+++ b/contrib/cvsps
@@ -0,0 +1,69 @@
+# bash completion for cvsps
+
+have cvsps &&
+_cvsps()
+{
+    COMPREPLY=()
+    local cur=`_get_cword :` prev=`_get_pword :`
+
+    case "$prev" in
+        -h|-z|-f|-d|-l|--diff-opts|--debuglvl)
+            return 0
+            ;;
+        -s)
+            COMPREPLY=( $( compgen -W "$( cvsps 2>/dev/null |
+                awk '/^PatchSet:?[[:space:]]/ { print $2 }' )" -- "$cur" ) )
+            return 0
+            ;;
+        -a)
+            COMPREPLY=( $( compgen -W "$( cvsps 2>/dev/null |
+                awk '/^Author:[[:space:]]/ { print $2 }' )" -- "$cur" ) )
+            return 0
+            ;;
+        -b)
+            COMPREPLY=( $( compgen -W "$( cvsps 2>/dev/null |
+                awk '/^Branch:[[:space:]]/ { print $2 }' )" -- "$cur" ) )
+            return 0
+            ;;
+        -r)
+            COMPREPLY=( $( compgen -W "$( cvsps 2>/dev/null |
+                awk '/^Tag:[[:space:]]+[^(]/ { print $2 }' )" \
+                    -- "$cur" ) )
+            return 0
+            ;;
+        -p)
+            _filedir -d
+            return 0
+            ;;
+        --test-log)
+            _filedir
+            return 0
+            ;;
+        -Z)
+            COMPREPLY=( $( compgen -W '1 2 3 4 5 6 7 8 9' -- "$cur" ) )
+            return 0
+            ;;
+        --root)
+            type _cvs_roots &>/dev/null && _cvs_roots
+            return 0
+            ;;
+    esac
+
+    if [[ "$cur" == -* ]] ; then
+        COMPREPLY=( $( compgen -W '-h -x -u -z -g -s -a -f -d -b -l -r -p -v \
+            -t --norc --summary-first --test-log --diff-opts --bkcvs --no-rlog \
+            --cvs-direct --no-cvs-direct --debuglvl -Z --root -q -A' \
+            -- "$cur" ) )
+    else
+        type _cvs_roots &>/dev/null && _cvs_roots
+    fi
+} &&
+complete -F _cvsps cvsps
+
+# 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/cvsps.exp b/test/completion/cvsps.exp
new file mode 100644
index 0000000..771d584
--- /dev/null
+++ b/test/completion/cvsps.exp
@@ -0,0 +1,3 @@
+if {[assert_bash_type cvsps]} {
+    source "lib/completions/cvsps.exp"
+}; # if
diff --git a/test/lib/completions/abook.exp b/test/lib/completions/cvsps.exp
similarity index 83%
copy from test/lib/completions/abook.exp
copy to test/lib/completions/cvsps.exp
index 3f4e301..add74c0 100644
--- a/test/lib/completions/abook.exp
+++ b/test/lib/completions/cvsps.exp
@@ -11,7 +11,7 @@ proc teardown {} {
 setup
 
 
-assert_complete_any "abook "
+assert_complete_any "cvsps "
 
 
 sync_after_int

-- 
bash-completion



More information about the Bash-completion-commits mailing list