forked from lix-project/lix
bd63ae7e18
This matches the behavior of bash. We don’t want to add a space after completion on attrs. Uses -S. Switches to new compadd style comppletions instead of _describe. Shouldn’t have any negative issues from what I can tell.
24 lines
542 B
Bash
24 lines
542 B
Bash
#compdef nix
|
|
|
|
function _nix() {
|
|
local ifs_bk="$IFS"
|
|
local input=("${(Q)words[@]}")
|
|
IFS=$'\n'
|
|
local res=($(NIX_GET_COMPLETIONS=$((CURRENT - 1)) "$input[@]" 2>/dev/null))
|
|
IFS="$ifs_bk"
|
|
local tpe="${${res[1]}%%> *}"
|
|
local -a suggestions
|
|
declare -a suggestions
|
|
for suggestion in ${res:1}; do
|
|
suggestions+=("${suggestion%% *}")
|
|
done
|
|
local -a args
|
|
if [[ "$tpe" == filenames ]]; then
|
|
args+=('-f')
|
|
elif [[ "$tpe" == attrs ]]; then
|
|
args+=('-S' '')
|
|
fi
|
|
compadd -J nix "${args[@]}" -a suggestions
|
|
}
|
|
|
|
# _nix "$@"
|