X-Git-Url: https://git.librecmc.org/?a=blobdiff_plain;f=coreutils%2Fnohup.c;h=f44e2af610a46f474a72a4e0db71a5fa0b6aa630;hb=8d680b51148b9cbe7dd3afd37022f3390dd999ef;hp=22419b800de37e5fc02766ab9f50240ed54078fa;hpb=b6adbf1be29841501cc49917249e85f273e1df7c;p=oweals%2Fbusybox.git diff --git a/coreutils/nohup.c b/coreutils/nohup.c index 22419b800..f44e2af61 100644 --- a/coreutils/nohup.c +++ b/coreutils/nohup.c @@ -5,28 +5,48 @@ * http://www.opengroup.org/onlinepubs/007904975/utilities/nohup.html * * Copyright 2006 Rob Landley - * Copyright 2006 Bernhard Fischer + * Copyright 2006 Bernhard Reutner-Fischer * * Licensed under GPLv2 or later, see file LICENSE in this tarball for details. */ #include "libbb.h" -int nohup_main(int argc, char **argv); +/* Compat info: nohup (GNU coreutils 6.8) does this: +# nohup true +nohup: ignoring input and appending output to `nohup.out' +# nohup true 1>/dev/null +nohup: ignoring input and redirecting stderr to stdout +# nohup true 2>zz +# cat zz +nohup: ignoring input and appending output to `nohup.out' +# nohup true 2>zz 1>/dev/null +# cat zz +nohup: ignoring input +# nohup true /dev/null +nohup: redirecting stderr to stdout +# nohup true zz 1>/dev/null +# cat zz + (nothing) +# +*/ + +int nohup_main(int argc, char **argv) MAIN_EXTERNALLY_VISIBLE; int nohup_main(int argc, char **argv) { - int nullfd; const char *nohupout; - char *home = NULL; + char *home; xfunc_error_retval = 127; if (argc < 2) bb_show_usage(); - nullfd = xopen(bb_dev_null, O_WRONLY|O_APPEND); /* If stdin is a tty, detach from it. */ - if (isatty(STDIN_FILENO)) - dup2(nullfd, STDIN_FILENO); + if (isatty(STDIN_FILENO)) { + /* bb_error_msg("ignoring input"); */ + close(STDIN_FILENO); + xopen(bb_dev_null, O_RDONLY); /* will be fd 0 (STDIN_FILENO) */ + } nohupout = "nohup.out"; /* Redirect stdout to nohup.out, either in "." or in "$HOME". */ @@ -37,24 +57,22 @@ int nohup_main(int argc, char **argv) if (home) { nohupout = concat_path_file(home, nohupout); xopen3(nohupout, O_CREAT|O_WRONLY|O_APPEND, S_IRUSR|S_IWUSR); + } else { + xopen(bb_dev_null, O_RDONLY); /* will be fd 1 */ } } - } else dup2(nullfd, STDOUT_FILENO); + bb_error_msg("appending output to %s", nohupout); + } - /* If we have a tty on stderr, announce filename and redirect to stdout. - * Else redirect to /dev/null. - */ + /* If we have a tty on stderr, redirect to stdout. */ if (isatty(STDERR_FILENO)) { - bb_error_msg("appending to %s", nohupout); + /* if (stdout_wasnt_a_tty) + bb_error_msg("redirecting stderr to stdout"); */ dup2(STDOUT_FILENO, STDERR_FILENO); - } else dup2(nullfd, STDERR_FILENO); + } - if (nullfd > 2) - close(nullfd); signal(SIGHUP, SIG_IGN); BB_EXECVP(argv[1], argv+1); - if (ENABLE_FEATURE_CLEAN_UP && home) - free((char*)nohupout); - bb_perror_msg_and_die("%s", argv[1]); + bb_simple_perror_msg_and_die(argv[1]); }