blob: 4763f71c8040d2f9ab6eeeca4f401acd8ed90d90 (
plain)
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
60
61
62
63
64
65
66
67
68
69
70
|
### --- Auto-completes aliases --- ###
# alias - normal aliases (completed with trailing space)
# balias - blank aliases (completed without space)
# ialias - ignored aliases (not completed)
# ignored aliases
typeset -a ialiases
ialiases=()
ialias() {
alias $@
args="$@"
args=${args%%\=*}
ialiases+=(${args##* })
}
# blank aliases
typeset -a baliases
baliases=()
balias() {
alias $@
args="$@"
args=${args%%\=*}
baliases+=(${args##* })
}
# functionality
expand-alias-space() {
[[ $LBUFFER =~ "\<(${(j:|:)baliases})\$" ]] && insertBlank=$?
if [[ ! $LBUFFER =~ "\<(${(j:|:)ialiases})\$" ]]; then
zle _expand_alias
zle expand-word
fi
zle self-insert
if [[ "$insertBlank" -eq 0 ]]; then
zle backward-delete-char
fi
}
zle -N expand-alias-space
# starts multiple args as programs in background
background() {
for ((i=2;i<=$#;i++)); do
${@[1]} ${@[$i]} &> /dev/null &
done
}
# A function for expanding any aliases before accepting the line as is and executing the entered command
expand-alias-and-accept-line() {
expand-alias-space
# zle .backward-delete-char
zle .accept-line
}
# zle -N accept-line expand-alias-and-accept-line
bindkey '^ ' expand-alias-space # ctrl-space to bypass completion
bindkey ' ' magic-space
bindkey -M isearch ' ' magic-space
# file completion patterns
zstyle ':completion:*:*:nvim:*' file-patterns '^*.(pdf|odt|ods|doc|docx|xls|xlsx|odp|ppt|pptx|mp4|mkv|aux):source-files' '*:all-files'
zstyle ':completion:*:*:(build-workshop|build-document):*' file-patterns '*.mom'
|