48 lines
1.6 KiB
Bash

# bash completion for gdb -*- shell-script -*-
_gdb()
{
local cur prev words cword i
_init_completion || return
# gdb [options] --args executable-file [inferior-arguments ...]
for ((i = 1; i < cword; i++)); do
if [[ ${words[i]} == --args ]]; then
_command_offset $((i + 1))
return $?
fi
done
# gdb [options] [executable-file [core-file or process-id]]
if ((cword == 1)); then
local IFS
compopt -o filenames
if [[ $cur == */* ]]; then
# compgen -c works as expected if $cur contains any slashes.
IFS=$'\n'
COMPREPLY=($(PATH="$PATH:." compgen -d -c -- "$cur"))
else
# otherwise compgen -c contains Bash's built-in commands,
# functions and aliases. Thus we need to retrieve the program
# names manually.
IFS=":"
local path_array=($(
command sed -e 's/:\{2,\}/:/g' -e 's/^://' -e 's/:$//' <<<"$PATH"
))
IFS=$'\n'
COMPREPLY=($(compgen -d -W '$(find "${path_array[@]}" . \
-mindepth 1 -maxdepth 1 -not -type d -executable \
-printf "%f\\n" 2>/dev/null)' -- "$cur"))
fi
elif ((cword == 2)); then
COMPREPLY=($(compgen -W "$(command ps axo comm,pid |
awk '{if ($1 ~ /^'"${prev##*/}"'/) print $2}')" -- "$cur"))
compopt -o filenames
COMPREPLY+=($(compgen -f -X '!?(*/)core?(.?*)' -o plusdirs \
-- "$cur"))
fi
} &&
complete -F _gdb gdb
# ex: filetype=sh