diff options
author | Marc Espie <espie@cvs.openbsd.org> | 2000-07-26 17:46:53 +0000 |
---|---|---|
committer | Marc Espie <espie@cvs.openbsd.org> | 2000-07-26 17:46:53 +0000 |
commit | 19122c4b1f6f2e9ccb50683ab386fa9c28390a58 (patch) | |
tree | ba84cd6074bc60b7e22c74465d49ad4f50298781 /usr.bin | |
parent | ae337e596f6821228e0febe433e4813ec5a749e0 (diff) |
Still truncate too long identifiers, but avoid writing all over the stack.
Diffstat (limited to 'usr.bin')
-rw-r--r-- | usr.bin/ctags/C.c | 44 |
1 files changed, 18 insertions, 26 deletions
diff --git a/usr.bin/ctags/C.c b/usr.bin/ctags/C.c index 95ac9f77292..2f1b3d22480 100644 --- a/usr.bin/ctags/C.c +++ b/usr.bin/ctags/C.c @@ -1,4 +1,4 @@ -/* $OpenBSD: C.c,v 1.5 2000/07/25 19:28:30 deraadt Exp $ */ +/* $OpenBSD: C.c,v 1.6 2000/07/26 17:46:52 espie Exp $ */ /* $NetBSD: C.c,v 1.3 1995/03/26 20:14:02 glass Exp $ */ /* @@ -38,7 +38,7 @@ #if 0 static char sccsid[] = "@(#)C.c 8.4 (Berkeley) 4/2/94"; #else -static char rcsid[] = "$OpenBSD: C.c,v 1.5 2000/07/25 19:28:30 deraadt Exp $"; +static char rcsid[] = "$OpenBSD: C.c,v 1.6 2000/07/26 17:46:52 espie Exp $"; #endif #endif /* not lint */ @@ -246,12 +246,10 @@ endtok: if (sp > tok) { sp = tok; } else if (sp != tok || begtoken(c)) { - if (sp >= tok + sizeof tok) { - /* hell... truncate it */ - if (sp == tok + sizeof(tok)) - *sp = '\0'; - sp++; - } else + /* hell... truncate it */ + if (sp == tok + sizeof tok - 1) + *sp = EOS; + else *sp++ = c; token = YES; } @@ -353,12 +351,10 @@ hash_entry() return; if (iswhite(c)) break; - if (sp >= tok + sizeof(tok)) { - /* hell... truncate it */ - if (sp == tok + sizeof(tok)) - *sp = '\0'; - sp++; - } else + /* hell... truncate it */ + if (sp == tok + sizeof tok - 1) + *sp = EOS; + else *sp++ = c; } *sp = EOS; @@ -371,12 +367,10 @@ hash_entry() break; } for (sp = tok;;) { /* get next token */ - if (sp >= tok + sizeof tok) { - /* hell... truncate it */ - if (sp == tok + sizeof(tok)) - *sp = '\0'; - sp++; - } else + /* hell... truncate it */ + if (sp == tok + sizeof tok - 1) + *sp = EOS; + else *sp++ = c; if (GETC(==, EOF)) return; @@ -419,12 +413,10 @@ str_entry(c) if (c == '{') /* it was "struct {" */ return (YES); for (sp = tok;;) { /* get next token */ - if (sp >= tok + sizeof tok) { - /* hell... truncate it */ - if (sp == tok + sizeof(tok)) - *sp = '\0'; - sp++; - } else + /* hell... truncate it */ + if (sp == tok + sizeof tok - 1) + *sp = EOS; + else *sp++ = c; if (GETC(==, EOF)) return (NO); |