[Bash-completion-commits] [SCM] bash-completion branch, master, updated. 1.90-63-geab195c

Ville Skyttä ville.skytta at iki.fi
Fri Nov 25 06:46:17 UTC 2011


The following commit has been merged in the master branch:
commit eab195c440c283adf1cbe5f06d045256372e505e
Author: Ville Skyttä <ville.skytta at iki.fi>
Date:   Thu Nov 24 23:29:39 2011 +0200

    iperf: New completion.

diff --git a/completions/Makefile.am b/completions/Makefile.am
index 8ded90d..892523b 100644
--- a/completions/Makefile.am
+++ b/completions/Makefile.am
@@ -126,6 +126,7 @@ bashcomp_DATA = a2x \
 		invoke-rc.d \
 		ionice \
 		ip \
+		iperf \
 		iptables \
 		ipmitool \
 		ipsec \
diff --git a/completions/iperf b/completions/iperf
new file mode 100644
index 0000000..721825e
--- /dev/null
+++ b/completions/iperf
@@ -0,0 +1,63 @@
+# iperf(1) completion                                      -*- shell-script -*-
+
+_iperf()
+{
+    local cur prev words cword split
+    _init_completion -s || return
+
+    case $prev in
+        -h|--help|-v|--version|-i|--interval|-l|--len|-p|--port|-w|--window|\
+        -M|--mss|-b|--bandwidth|-n|--num|-t|--time|-L|--listenport|-P|\
+        --parallel|-T|--ttl|-Z|--linux-congestion)
+            return
+            ;;
+        -f|--format)
+            COMPREPLY=( $( compgen -W 'k m K M' -- "$cur" ) )
+            return
+            ;;
+        -o|--output|-F|--fileinput)
+            _filedir
+            return
+            ;;
+        -B|--bind)
+            _available_interfaces -a
+            _ip_addresses
+            return
+            ;;
+        -c|--client)
+            _known_hosts_real "$cur"
+            return
+            ;;
+        -x|--reportexclude)
+            COMPREPLY=( $( compgen -W 'C D M S V' -- "$cur" ) )
+            return
+            ;;
+        -y|--reportstyle)
+            COMPREPLY=( $( compgen -W 'C' -- "$cur" ) )
+            return
+            ;;
+    esac
+
+    $split && return
+
+    # Filter mode specific options
+    local i filter=cat
+    for i in ${words[@]}; do
+        case $i in
+            -s|--server)
+                filter='sed -e /^Client.specific/,/^$/d'
+                ;;
+            -c|--client)
+                filter='sed -e /^Server.specific/,/^$/d'
+                ;;
+        esac
+    done
+    [[ $filter != cat ]] && filter+=' -e /--client/d -e /--server/d'
+
+    COMPREPLY=( $( compgen -W \
+        '$( "$1" --help 2>&1 | $filter | _parse_help - )' -- "$cur" ) )
+    [[ $COMPREPLY == *= ]] && compopt -o nospace
+} &&
+complete -F _iperf iperf
+
+# ex: ts=4 sw=4 et filetype=sh
diff --git a/test/completion/iperf.exp b/test/completion/iperf.exp
new file mode 100644
index 0000000..f5f19ef
--- /dev/null
+++ b/test/completion/iperf.exp
@@ -0,0 +1 @@
+assert_source_completions iperf
diff --git a/test/lib/completions/abook.exp b/test/lib/completions/iperf.exp
similarity index 80%
copy from test/lib/completions/abook.exp
copy to test/lib/completions/iperf.exp
index 43f6272..66a0ba3 100644
--- a/test/lib/completions/abook.exp
+++ b/test/lib/completions/iperf.exp
@@ -11,7 +11,7 @@ proc teardown {} {
 setup
 
 
-assert_complete_any "abook "
+assert_complete_any "iperf "
 
 
 sync_after_int

-- 
bash-completion



More information about the Bash-completion-commits mailing list