aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohannes Stezenbach <js@sig21.net>2012-10-30 00:22:25 +0000
committerJohannes Stezenbach <js@sig21.net>2012-10-30 00:22:25 +0000
commit5ddbc863e1731a96abb8cc8d255aaac65d7885c5 (patch)
tree082052a5471ed3a768f87827047835a232f2bd5f
parent34a6501a2e79ef7a740171fddf6ccae916a12b1d (diff)
downloadcrosstool-ng-5ddbc863e1731a96abb8cc8d255aaac65d7885c5.tar.gz
crosstool-ng-5ddbc863e1731a96abb8cc8d255aaac65d7885c5.tar.bz2
crosstool-ng-5ddbc863e1731a96abb8cc8d255aaac65d7885c5.zip
scripts/functions: fix endless loop in debug-shell with IO redirection
CT_DEBUG_INTERACTIVE is disabled when stdin, stdout or stderr are redirected, but the check is only done at the start of the build and doesn't catch when individual build commands use redirection. When stdin is redirected it will cause the debug shell to exit immediately, causing and endless loop. Thus, save the stdin/our/err file handles and restore them before invoking the debug shell. Signed-off-by: Johannes Stezenbach <js@sig21.net> Message-Id: <20121030102225.GA8303@sig21.net> Patchwork-Id: 195409
-rw-r--r--scripts/functions5
1 files changed, 3 insertions, 2 deletions
diff --git a/scripts/functions b/scripts/functions
index 028af3f7..c47aadbf 100644
--- a/scripts/functions
+++ b/scripts/functions
@@ -46,7 +46,7 @@ CT_OnError() {
old_trap="$(trap -p ERR)"
trap -- ERR
(
- exec >&6
+ exec >&6 2>&7 <&8
printf "\r \n\nCurrent command"
if [ -n "${cur_cmd}" ]; then
printf ":\n %s\n" "${cur_cmd}"
@@ -131,7 +131,8 @@ set +o hashall
# Log policy:
# - first of all, save stdout so we can see the live logs: fd #6
-exec 6>&1
+# (also save stdin and stderr for use by CT_DEBUG_INTERACTIVE)
+exec 6>&1 7>&2 8<&0
# - then point stdout to the log file
tmp_log_file="${CT_TOP_DIR}/build.log"
rm -f "${tmp_log_file}"