mirror of
git://git.suckless.org/sbase
synced 2025-01-03 13:42:03 +00:00
d2824f5294
This reverts commit 9016d288f1cd03bf514fe84d537b203040e1ccf8. Tools that have no options are required by POSIX to support "--" so that conforming applications have a way to shield their operands from implementations that provide options as an extension. echo(1) is just an exception, so it is handled specially. See OPTIONS in https://pubs.opengroup.org/onlinepubs/9699919799.2018edition/utilities/V3_chap01.html#tag_17_04
49 lines
890 B
C
49 lines
890 B
C
/* See LICENSE file for copyright and license details. */
|
|
#include <sys/stat.h>
|
|
|
|
#include <errno.h>
|
|
#include <fcntl.h>
|
|
#include <signal.h>
|
|
#include <unistd.h>
|
|
|
|
#include "util.h"
|
|
|
|
static void
|
|
usage(void)
|
|
{
|
|
eprintf("usage: %s cmd [arg ...]\n", argv0);
|
|
}
|
|
|
|
int
|
|
main(int argc, char *argv[])
|
|
{
|
|
int fd, savederrno;
|
|
|
|
ARGBEGIN {
|
|
default:
|
|
usage();
|
|
} ARGEND
|
|
|
|
if (!argc)
|
|
usage();
|
|
|
|
if (signal(SIGHUP, SIG_IGN) == SIG_ERR)
|
|
enprintf(127, "signal HUP:");
|
|
|
|
if (isatty(STDOUT_FILENO)) {
|
|
if ((fd = open("nohup.out", O_APPEND | O_CREAT, S_IRUSR | S_IWUSR)) < 0)
|
|
enprintf(127, "open nohup.out:");
|
|
if (dup2(fd, STDOUT_FILENO) < 0)
|
|
enprintf(127, "dup2:");
|
|
close(fd);
|
|
}
|
|
if (isatty(STDERR_FILENO) && dup2(STDOUT_FILENO, STDERR_FILENO) < 0)
|
|
enprintf(127, "dup2:");
|
|
|
|
execvp(argv[0], argv);
|
|
savederrno = errno;
|
|
weprintf("execvp %s:", argv[0]);
|
|
|
|
_exit(126 + (savederrno == ENOENT));
|
|
}
|