summaryrefslogtreecommitdiff
path: root/usr.bin/find
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/find')
-rw-r--r--usr.bin/find/main.c9
-rw-r--r--usr.bin/find/misc.c14
2 files changed, 15 insertions, 8 deletions
diff --git a/usr.bin/find/main.c b/usr.bin/find/main.c
index df8de968628..68a93604372 100644
--- a/usr.bin/find/main.c
+++ b/usr.bin/find/main.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: main.c,v 1.16 2003/06/10 22:20:46 deraadt Exp $ */
+/* $OpenBSD: main.c,v 1.17 2003/09/26 22:22:26 tedu Exp $ */
/*-
* Copyright (c) 1990, 1993
@@ -31,7 +31,7 @@
#ifndef lint
/*static char sccsid[] = "@(#)main.c 8.1 (Berkeley) 6/6/93";*/
-static char rcsid[] = "$OpenBSD: main.c,v 1.16 2003/06/10 22:20:46 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: main.c,v 1.17 2003/09/26 22:22:26 tedu Exp $";
#endif /* not lint */
#include <sys/types.h>
@@ -63,7 +63,7 @@ int
main(int argc, char *argv[])
{
struct sigaction sa;
- char **p, **paths;
+ char **p, **paths, **paths2;
int ch;
memset(&sa, 0, sizeof sa);
@@ -126,8 +126,9 @@ main(int argc, char *argv[])
usage();
*p = NULL;
- if (!(paths = realloc(paths, sizeof(char *) * (p - paths + 1))))
+ if (!(paths2 = realloc(paths, sizeof(char *) * (p - paths + 1))))
err(1, NULL);
+ paths = paths2;
if ((dotfd = open(".", O_RDONLY, 0)) < 0)
err(1, ".:");
diff --git a/usr.bin/find/misc.c b/usr.bin/find/misc.c
index ad343b56e18..0635129f850 100644
--- a/usr.bin/find/misc.c
+++ b/usr.bin/find/misc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: misc.c,v 1.9 2003/06/26 07:27:29 deraadt Exp $ */
+/* $OpenBSD: misc.c,v 1.10 2003/09/26 22:22:26 tedu Exp $ */
/*-
* Copyright (c) 1990, 1993
@@ -34,7 +34,7 @@
#ifndef lint
/*static char sccsid[] = "from: @(#)misc.c 8.1 (Berkeley) 6/6/93";*/
-static char rcsid[] = "$OpenBSD: misc.c,v 1.9 2003/06/26 07:27:29 deraadt Exp $";
+static char rcsid[] = "$OpenBSD: misc.c,v 1.10 2003/09/26 22:22:26 tedu Exp $";
#endif /* not lint */
#include <sys/types.h>
@@ -64,9 +64,15 @@ brace_subst(char *orig, char **store, char *path, int len)
plen = strlen(path);
for (p = *store; (ch = *orig); ++orig)
if (ch == '{' && orig[1] == '}') {
- while ((p - *store) + plen > len)
- if (!(*store = realloc(*store, len *= 2)))
+ while ((p - *store) + plen > len) {
+ int newlen = len * 2;
+ char *newstore;
+
+ if (!(newstore = realloc(*store, newlen)))
err(1, NULL);
+ *store = newstore;
+ len = newlen;
+ }
memmove(p, path, plen);
p += plen;
++orig;