[Bash-completion-commits] [SCM] bash-completion branch, master, updated. 1.3-438-ge81223a

Igor Murzov e-mail at date.by
Sun Sep 25 23:04:02 UTC 2011


The following commit has been merged in the master branch:
commit e81223ac46c2e7692e97d469f3eefdcfb2cb9075
Author: Igor Murzov <e-mail at date.by>
Date:   Sun Sep 25 03:27:52 2011 +0400

    xgamma: New completion

diff --git a/completions/Makefile.am b/completions/Makefile.am
index 62060c5..bdb8368 100644
--- a/completions/Makefile.am
+++ b/completions/Makefile.am
@@ -188,6 +188,7 @@ bashcomp_DATA = abook \
 		wol \
 		wtf \
 		wvdial \
+		xgamma \
 		xhost \
 		xm \
 		xmllint \
diff --git a/completions/xgamma b/completions/xgamma
new file mode 100644
index 0000000..fba7cd5
--- /dev/null
+++ b/completions/xgamma
@@ -0,0 +1,65 @@
+# bash completion for xgamma(1)
+
+have xgamma || return
+
+_xgamma()
+{
+    local cur prev words cword
+    _init_completion -n : || return
+
+    case "$prev" in
+        -screen)
+            local screens=$(xrandr --query 2>/dev/null | \
+                sed -n '/^Screen /s|^Screen \{1,\}\(.*\):.*$|\1|p' 2>/dev/null)
+            COMPREPLY=( $(compgen -W "$screens" -- "$cur"))
+            return
+            ;;
+        -gamma|-rgamma|-ggamma|-bgamma)
+            # expect f.f
+            if [[ $cur && "$cur" != *.* ]]; then
+                COMPREPLY=( . )
+            fi
+            COMPREPLY+=( $(compgen -W "{0..9}") )
+            compopt -o nospace
+            return
+            ;;
+        -display)
+            # expect hostname:displaynumber.screennumber
+            if [[ "$cur" == :* && "$cur" != :*.* ]]; then
+                # FIXME: where to get local display numbers?
+                local display=${cur#:}
+                COMPREPLY=( $(compgen -W "${display:-0}.") )
+                compopt -o nospace
+            elif [[ "$cur" == :*.* ]]; then
+                # local screen numbers
+                local t screens=$(xrandr --query 2>/dev/null | sed -n \
+                    -e '/^Screen /s|^Screen \{1,\}\(.*\):.*$|\1|p' 2>/dev/null)
+                t="${cur#:}"
+                COMPREPLY=( $(compgen -P "${t%.*}." -W "$screens" -- "${cur##*.}"))
+            elif [[ "$cur" != *:* ]]; then
+                # complete hostnames
+                _known_hosts_real -c "$cur"
+                if [[ ! $cur ]]; then
+                    COMPREPLY+=( : )
+                fi
+                compopt -o nospace
+            fi
+            # no dislpay completion for remote hosts
+            return
+            ;;
+    esac
+
+    if [[ "$cur" == -* ]]; then
+        COMPREPLY=( $( compgen -W '$( _parse_help "$1" -help )' -- "$cur" ) )
+        [[ $COMPREPLY == *= ]] && compopt -o nospace
+        [[ $COMPREPLY ]] && return
+    fi
+} && complete -F _xgamma xgamma
+
+# 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/xgamma.exp b/test/completion/xgamma.exp
new file mode 100644
index 0000000..706e74f
--- /dev/null
+++ b/test/completion/xgamma.exp
@@ -0,0 +1 @@
+assert_source_completions xgamma
diff --git a/test/lib/completions/a2ps.exp b/test/lib/completions/xgamma.exp
similarity index 55%
copy from test/lib/completions/a2ps.exp
copy to test/lib/completions/xgamma.exp
index 77cd07f..c4c2228 100644
--- a/test/lib/completions/a2ps.exp
+++ b/test/lib/completions/xgamma.exp
@@ -11,7 +11,8 @@ proc teardown {} {
 setup
 
 
-assert_complete_any "a2ps "
+set test "-gam<TAB> should complete \"-gamma\""
+assert_complete "-gamma" "xgamma -gam" $test
 
 
 sync_after_int

-- 
bash-completion



More information about the Bash-completion-commits mailing list