diff options
Diffstat (limited to 'usr.bin/find')
-rw-r--r-- | usr.bin/find/main.c | 9 | ||||
-rw-r--r-- | usr.bin/find/misc.c | 14 |
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; |