/*- * Copyright (c) 1990 The Regents of the University of California. * All rights reserved. * * This code is derived from software contributed to Berkeley by * Cimarron D. Taylor of the University of California, Berkeley. * * %sccs.include.redist.c% */ #ifndef lint static char sccsid[] = "@(#)misc.c 5.8 (Berkeley) 05/24/91"; #endif /* not lint */ #include #include #include #include #include #include #include "find.h" /* * brace_subst -- * Replace occurrences of {} in s1 with s2 and return the result string. */ void brace_subst(orig, store, path, len) char *orig, **store, *path; int len; { register int plen; register char ch, *p; plen = strlen(path); for (p = *store; ch = *orig; ++orig) if (ch == '{' && orig[1] == '}') { while ((p - *store) + plen > len) if (!(*store = realloc(*store, len *= 2))) err("%s", strerror(errno)); bcopy(path, p, plen); p += plen; ++orig; } else *p++ = ch; *p = '\0'; } /* * queryuser -- * print a message to standard error and then read input from standard * input. If the input is 'y' then 1 is returned. */ queryuser(argv) register char **argv; { int ch, first, nl; (void)fprintf(stderr, "\"%s", *argv); while (*++argv) (void)fprintf(stderr, " %s", *argv); (void)fprintf(stderr, "\"? "); (void)fflush(stderr); first = ch = getchar(); for (nl = 0;;) { if (ch == '\n') { nl = 1; break; } if (ch == EOF) break; ch = getchar(); } if (!nl) { (void)fprintf(stderr, "\n"); (void)fflush(stderr); } return(first == 'y'); } /* * emalloc -- * malloc with error checking. */ void * emalloc(len) u_int len; { void *p; if (p = malloc(len)) return(p); err("%s", strerror(errno)); /* NOTREACHED */ } #if __STDC__ #include #else #include #endif void #if __STDC__ err(const char *fmt, ...) #else err(fmt, va_alist) char *fmt; va_dcl #endif { va_list ap; #if __STDC__ va_start(ap, fmt); #else va_start(ap); #endif (void)fprintf(stderr, "find: "); (void)vfprintf(stderr, fmt, ap); va_end(ap); (void)fprintf(stderr, "\n"); exit(1); /* NOTREACHED */ }