diff options
author | Chad Loder <cloder@cvs.openbsd.org> | 2005-12-02 18:03:10 +0000 |
---|---|---|
committer | Chad Loder <cloder@cvs.openbsd.org> | 2005-12-02 18:03:10 +0000 |
commit | 6e810003a432609fd7b1781ff23315d009df67c1 (patch) | |
tree | 07be3c1f8cc53644add3107fe3f7cf334e419011 | |
parent | 64048282f6310bae17f20cf59140a4f81170f78d (diff) |
Make three of the keytab fields into a union, because they are 3 different
enums that are mutually exclusive with each other. Makes this file so
much neater.
-rw-r--r-- | usr.bin/xlint/lint1/scan.l | 110 |
1 files changed, 56 insertions, 54 deletions
diff --git a/usr.bin/xlint/lint1/scan.l b/usr.bin/xlint/lint1/scan.l index 6d029a709ff..406b8cc1985 100644 --- a/usr.bin/xlint/lint1/scan.l +++ b/usr.bin/xlint/lint1/scan.l @@ -1,5 +1,5 @@ %{ -/* $OpenBSD: scan.l,v 1.17 2005/12/01 03:17:14 cloder Exp $ */ +/* $OpenBSD: scan.l,v 1.18 2005/12/02 18:03:09 cloder Exp $ */ /* $NetBSD: scan.l,v 1.8 1995/10/23 13:38:51 jpo Exp $ */ /* @@ -34,7 +34,7 @@ */ #ifndef lint -static char rcsid[] = "$OpenBSD: scan.l,v 1.17 2005/12/01 03:17:14 cloder Exp $"; +static char rcsid[] = "$OpenBSD: scan.l,v 1.18 2005/12/02 18:03:09 cloder Exp $"; #endif #include <stdlib.h> @@ -180,61 +180,63 @@ badchar(int c) static struct kwtab { const char *kw_name; /* keyword */ int kw_token; /* token returned by yylex() */ - scl_t kw_scl; /* storage class if kw_token T_SCLASS */ - tspec_t kw_tspec; /* type spec. if kw_token T_TYPE or T_SOU */ - tqual_t kw_tqual; /* type qual. fi kw_token T_QUAL */ + union { + scl_t kw_scl; /* storage class if kw_token T_SCLASS */ + tspec_t kw_tspec; /* type spec. if kw_token T_TYPE or T_SOU */ + tqual_t kw_tqual; /* type qual. if kw_token T_QUAL */ + }; u_int kw_stdc : 1; /* STDC keyword */ u_int kw_gcc : 1; /* GCC keyword */ } kwtab[] = { - { "asm", T_ASM, 0, 0, 0, 0, 1 }, - { "__asm", T_ASM, 0, 0, 0, 0, 0 }, - { "__asm__", T_ASM, 0, 0, 0, 0, 0 }, - { "__attribute__", T_ATTRIBUTE, 0, 0, 0, 0, 0 }, - { "__lint_equal__", T_LEQUAL, 0, 0, 0, 0, 0 }, - { "auto", T_SCLASS, AUTO, 0, 0, 0, 0 }, - { "break", T_BREAK, 0, 0, 0, 0, 0 }, - { "case", T_CASE, 0, 0, 0, 0, 0 }, - { "char", T_TYPE, 0, CHAR, 0, 0, 0 }, - { "const", T_QUAL, 0, 0, CONST, 1, 0 }, - { "__const__", T_QUAL, 0, 0, CONST, 0, 0 }, - { "__const", T_QUAL, 0, 0, CONST, 0, 0 }, - { "continue", T_CONTINUE, 0, 0, 0, 0, 0 }, - { "default", T_DEFAULT, 0, 0, 0, 0, 0 }, - { "do", T_DO, 0, 0, 0, 0, 0 }, - { "double", T_TYPE, 0, DOUBLE, 0, 0, 0 }, - { "else", T_ELSE, 0, 0, 0, 0, 0 }, - { "enum", T_ENUM, 0, 0, 0, 0, 0 }, - { "extern", T_SCLASS, EXTERN, 0, 0, 0, 0 }, - { "float", T_TYPE, 0, FLOAT, 0, 0, 0 }, - { "for", T_FOR, 0, 0, 0, 0, 0 }, - { "goto", T_GOTO, 0, 0, 0, 0, 0 }, - { "if", T_IF, 0, 0, 0, 0, 0 }, - { "inline", T_SCLASS, INLINE, 0, 0, 1, 0 }, - { "__inline__", T_SCLASS, INLINE, 0, 0, 0, 0 }, - { "__inline", T_SCLASS, INLINE, 0, 0, 0, 0 }, - { "int", T_TYPE, 0, INT, 0, 0, 0 }, - { "long", T_TYPE, 0, LONG, 0, 0, 0 }, - { "register", T_SCLASS, REG, 0, 0, 0, 0 }, - { "__restrict", T_QUAL, 0, 0, RESTRICT, 0, 0 }, - { "__restrict__", T_QUAL, 0, 0, RESTRICT, 0, 0 }, - { "return", T_RETURN, 0, 0, 0, 0, 0 }, - { "short", T_TYPE, 0, SHORT, 0, 0, 0 }, - { "signed", T_TYPE, 0, SIGNED, 0, 1, 0 }, - { "__signed__", T_TYPE, 0, SIGNED, 0, 0, 0 }, - { "__signed", T_TYPE, 0, SIGNED, 0, 0, 0 }, - { "sizeof", T_SIZEOF, 0, 0, 0, 0, 0 }, - { "static", T_SCLASS, STATIC, 0, 0, 0, 0 }, - { "struct", T_SOU, 0, STRUCT, 0, 0, 0 }, - { "switch", T_SWITCH, 0, 0, 0, 0, 0 }, - { "typedef", T_SCLASS, TYPEDEF, 0, 0, 0, 0 }, - { "union", T_SOU, 0, UNION, 0, 0, 0 }, - { "unsigned", T_TYPE, 0, UNSIGN, 0, 0, 0 }, - { "void", T_TYPE, 0, VOID, 0, 0, 0 }, - { "volatile", T_QUAL, 0, 0, VOLATILE, 1, 0 }, - { "__volatile__", T_QUAL, 0, 0, VOLATILE, 0, 0 }, - { "__volatile", T_QUAL, 0, 0, VOLATILE, 0, 0 }, - { "while", T_WHILE, 0, 0, 0, 0, 0 }, - { NULL, 0, 0, 0, 0, 0, 0 } + { "asm", T_ASM, { 0 }, 0, 1 }, + { "__asm", T_ASM, { 0 }, 0, 0 }, + { "__asm__", T_ASM, { 0 }, 0, 0 }, + { "__attribute__", T_ATTRIBUTE, { 0 }, 0, 0 }, + { "auto", T_SCLASS, { AUTO }, 0, 0 }, + { "break", T_BREAK, { 0 }, 0, 0 }, + { "case", T_CASE, { 0 }, 0, 0 }, + { "char", T_TYPE, { CHAR }, 0, 0 }, + { "const", T_QUAL, { CONST }, 1, 0 }, + { "__const__", T_QUAL, { CONST }, 0, 0 }, + { "__const", T_QUAL, { CONST }, 0, 0 }, + { "continue", T_CONTINUE, { 0 }, 0, 0 }, + { "default", T_DEFAULT, { 0 }, 0, 0 }, + { "do", T_DO, { 0 }, 0, 0 }, + { "double", T_TYPE, { DOUBLE }, 0, 0 }, + { "else", T_ELSE, { 0 }, 0, 0 }, + { "enum", T_ENUM, { 0 }, 0, 0 }, + { "extern", T_SCLASS, { EXTERN }, 0, 0 }, + { "float", T_TYPE, { FLOAT }, 0, 0 }, + { "for", T_FOR, { 0 }, 0, 0 }, + { "goto", T_GOTO, { 0 }, 0, 0 }, + { "if", T_IF, { 0 }, 0, 0 }, + { "inline", T_SCLASS, { INLINE }, 1, 0 }, + { "__inline__", T_SCLASS, { INLINE }, 0, 0 }, + { "__inline", T_SCLASS, { INLINE }, 0, 0 }, + { "int", T_TYPE, { INT }, 0, 0 }, + { "__lint_equal__", T_LEQUAL, { 0 }, 0, 0 }, + { "long", T_TYPE, { LONG }, 0, 0 }, + { "register", T_SCLASS, { REG }, 0, 0 }, + { "__restrict", T_QUAL, { RESTRICT }, 0, 0 }, + { "__restrict__", T_QUAL, { RESTRICT }, 0, 0 }, + { "return", T_RETURN, { 0 }, 0, 0 }, + { "short", T_TYPE, { SHORT }, 0, 0 }, + { "signed", T_TYPE, { SIGNED }, 1, 0 }, + { "__signed__", T_TYPE, { SIGNED }, 0, 0 }, + { "__signed", T_TYPE, { SIGNED }, 0, 0 }, + { "sizeof", T_SIZEOF, { 0 }, 0, 0 }, + { "static", T_SCLASS, { STATIC }, 0, 0 }, + { "struct", T_SOU, { STRUCT }, 0, 0 }, + { "switch", T_SWITCH, { 0 }, 0, 0 }, + { "typedef", T_SCLASS, { TYPEDEF }, 0, 0 }, + { "union", T_SOU, { UNION }, 0, 0 }, + { "unsigned", T_TYPE, { UNSIGN }, 0, 0 }, + { "void", T_TYPE, { VOID }, 0, 0 }, + { "volatile", T_QUAL, { VOLATILE }, 1, 0 }, + { "__volatile__", T_QUAL, { VOLATILE }, 0, 0 }, + { "__volatile", T_QUAL, { VOLATILE }, 0, 0 }, + { "while", T_WHILE, { 0 }, 0, 0 }, + { NULL, 0, { 0 }, 0, 0 } }; /* Symbol table */ |