This repository has been archived by the owner on Jun 20, 2020. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathutils.kak
53 lines (45 loc) · 1.75 KB
/
utils.kak
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
##
## utils.kak by lenormf
##
define-command -params 4.. -file-completion \
-docstring %{find-parent-file <filename> <scope:name> <depth> <dirs>: assign to a given variable the full path of a file, looked for upwards from a given path
The dirs parameter is a list of one or more directories which the function will traverse in order} \
find-parent-file %{ evaluate-commands %sh{
filename="$1"
variable="${2#*:}"
variable_scope="${2%%:*}"
maxdepth="$3"
shift 3
function fatal {
printf %s\\n "echo -color Error %{$@}"
exit 1
}
## FIXME: backup the old value in the variable, and restore it after looking up the file
printf %s\\n "set '${variable_scope}' '${variable}' ''"
if [ -z "${filename}" ]; then
fatal "first argument: filename needed"
elif [ -z "${variable}" ] || ! echo "window buffer global current" | grep -qiw "${variable_scope}"; then
fatal "second argument: syntax expected: \"scope:name\""
elif ! [[ $maxdepth =~ [0-9]+ ]]; then
fatal "third argument: maximum depth of recursion needed"
fi
for basedir in "$@"; do
if [ ! -d "${basedir}" ]; then
fatal "no such directory: \"${basedir}\""
fi
n_depth=0
while true; do
n_depth=$((n_depth + 1))
current_path=$(readlink -e "${basedir}/${filename}")
if [ -f "${basedir}/${filename}" ]; then
printf %s\\n "set '${variable_scope}' '${variable}' '${current_path}'"
exit
elif [ "${basedir}" = / ]; then
break
elif [ "${n_depth}" -ge "${maxdepth}" ] && [ "${maxdepth}" -gt 0 ]; then
break
fi
basedir="${basedir}/.."
done
done
} }