[Bash-completion-commits] [SCM] bash-completion branch, master, updated. 1.90-110-g2622723

Ville Skyttä ville.skytta at iki.fi
Wed Dec 21 21:50:01 UTC 2011


The following commit has been merged in the master branch:
commit 2622723ae917e7f4adfb1357aa1d187f50657a96
Author: Ville Skyttä <ville.skytta at iki.fi>
Date:   Wed Dec 21 23:49:51 2011 +0200

    udevadm: New completion.

diff --git a/completions/Makefile.am b/completions/Makefile.am
index 43a5955..70cc7ca 100644
--- a/completions/Makefile.am
+++ b/completions/Makefile.am
@@ -299,6 +299,7 @@ bashcomp_DATA = a2x \
 		tcpnice \
 		tracepath \
 		tune2fs \
+		udevadm \
 		umount \
 		umount.linux \
 		unace \
diff --git a/completions/udevadm b/completions/udevadm
new file mode 100644
index 0000000..e8db714
--- /dev/null
+++ b/completions/udevadm
@@ -0,0 +1,76 @@
+# udevadm(8) completion                                    -*- shell-script -*-
+
+_udevadm()
+{
+    local cur prev words cword split
+    _init_completion -s || return
+
+    local i udevcmd
+    for (( i=1; i < cword; i++ )); do
+        if [[ ${words[i]} != -* ]]; then
+            udevcmd=${words[i]}
+            break
+        fi
+    done
+
+    case $prev in
+        --help|--version|--property|--children-max|--timeout|--seq-start|\
+        --seq-end|--attr-match|--attr-nomatch|--parent-match|--property-match|\
+        --tag-match|--subsystem-match|--subsystem-nomatch|--sysname-match|\
+        --path)
+            return
+            ;;
+        --log-priority)
+            COMPREPLY=( $( compgen -W 'err info debug' -- "$cur" ) )
+            return
+            ;;
+        --query)
+            COMPREPLY=( $( compgen -W 'name symlink path property all' \
+                -- "$cur" ) )
+            return
+            ;;
+        --name)
+            cur=${cur:=/dev/}
+            _filedir
+            return
+            ;;
+        --device-id-of-file|--exit-if-exists)
+            _filedir
+            return
+            ;;
+        --action)
+            COMPREPLY=( $( compgen -W 'add change remove' -- "$cur" ) )
+            return
+            ;;
+        --type)
+            COMPREPLY=( $( compgen -W 'devices subsystems failed' -- "$cur" ) )
+            return
+            ;;
+    esac
+
+    $split && return
+
+    if [[ -z $udevcmd ]]; then
+        case $cur in
+            -*)
+                COMPREPLY=( $( compgen -W '--help --version --debug' -- \
+                    "$cur" ) )
+                ;;
+            *)
+                COMPREPLY=( $( compgen -W "$( "$1" --help 2>/dev/null |
+                    awk '/^[[:space:]]+/ { print $1 }' )" -- "$cur" ) )
+                ;;
+        esac
+        return
+    fi
+
+    if [[ $cur == -* ]]; then
+        COMPREPLY=( $( compgen -W \
+            '$( "$1" $udevcmd --help 2>/dev/null | _parse_help - )' \
+            -- "$cur" ) )
+        [[ $COMPREPLY == *= ]] && compopt -o nospace
+    fi
+} &&
+complete -F _udevadm udevadm
+
+# ex: ts=4 sw=4 et filetype=sh
diff --git a/test/completion/udevadm.exp b/test/completion/udevadm.exp
new file mode 100644
index 0000000..69c980f
--- /dev/null
+++ b/test/completion/udevadm.exp
@@ -0,0 +1 @@
+assert_source_completions udevadm
diff --git a/test/lib/completions/abook.exp b/test/lib/completions/udevadm.exp
similarity index 79%
copy from test/lib/completions/abook.exp
copy to test/lib/completions/udevadm.exp
index 43f6272..bef16f0 100644
--- a/test/lib/completions/abook.exp
+++ b/test/lib/completions/udevadm.exp
@@ -11,7 +11,7 @@ proc teardown {} {
 setup
 
 
-assert_complete_any "abook "
+assert_complete_any "udevadm "
 
 
 sync_after_int

-- 
bash-completion



More information about the Bash-completion-commits mailing list