ref: 34c0b8bd4e22a498930f2c4114d70d13032e85ff
parent: 804901a9a3e5b33a0514ea2670597057da68d03b
author: Roberto E. Vargas Caballero <k0ga@shike2.com>
date: Mon May 25 05:49:51 EDT 2015
Simplify copydefine()
--- a/cc1/cpp.c
+++ b/cc1/cpp.c
@@ -246,51 +246,43 @@
}
/*
* Copy a define string, and substitute formal arguments of the
- * macro into strings in the form @XX, where XX is the position
+ * macro into strings in the form @XX@, where XX is the position
* of the argument in the argument list.
*/
static char *
copydefine(char *s, char *args[], char *buff, int bufsiz, int nargs)
{
- unsigned ncopy;
int n;
- size_t len;
- char arroba[6], *par, *endp, **bp;
+ size_t ncopy;
+ char arroba[6], *p, **bp, c;
- while (*s && bufsiz > 0) {
- if (!isalnum(*s) && *s != '_') {
- --bufsiz;
- *buff++ = *s++;
+ while ((c = *s) && bufsiz > 0) {
+ if (!isalnum(c) && c != '_' || nargs < 1) {
+ *buff++ = c;
+ ++s, --bufsiz;
continue;
}
- /*
- * found an identifier, is it one of the macro arguments?
- */
- for (endp = s+1; isalnum(*endp) || *endp == '_'; ++endp)
+ /* found an identifier, is it one of the macro arguments? */
+ for (p = s+1; isalnum(c = *p) || c == '_'; ++p)
/* nothing */;
- len = endp - s;
- for (bp =args, n = 0; n < nargs; ++bp, n++) {
- if (strncmp(s, *bp, len))
+ ncopy = p - s;
+ bp = args;
+ for (n = 0; n < nargs; ++n) {
+ if (strncmp(s, *bp++, ncopy))
continue;
sprintf(arroba, "@%02d@", n);
+ s = arroba, ncopy = 4;
break;
}
- if (n == nargs || nargs == -1)
- par = s, ncopy = len;
- else
- par = arroba, ncopy = 4;
-
if ((bufsiz -= ncopy) < 0)
goto too_long;
- memcpy(buff, par, ncopy);
- buff += ncopy;
- s = endp;
+ memcpy(buff, s, ncopy);
+ buff += ncopy, s = p;
}
-
- if (*s == '\0') {
- *buff = '\0';
- return s;
- }
+ if (bufsiz == 0)
+ goto too_long;
+ *buff = '\0';
+ return s;
too_long:
error("macro definition too long");