2011-07-29 04:41:39 +08:00
|
|
|
# Checks if a file can be autoloaded by trying to load it in a subshell.
|
|
|
|
function autoloadable() {
|
|
|
|
( unfunction $1 ; autoload -U +X $1 ) &> /dev/null
|
|
|
|
}
|
|
|
|
|
|
|
|
# Checks boolean variable for "true" (case insensitive "1", "y", "yes", "t", "true", "o", and "on").
|
2012-01-21 11:03:17 +08:00
|
|
|
function is-true() {
|
2011-07-29 04:41:39 +08:00
|
|
|
[[ -n "$1" && "$1" == (1|[Yy]([Ee][Ss]|)|[Tt]([Rr][Uu][Ee]|)|[Oo]([Nn]|)) ]]
|
|
|
|
}
|
|
|
|
|
|
|
|
# Trap signals were generated with 'kill -l'.
|
2011-10-12 11:13:58 +08:00
|
|
|
# DEBUG, EXIT, and ZERR are Zsh signals.
|
2011-07-29 04:41:39 +08:00
|
|
|
TRAP_SIGNALS=(
|
|
|
|
ABRT ALRM BUS CHLD CONT EMT FPE HUP ILL INFO INT IO KILL PIPE PROF QUIT
|
|
|
|
SEGV STOP SYS TERM TRAP TSTP TTIN TTOU URG USR1 USR2 VTALRM WINCH XCPU XFSZ
|
|
|
|
DEBUG EXIT ZERR
|
|
|
|
)
|
|
|
|
|
|
|
|
# Adds a function to a list to be called when a trap is triggered.
|
2011-12-29 06:32:20 +08:00
|
|
|
function add-zsh-trap() {
|
2011-07-29 04:41:39 +08:00
|
|
|
if (( $# < 2 )); then
|
2012-01-25 12:40:32 +08:00
|
|
|
print "usage: $0 type function" >&2
|
2011-07-29 04:41:39 +08:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [[ -z "$TRAP_SIGNALS[(r)$1]" ]]; then
|
2012-01-25 12:40:32 +08:00
|
|
|
print "$0: unknown signal: $1" >&2
|
2011-07-29 04:41:39 +08:00
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
local trap_functions="TRAP${1}_FUNCTIONS"
|
|
|
|
if (( ! ${(P)+trap_functions} )); then
|
|
|
|
typeset -gaU "$trap_functions"
|
|
|
|
fi
|
|
|
|
eval "$trap_functions+="$2""
|
|
|
|
|
|
|
|
if (( ! $+functions[TRAP${1}] )); then
|
|
|
|
eval "
|
|
|
|
function TRAP${1}() {
|
|
|
|
for trap_function in \"\$TRAP${1}_FUNCTIONS[@]\"; do
|
|
|
|
if (( \$+functions[\$trap_function] )); then
|
|
|
|
\"\$trap_function\" \"\$1\"
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
return \$(( 128 + \$1 ))
|
|
|
|
}
|
|
|
|
"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|