blob: b0e44ca0bef48099ad97ca32f948ea43c0ee6624 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
# Completion function for sd; any sibling directories, excluding the self
_sd() {
# Only makes sense for the first argument
((COMP_CWORD == 1)) || return 1
# Current directory can't be root directory
[[ $PWD != / ]] || return 1
# Build list of matching sibling directories
local dirname
while IFS= read -rd '' dirname ; do
[[ -n $dirname ]] || continue
COMPREPLY[${#COMPREPLY[@]}]=$dirname
done < <(
# Set options to glob correctly
shopt -s dotglob nullglob
# Make globbing case-insensitive if appropriate; is there a cleaner way
# to find this value?
while read -r _ option value ; do
case $option in
completion-ignore-case)
case $value in
on)
shopt -s nocaseglob
break
;;
esac
;;
esac
done < <(bind -v)
# Collect directory names, strip leading ../ and trailing /
local -a dirnames
dirnames=(../"${COMP_WORDS[COMP_CWORD]}"*/)
dirnames=("${dirnames[@]#../}")
dirnames=("${dirnames[@]%/}")
# Iterate again, but exclude the current directory this time
local -a sibs
local dirname
for dirname in "${dirnames[@]}" ; do
[[ $dirname != "${PWD##*/}" ]] || continue
sibs[${#sibs[@]}]=$dirname
done
# Print quoted sibs, null-delimited, if there was at least one;
# otherwise, just print a null character to stop this hanging in Bash
# 4.4
if ((${#sibs[@]})) ; then
printf '%q\0' "${sibs[@]}"
else
printf '\0'
fi
)
}
complete -F _sd sd
|