From 18b0017ae6a80f2eb4e7e1bdf81264b7f4d457f6 Mon Sep 17 00:00:00 2001 From: Sami Kerola Date: Sun, 24 Mar 2013 17:10:55 +0000 Subject: bash-completion: schedutils Signed-off-by: Sami Kerola --- shell-completion/taskset | 38 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 shell-completion/taskset (limited to 'shell-completion/taskset') diff --git a/shell-completion/taskset b/shell-completion/taskset new file mode 100644 index 000000000..5311316a2 --- /dev/null +++ b/shell-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