From 20da58084a68b118b15fa01228192463b61fa28f Mon Sep 17 00:00:00 2001 From: Karel Zak Date: Fri, 5 Apr 2013 14:58:07 +0200 Subject: bash-completion: rename shell-completion -> bash-completion Signed-off-by: Karel Zak --- bash-completion/taskset | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 bash-completion/taskset (limited to 'bash-completion/taskset') diff --git a/bash-completion/taskset b/bash-completion/taskset new file mode 100644 index 000000000..5311316a2 --- /dev/null +++ b/bash-completion/taskset @@ -0,0 +1,38 @@ +_taskset_module() +{ + local cur prev OPTS + COMPREPLY=() + cur="${COMP_WORDS[COMP_CWORD]}" + prev="${COMP_WORDS[COMP_CWORD-1]}" + case $prev in + '-c'|'--cpu-list') + local CPULIST + # FIXME: will propose only binding to a cpu. + # Maybe this should add comma, and continue? + CPULIST=$(sed 's/^/{/; s/-/../g; s/,/} {/g; s/$/}/' /sys/devices/system/cpu/online) + COMPREPLY=( $(compgen -W "$(eval echo $CPULIST)" -- $cur) ) + return 0 + ;; + '-p'|'--pid') + local PIDS + # FIXME: the pid argument is ambiguous. When + # setting an affinity the optarg has to be cpu + # mask. The following is good only for getting + # affinity. + PIDS=$(for I in /proc/[0-9]*; do echo ${I##"/proc/"}; done) + COMPREPLY=( $(compgen -W "$PIDS" -- $cur) ) + return 0 + ;; + esac + case $cur in + -*) + OPTS="-a --all-tasks -p --pid -c --cpu-list -h --help -V --version" + COMPREPLY=( $(compgen -W "${OPTS[*]}" -- $cur) ) + return 0 + ;; + esac + compopt -o bashdefault + COMPREPLY=( $(compgen -c -- $cur) ) + return 0 +} +complete -F _taskset_module taskset -- cgit v1.2.3-55-g7522