Rev 36 | Blame | Compare with Previous | Last modification | View Log | RSS feed
# perf bash and zsh completion# Taken from git.git's completion script.__my_reassemble_comp_words_by_ref(){local exclude i j first# Which word separators to exclude?exclude="${1//[^$COMP_WORDBREAKS]}"cword_=$COMP_CWORDif [ -z "$exclude" ]; thenwords_=("${COMP_WORDS[@]}")returnfi# List of word completion separators has shrunk;# re-assemble words to complete.for ((i=0, j=0; i < ${#COMP_WORDS[@]}; i++, j++)); do# Append each nonempty word consisting of just# word separator characters to the current word.first=twhile[ $i -gt 0 ] &&[ -n "${COMP_WORDS[$i]}" ] &&# word consists of excluded word separators[ "${COMP_WORDS[$i]//[^$exclude]}" = "${COMP_WORDS[$i]}" ]do# Attach to the previous token,# unless the previous token is the command name.if [ $j -ge 2 ] && [ -n "$first" ]; then((j--))fifirst=words_[$j]=${words_[j]}${COMP_WORDS[i]}if [ $i = $COMP_CWORD ]; thencword_=$jfiif (($i < ${#COMP_WORDS[@]} - 1)); then((i++))else# Done.returnfidonewords_[$j]=${words_[j]}${COMP_WORDS[i]}if [ $i = $COMP_CWORD ]; thencword_=$jfidone}# Define preload_get_comp_words_by_ref="false", if the function# __perf_get_comp_words_by_ref() is required instead.preload_get_comp_words_by_ref="true"if [ $preload_get_comp_words_by_ref = "true" ]; thentype _get_comp_words_by_ref &>/dev/null ||preload_get_comp_words_by_ref="false"fi[ $preload_get_comp_words_by_ref = "true" ] ||__perf_get_comp_words_by_ref(){local exclude cur_ words_ cword_if [ "$1" = "-n" ]; thenexclude=$2shift 2fi__my_reassemble_comp_words_by_ref "$exclude"cur_=${words_[cword_]}while [ $# -gt 0 ]; docase "$1" incur)cur=$cur_;;prev)prev=${words_[$cword_-1]};;words)words=("${words_[@]}");;cword)cword=$cword_;;esacshiftdone}# Define preload__ltrim_colon_completions="false", if the function# __perf__ltrim_colon_completions() is required instead.preload__ltrim_colon_completions="true"if [ $preload__ltrim_colon_completions = "true" ]; thentype __ltrim_colon_completions &>/dev/null ||preload__ltrim_colon_completions="false"fi[ $preload__ltrim_colon_completions = "true" ] ||__perf__ltrim_colon_completions(){if [[ "$1" == *:* && "$COMP_WORDBREAKS" == *:* ]]; then# Remove colon-word prefix from COMPREPLY itemslocal colon_word=${1%"${1##*:}"}local i=${#COMPREPLY[*]}while [[ $((--i)) -ge 0 ]]; doCOMPREPLY[$i]=${COMPREPLY[$i]#"$colon_word"}donefi}__perfcomp (){COMPREPLY=( $( compgen -W "$1" -- "$2" ) )}__perfcomp_colon (){__perfcomp "$1" "$2"if [ $preload__ltrim_colon_completions = "true" ]; then__ltrim_colon_completions $curelse__perf__ltrim_colon_completions $curfi}__perf_prev_skip_opts (){local i cmd_ cmds_let i=cword-1cmds_=$($cmd $1 --list-cmds)prev_skip_opts=()while [ $i -ge 0 ]; doif [[ ${words[i]} == $1 ]]; thenreturnfifor cmd_ in $cmds_; doif [[ ${words[i]} == $cmd_ ]]; thenprev_skip_opts=${words[i]}returnfidone((i--))done}__perf_main (){local cmdcmd=${words[0]}COMPREPLY=()# Skip options backward and find the last perf command__perf_prev_skip_opts# List perf subcommands or long optionsif [ -z $prev_skip_opts ]; thenif [[ $cur == --* ]]; thencmds=$($cmd --list-opts)elsecmds=$($cmd --list-cmds)fi__perfcomp "$cmds" "$cur"# List possible events for -e optionelif [[ $prev == @("-e"|"--event") &&$prev_skip_opts == @(record|stat|top) ]]; thenevts=$($cmd list --raw-dump)__perfcomp_colon "$evts" "$cur"else# List subcommands for perf commandsif [[ $prev_skip_opts == @(kvm|kmem|mem|lock|sched||data|help|script|test|timechart|trace) ]]; thensubcmds=$($cmd $prev_skip_opts --list-cmds)__perfcomp_colon "$subcmds" "$cur"fi# List long option namesif [[ $cur == --* ]]; thensubcmd=$prev_skip_opts__perf_prev_skip_opts $subcmdsubcmd=$subcmd" "$prev_skip_optsopts=$($cmd $subcmd --list-opts)__perfcomp "$opts" "$cur"fifi}if [[ -n ${ZSH_VERSION-} ]]; thenautoload -U +X compinit && compinit__perfcomp (){emulate -L zshlocal c IFS=$' \t\n'local -a arrayfor c in ${=1}; docase $c in--*=*|*.) ;;*) c="$c " ;;esacarray[${#array[@]}+1]="$c"donecompset -P '*[=:]'compadd -Q -S '' -a -- array && _ret=0}__perfcomp_colon (){emulate -L zshlocal cur_="${2-$cur}"local c IFS=$' \t\n'local -a arrayif [[ "$cur_" == *:* ]]; thenlocal colon_word=${cur_%"${cur_##*:}"}fifor c in ${=1}; docase $c in--*=*|*.) ;;*) c="$c " ;;esacarray[$#array+1]=${c#"$colon_word"}donecompset -P '*[=:]'compadd -Q -S '' -a -- array && _ret=0}_perf (){local _ret=1 cur cword prevcur=${words[CURRENT]}prev=${words[CURRENT-1]}let cword=CURRENT-1emulate ksh -c __perf_mainlet _ret && _default && _ret=0return _ret}compdef _perf perfreturnfitype perf &>/dev/null &&_perf(){local cur words cword previf [ $preload_get_comp_words_by_ref = "true" ]; then_get_comp_words_by_ref -n =: cur words cword prevelse__perf_get_comp_words_by_ref -n =: cur words cword prevfi__perf_main} &&complete -o bashdefault -o default -o nospace -F _perf perf 2>/dev/null \|| complete -o default -o nospace -F _perf perf