aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThomas Deutschmann <whissi@gentoo.org>2019-07-15 16:17:48 +0200
committerThomas Deutschmann <whissi@gentoo.org>2019-07-15 16:21:44 +0200
commite04895cd0c01e2b39e33dabf1b42e51bc50cc9c4 (patch)
tree55d9da8374f9b5e4f96b5205bc0a3984b09f771a
parentgen_configkernel.sh: config_kernel(): Don't check kernelruntask's return valu... (diff)
downloadgenkernel-e04895cd0c01e2b39e33dabf1b42e51bc50cc9c4.tar.gz
genkernel-e04895cd0c01e2b39e33dabf1b42e51bc50cc9c4.tar.bz2
genkernel-e04895cd0c01e2b39e33dabf1b42e51bc50cc9c4.zip
gen_funcs.sh: trap_cleanup(): Log received signal
Signed-off-by: Thomas Deutschmann <whissi@gentoo.org>
-rwxr-xr-xgen_funcs.sh21
1 files changed, 19 insertions, 2 deletions
diff --git a/gen_funcs.sh b/gen_funcs.sh
index 4136122..caae87b 100755
--- a/gen_funcs.sh
+++ b/gen_funcs.sh
@@ -1041,8 +1041,21 @@ trap_cleanup() {
exec &> /dev/tty
fi
+ local signal_msg=
+ if [ -n "${GK_TRAP_SIGNAL}" ]
+ then
+ case "${GK_TRAP_SIGNAL}" in
+ SIGABRT|SIGHUP|SIGQUIT|SIGINT|SIGTERM)
+ signal_msg=" (signal ${GK_TRAP_SIGNAL} received)"
+ ;;
+ *)
+ signal_msg=" (unknown signal ${GK_TRAP_SIGNAL} received)"
+ ;;
+ esac
+ fi
+
echo ''
- print_error 1 "Genkernel was unexpectedly terminated."
+ print_error 1 "Genkernel was unexpectedly terminated${signal_msg}."
print_error 1 "Please consult '${LOGFILE}' for more information and any"
print_error 1 "errors that were reported above."
cleanup
@@ -1236,7 +1249,11 @@ unpack() {
}
set_default_gk_trap() {
- trap trap_cleanup SIGABRT SIGHUP SIGQUIT SIGINT SIGTERM
+ local signal
+ for signal in SIGABRT SIGHUP SIGQUIT SIGINT SIGTERM
+ do
+ trap "GK_TRAP_SIGNAL=${signal}; trap_cleanup" ${signal}
+ done
}
#