summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTodd C. Miller <millert@cvs.openbsd.org>1997-06-17 05:26:18 +0000
committerTodd C. Miller <millert@cvs.openbsd.org>1997-06-17 05:26:18 +0000
commitd9ca1896a1a2d718477658ae3fb0423025bbb969 (patch)
treeca045c12eeb7dbcda1b181d3963acf12a250c839
parent08a3faaa5c971e3de45dd8828ab58c0e612549f2 (diff)
Don't trample argv[], we want ps et al to be able to see args.
-rw-r--r--usr.bin/find/main.c17
1 files changed, 10 insertions, 7 deletions
diff --git a/usr.bin/find/main.c b/usr.bin/find/main.c
index cc045166b7a..35d01cd371e 100644
--- a/usr.bin/find/main.c
+++ b/usr.bin/find/main.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: main.c,v 1.4 1997/01/15 23:42:27 millert Exp $ */
+/* $OpenBSD: main.c,v 1.5 1997/06/17 05:26:17 millert Exp $ */
/*-
* Copyright (c) 1990, 1993
@@ -35,7 +35,7 @@
#ifndef lint
/*static char sccsid[] = "@(#)main.c 8.1 (Berkeley) 6/6/93";*/
-static char rcsid[] = "$OpenBSD: main.c,v 1.4 1997/01/15 23:42:27 millert Exp $";
+static char rcsid[] = "$OpenBSD: main.c,v 1.5 1997/06/17 05:26:17 millert Exp $";
#endif /* not lint */
#include <sys/types.h>
@@ -68,14 +68,15 @@ main(argc, argv)
char *argv[];
{
struct sigaction sa = { show_path, SA_RESTART, NULL };
- register char **p, **start;
+ char **p, **paths;
int ch;
(void)time(&now); /* initialize the time-of-day */
+ p = paths = (char **) emalloc(sizeof(char *) * argc);
+
sigaction(SIGINFO, &sa, NULL);
- p = start = argv;
ftsoptions = FTS_NOSTAT|FTS_PHYSICAL;
while ((ch = getopt(argc, argv, "Hdf:hXx")) != -1)
switch(ch) {
@@ -118,14 +119,16 @@ main(argc, argv)
*p++ = *argv++;
}
- if (p == start)
- usage();
*p = NULL;
+ if (paths[0] == NULL) /* we must have at least one path */
+ usage();
+ if (!(paths = realloc(paths, sizeof(char *) * (p - paths + 1))))
+ err(1, NULL);
if ((dotfd = open(".", O_RDONLY, 0)) < 0)
err(1, ".:");
- find_execute(find_formplan(argv), start);
+ find_execute(find_formplan(argv), paths);
exit(0);
}