summaryrefslogtreecommitdiff
path: root/util-linux/script.c
diff options
context:
space:
mode:
authorDenys Vlasenko2014-03-16 12:34:53 +0100
committerDenys Vlasenko2014-03-16 12:34:53 +0100
commit438b4ac2860f4aec5b5fb82c47f75a0cb80d9cb4 (patch)
tree83dd96e62dfe975fa9ea3f738fe32e220862b2fa /util-linux/script.c
parent29f352604868c5d17c81948ea30e332491cecada (diff)
downloadbusybox-438b4ac2860f4aec5b5fb82c47f75a0cb80d9cb4.zip
busybox-438b4ac2860f4aec5b5fb82c47f75a0cb80d9cb4.tar.gz
script: make it work even if fd 0 is closed
Testcase: script -q -c "echo hey" /dev/null 0>&- Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'util-linux/script.c')
-rw-r--r--util-linux/script.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/util-linux/script.c b/util-linux/script.c
index 8fb991d..abcd73b 100644
--- a/util-linux/script.c
+++ b/util-linux/script.c
@@ -77,8 +77,15 @@ int script_main(int argc UNUSED_PARAM, char **argv)
if (!(opt & OPT_q)) {
printf("Script started, file is %s\n", fname);
}
+
shell = get_shell_name();
+ /* Some people run "script ... 0>&-".
+ * Our code assumes that STDIN_FILENO != pty.
+ * Ensure STDIN_FILENO is not closed:
+ */
+ bb_sanitize_stdio();
+
pty = xgetpty(pty_line);
/* get current stdin's tty params */