[Bash-completion-commits] [SCM] bash-completion branch, master, updated. 1.90-50-g834379e

Ville Skyttä ville.skytta at iki.fi
Thu Nov 17 16:00:50 UTC 2011


The following commit has been merged in the master branch:
commit 834379ef6381c83a51d9277617d49bc3d3b10c7c
Author: Ville Skyttä <ville.skytta at iki.fi>
Date:   Thu Nov 17 18:00:41 2011 +0200

    valgrind: New completion.

diff --git a/completions/Makefile.am b/completions/Makefile.am
index c6ff1ec..e2137ed 100644
--- a/completions/Makefile.am
+++ b/completions/Makefile.am
@@ -300,6 +300,7 @@ bashcomp_DATA = a2x \
 		useradd \
 		userdel \
 		usermod \
+		valgrind \
 		vipw \
 		vncviewer \
 		vpnc \
diff --git a/completions/valgrind b/completions/valgrind
new file mode 100644
index 0000000..bd1391b
--- /dev/null
+++ b/completions/valgrind
@@ -0,0 +1,182 @@
+# valgrind(1) completion                                   -*- shell-script -*-
+
+_valgrind()
+{
+    local cur prev words cword split
+    _init_completion -s || return
+
+    local i
+    # Note: intentionally using COMP_WORDS and COMP_CWORD instead of
+    # words and cword here due to splitting on = causing index differences
+    # (_command_offset assumes the former).
+    for (( i=1; i <= COMP_CWORD; i++ )); do
+        if [[ ${COMP_WORDS[i]} != @([-=])* && ${COMP_WORDS[i-1]} != = ]]; then
+            _command_offset $i
+            return
+        fi
+    done
+
+    case $prev in
+        -h|--help|--help-debug|--version|--log-fd|--log-socket|--xml-fd|\
+        --xml-socket|--xml-user-comment|--num-callers|--error-exitcode|\
+        --db-command|--input-fd|--max-strackframe|--main-stacksize|\
+        --alignment)
+            return
+            ;;
+        --tool)
+            # Tools seem to be named e.g. like memcheck-amd64-linux from which
+            # we want to grab memcheck; the same dir may contain things like
+            # default.supp, vgpreload_*.so etc which we want to skip.
+            # TODO: probably needs adjustment to be more generic
+            COMPREPLY=( $( compgen -W "$( \
+                command ls -1 /usr{,/local}/lib{,64}/valgrind 2>/dev/null | \
+                sed -e '/\.so$/d' -ne 's/^\(.*\)-\([^-]*\)-\([^-]*\)/\1/p' )" \
+                -- "$cur" ) )
+            return
+            ;;
+        --trace-children|--child-silent-after-fork|--track-fds|--time-stamp|\
+        --xml|--demangle|--error-limit|--show-below-main|--dsymutil|\
+        --read-var-info|--run-libc-freeres|--show-emwarns)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        --log-file|--xml-file|--suppressions|--db-attach)
+            _filedir
+            return
+            ;;
+        --gen-suppressions)
+            COMPREPLY=( $( compgen -W 'yes no all' -- "$cur" ) )
+            return
+            ;;
+        --smc-check)
+            COMPREPLY=( $( compgen -W 'none stack all' -- "$cur" ) )
+            return
+            ;;
+        --sim-hints)
+            COMPREPLY=( $( compgen -W 'lax-ioctls enable-outer' -- "$cur" ) )
+            return
+            ;;
+        --kernel-variant)
+            COMPREPLY=( $( compgen -W 'bproc' -- "$cur" ) )
+            return
+            ;;
+        # memcheck:
+        --leak-check)
+            COMPREPLY=( $( compgen -W 'no summary full' -- "$cur" ) )
+            return
+            ;;
+        --leak-resolution)
+            COMPREPLY=( $( compgen -W 'low med high' -- "$cur" ) )
+            return
+            ;;
+        --show-reachable|--undef-value-errors|--track-origins|\
+        --partial-loads-ok|--workaround-gcc296-bugs)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        --freelist-vol|--ignore-ranges|--malloc-fill|--free-fill)
+            return
+            ;;
+        # cachegrind:
+        --I1|--D1|--L2)
+            return
+            ;;
+        --cache-sim|--branch-sim)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        --cachegrind-out-file)
+            _filedir
+            return
+            ;;
+        # callgrind (also --I1, --D1, and --L2 which are above in cachegrind):
+        --simulate-cache|--simulate-wb|--simulate-hwpref|--cacheuse)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        # drd:
+        --trace-addr)
+            return
+            ;;
+        --trace-barrier|--trace-cond|--trace-fork-join|--trace-mutex|\
+        --trace-rwlock|--trace-semaphore)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        # exp-bbv:
+        --bb-out-file|--pc-out-file)
+            _filedir
+            return
+            ;;
+        --interval-size)
+            return
+            ;;
+        --instr-count-only)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        # exp-ptrcheck (also --partial-loads-ok which is above in memcheck):
+        --enable-sg-checks)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        # helgrind:
+        --track-lockorders)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        --history-level)
+            COMPREPLY=( $( compgen -W 'none approx full' -- "$cur" ) )
+            return
+            ;;
+        --conflict-cache-size)
+            return
+            ;;
+        # lackey:
+        --basic-counts|--detailed-counts|--trace-mem|--trace-superblock)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        --fnname)
+            return
+            ;;
+        # massif:
+        --heap|--stacks)
+            COMPREPLY=( $( compgen -W 'yes no' -- "$cur" ) )
+            return
+            ;;
+        --heap-admin|--depth|--alloc-fn|--ignore-fn|--threshold|\
+        --peak-inaccuracy|--detailed-freq|--max-snapshots)
+            return
+            ;;
+        --time-unit)
+            COMPREPLY=( $( compgen -W 'i ms B' -- "$cur" ) )
+            return
+            ;;
+        --massif-out-file)
+            _filedir
+            return
+            ;;
+    esac
+
+    $split && return
+
+    if [[ $cur == -* ]]; then
+
+        local tool
+        for (( i=1; i < ${#words[@]}; i++ )); do
+            if [[ ${words[i]} == --tool=?* ]]; then
+                tool=${words[i]}
+                break
+            fi
+        done
+
+        COMPREPLY=( $( compgen -W '$( _parse_help "$1" "--help $tool" )' \
+            -- "$cur" ) )
+        [[ $COMPREPLY == *= ]] && compopt -o nospace
+        return
+    fi
+} &&
+complete -F _valgrind valgrind
+
+# ex: ts=4 sw=4 et filetype=sh
diff --git a/test/completion/valgrind.exp b/test/completion/valgrind.exp
new file mode 100644
index 0000000..aadd5a5
--- /dev/null
+++ b/test/completion/valgrind.exp
@@ -0,0 +1 @@
+assert_source_completions valgrind
diff --git a/test/lib/completions/valgrind.exp b/test/lib/completions/valgrind.exp
new file mode 100644
index 0000000..3e7799e
--- /dev/null
+++ b/test/lib/completions/valgrind.exp
@@ -0,0 +1,25 @@
+proc setup {} {
+    save_env
+}
+
+
+proc teardown {} {
+    assert_env_unmodified
+}
+
+
+setup
+
+
+# b: assuming we have at least bash that starts with b in $PATH
+assert_complete_any "valgrind b"
+sync_after_int
+
+assert_complete_any "valgrind -"
+sync_after_int
+
+assert_complete_any "valgrind --tool="
+sync_after_int
+
+
+teardown

-- 
bash-completion



More information about the Bash-completion-commits mailing list