Revert "Do not use arg.h for tools which take no flags"
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
This commit is contained in:
parent
9ae6c45097
commit
d2824f5294
5
chroot.c
5
chroot.c
@ -17,7 +17,10 @@ main(int argc, char *argv[])
|
||||
char *shell[] = { "/bin/sh", "-i", NULL }, *aux, *cmd;
|
||||
int savederrno;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (!argc)
|
||||
usage();
|
||||
|
11
cksum.c
11
cksum.c
@ -92,12 +92,21 @@ cksum(int fd, const char *s)
|
||||
putchar('\n');
|
||||
}
|
||||
|
||||
static void
|
||||
usage(void)
|
||||
{
|
||||
eprintf("usage: %s [file ...]\n", argv0);
|
||||
}
|
||||
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
int fd;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (!argc) {
|
||||
cksum(0, NULL);
|
||||
|
@ -16,7 +16,10 @@ main(int argc, char *argv[])
|
||||
{
|
||||
char host[HOST_NAME_MAX + 1];
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (!argc) {
|
||||
if (gethostname(host, sizeof(host)) < 0)
|
||||
|
5
link.c
5
link.c
@ -12,7 +12,10 @@ usage(void)
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (argc != 2)
|
||||
usage();
|
||||
|
5
nohup.c
5
nohup.c
@ -19,7 +19,10 @@ main(int argc, char *argv[])
|
||||
{
|
||||
int fd, savederrno;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (!argc)
|
||||
usage();
|
||||
|
11
printenv.c
11
printenv.c
@ -6,13 +6,22 @@
|
||||
|
||||
extern char **environ;
|
||||
|
||||
static void
|
||||
usage(void)
|
||||
{
|
||||
eprintf("usage: %s [var ...]\n", argv0);
|
||||
}
|
||||
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
char *var;
|
||||
int ret = 0;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (!argc) {
|
||||
for (; *environ; environ++)
|
||||
|
5
setsid.c
5
setsid.c
@ -15,7 +15,10 @@ main(int argc, char *argv[])
|
||||
{
|
||||
int savederrno;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (!argc)
|
||||
usage();
|
||||
|
5
sleep.c
5
sleep.c
@ -14,7 +14,10 @@ main(int argc, char *argv[])
|
||||
{
|
||||
unsigned seconds;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (argc != 1)
|
||||
usage();
|
||||
|
5
sponge.c
5
sponge.c
@ -17,7 +17,10 @@ main(int argc, char *argv[])
|
||||
char tmp[] = "/tmp/sponge-XXXXXX";
|
||||
int fd, tmpfd;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (argc != 1)
|
||||
usage();
|
||||
|
5
sync.c
5
sync.c
@ -12,7 +12,10 @@ usage(void)
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (argc)
|
||||
usage();
|
||||
|
5
tty.c
5
tty.c
@ -15,7 +15,10 @@ main(int argc, char *argv[])
|
||||
{
|
||||
char *tty;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (argc)
|
||||
usage();
|
||||
|
5
unlink.c
5
unlink.c
@ -12,7 +12,10 @@ usage(void)
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
if (argc != 1)
|
||||
usage();
|
||||
|
11
yes.c
11
yes.c
@ -3,12 +3,21 @@
|
||||
|
||||
#include "util.h"
|
||||
|
||||
static void
|
||||
usage(void)
|
||||
{
|
||||
eprintf("usage: %s [string ...]\n", argv0);
|
||||
}
|
||||
|
||||
int
|
||||
main(int argc, char *argv[])
|
||||
{
|
||||
char **p;
|
||||
|
||||
argv0 = *argv, argv0 ? (argc--, argv++) : (void *)0;
|
||||
ARGBEGIN {
|
||||
default:
|
||||
usage();
|
||||
} ARGEND
|
||||
|
||||
for (p = argv; ; p = (*p && *(p + 1)) ? p + 1 : argv) {
|
||||
fputs(*p ? *p : "y", stdout);
|
||||
|
Loading…
x
Reference in New Issue
Block a user