mirror of
https://github.com/torvalds/linux.git
synced 2024-12-26 12:52:30 +00:00
a1d668c3ff
The '_get_comp_words_by_ref' function is available from the bash completion v1.2 so that earlier version emits following warning: $ perf re<TAB>_get_comp_words_by_ref: command not found Use older '_get_cword' method when the above function doesn't exist. Signed-off-by: Namhyung Kim <namhyung@kernel.org> Acked-by: Frederic Weisbecker <fweisbec@gmail.com> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Peter Zijlstra <peterz@infradead.org> Link: http://lkml.kernel.org/r/1349191294-6926-2-git-send-email-namhyung@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
38 lines
723 B
Bash
38 lines
723 B
Bash
# perf completion
|
|
|
|
function_exists()
|
|
{
|
|
declare -F $1 > /dev/null
|
|
return $?
|
|
}
|
|
|
|
have perf &&
|
|
_perf()
|
|
{
|
|
local cur prev cmd
|
|
|
|
COMPREPLY=()
|
|
if function_exists _get_comp_words_by_ref; then
|
|
_get_comp_words_by_ref cur prev
|
|
else
|
|
cur=$(_get_cword)
|
|
prev=${COMP_WORDS[COMP_CWORD-1]}
|
|
fi
|
|
|
|
cmd=${COMP_WORDS[0]}
|
|
|
|
# List perf subcommands
|
|
if [ $COMP_CWORD -eq 1 ]; then
|
|
cmds=$($cmd --list-cmds)
|
|
COMPREPLY=( $( compgen -W '$cmds' -- "$cur" ) )
|
|
# List possible events for -e option
|
|
elif [[ $prev == "-e" && "${COMP_WORDS[1]}" == @(record|stat|top) ]]; then
|
|
cmds=$($cmd list --raw-dump)
|
|
COMPREPLY=( $( compgen -W '$cmds' -- "$cur" ) )
|
|
# Fall down to list regular files
|
|
else
|
|
_filedir
|
|
fi
|
|
} &&
|
|
complete -F _perf perf
|