diff options
author | Johannes Stezenbach <js@sig21.net> | 2012-10-30 00:22:25 +0000 |
---|---|---|
committer | Johannes Stezenbach <js@sig21.net> | 2012-10-30 00:22:25 +0000 |
commit | 5ddbc863e1731a96abb8cc8d255aaac65d7885c5 (patch) | |
tree | 082052a5471ed3a768f87827047835a232f2bd5f | |
parent | 34a6501a2e79ef7a740171fddf6ccae916a12b1d (diff) | |
download | crosstool-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/functions | 5 |
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}" |