]> andersk Git - splint.git/blob - src/lltok.c
Merged code tree with Dave Evans's version. Many changes to numberous to list....
[splint.git] / src / lltok.c
1 /*
2 ** LCLint - annotation-assisted static program checker
3 ** Copyright (C) 1994-2001 University of Virginia,
4 **         Massachusetts Institute of Technology
5 **
6 ** This program is free software; you can redistribute it and/or modify it
7 ** under the terms of the GNU General Public License as published by the
8 ** Free Software Foundation; either version 2 of the License, or (at your
9 ** option) any later version.
10 ** 
11 ** This program is distributed in the hope that it will be useful, but
12 ** WITHOUT ANY WARRANTY; without even the implied warranty of
13 ** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 ** General Public License for more details.
15 ** 
16 ** The GNU General Public License is available from http://www.gnu.org/ or
17 ** the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston,
18 ** MA 02111-1307, USA.
19 **
20 ** For information on lclint: lclint-request@cs.virginia.edu
21 ** To report a bug: lclint-bug@cs.virginia.edu
22 ** For more information: http://lclint.cs.virginia.edu
23 */
24 /*
25 ** lltok.c
26 */
27
28 # include "lclintMacros.nf"
29 # include "basic.h"
30
31 # include "cgrammar.h"
32 # include "cgrammar_tokens.h"
33
34 bool
35 lltok_isSemi (lltok tok)
36 {
37   return (tok.tok == TSEMI);
38 }
39
40 bool
41 lltok_isMult (lltok tok)
42 {
43   return (tok.tok == TMULT);
44 }
45
46 bool lltok_isInc_Op (lltok tok)
47 {
48   return (tok.tok == INC_OP);
49 }
50
51 bool lltok_isDec_Op  (lltok tok)
52 {
53   return (tok.tok == DEC_OP);
54 }
55
56
57 /* DRL added this function 10/23/2000 for boolean stuff */
58 bool lltok_isEq_Op (lltok tok)
59 {
60   return (tok.tok == EQ_OP);
61 }
62
63 /* DRL added this function 10/25/2000 for boolean stuff */
64 bool lltok_isAnd_Op (lltok tok)
65 {
66   return (tok.tok == AND_OP);
67 }
68
69 bool lltok_isOr_Op (lltok tok)
70 {
71   return (tok.tok == OR_OP);
72 }
73
74 bool lltok_isNot_Op (lltok tok)
75 {
76   return (tok.tok ==  TEXCL);
77 }
78 /*drl7x added this function 11/20/00 */
79
80 bool lltok_isLt_Op (lltok tok)
81 {
82   return (tok.tok ==  TLT);
83 }
84
85 bool lltok_isGt_Op (lltok tok)
86 {
87   return (tok.tok ==  TGT);
88 }
89   
90 bool lltok_isGe_Op (lltok tok)
91 {
92   return (tok.tok ==  GE_OP);
93 }
94
95 bool lltok_isLe_Op (lltok tok)
96 {
97   return (tok.tok ==  LE_OP);
98 }
99
100 /* end drl7x added */
101
102
103 /*drl7x added 11 30 2000*/
104 bool  lltok_isPlus_Op (lltok tok)
105 {
106   return (tok.tok ==  TPLUS);
107 }
108
109 bool  lltok_isMinus_Op (lltok tok)
110 {
111   return (tok.tok ==  TMINUS);
112 }
113
114 /*drl7x added 6 6 2001 */
115
116
117 bool  lltok_isAmpersand_Op (lltok tok)
118 {
119   return (tok.tok == TAMPERSAND);
120 }
121
122 /*end drl added */
123
124 /*drl7x added 6 15 2001 */
125
126 bool  lltok_isExcl_Op (lltok tok)
127 {
128   return (tok.tok == TEXCL);
129 }
130
131 bool  lltok_isTilde_Op (lltok tok)
132 {
133   return (tok.tok == TTILDE);
134 }
135
136 /*end drl added */
137
138
139
140 cstring
141 lltok_unparse (lltok tok)
142 {
143   char *lit;
144
145   switch (tok.tok)
146     {
147     case BREAK:      lit = "break"; break;
148     case CASE:       lit = "case"; break;
149     case CONTINUE:   lit = "continue"; break;
150     case DEFAULT:    lit = "default"; break;
151     case DO:         lit = "do"; break;
152     case CDOUBLE:    lit = "double"; break;
153     case CELSE:      lit = "else"; break;
154     case CFOR:       lit = "for"; break;
155     case GOTO:       lit = "goto"; break;
156     case CIF:        lit = "if"; break;
157     case RETURN:     lit = "return"; break;
158     case CSIZEOF:    lit = "sizeof"; break;
159     case SWITCH:     lit = "switch"; break;
160     case WHILE:      lit = "while"; break;
161     case CSTRUCT:    lit = "struct"; break;
162     case CTYPEDEF:   lit = "typedef"; break;
163     case CUNION:     lit = "union"; break;
164     case CENUM:      lit = "enum"; break;
165     case QEXTERN:     lit = "extern"; break;
166     case QAUTO:       lit = "auto"; break;
167     case QSTATIC:     lit = "static"; break;
168     case RIGHT_ASSIGN: lit = ">>="; break;
169     case LEFT_ASSIGN:  lit = "<<="; break;
170     case ADD_ASSIGN: lit = "+="; break;
171     case SUB_ASSIGN: lit = "-="; break;
172     case MUL_ASSIGN: lit = "*="; break;
173     case DIV_ASSIGN: lit = "/="; break;
174     case MOD_ASSIGN: lit = "%="; break;
175     case AND_ASSIGN: lit = "&="; break;
176     case XOR_ASSIGN: lit = "^="; break;
177     case OR_ASSIGN:  lit = "|="; break;
178     case RIGHT_OP:   lit = ">>"; break;
179     case LEFT_OP:    lit = "<<"; break;
180     case INC_OP:     lit = "++"; break; 
181     case DEC_OP:     lit = "--"; break;
182     case ARROW_OP:   lit = "->"; break;
183     case AND_OP:     lit = "&&"; break;
184     case OR_OP:      lit = "||"; break;
185     case LE_OP:      lit = "<="; break;
186     case GE_OP:      lit = ">="; break;
187     case EQ_OP:      lit = "=="; break;
188     case NE_OP:      lit = "!="; break;
189     case TSEMI:      lit = ";"; break;
190     case TLBRACE:    lit = "{"; break;
191     case TRBRACE:    lit = "}"; break;
192     case TCOMMA:     lit = ","; break;
193     case TCOLON:     lit = ":"; break;
194     case TASSIGN:        lit = "="; break;
195     case TLPAREN:    lit = "("; break;
196     case TRPAREN:    lit = ")"; break;
197     case TLSQBR:     lit = "["; break;
198     case TRSQBR:     lit = "]"; break;
199     case TDOT:       lit = "."; break;
200     case TAMPERSAND: lit = "&"; break;
201     case TEXCL:      lit = "!"; break;
202     case TTILDE:     lit = "~"; break;
203     case TMINUS:     lit = "-"; break;
204     case TPLUS:      lit = "+"; break;
205     case TMULT:      lit = "*"; break;
206     case TDIV:       lit = "/"; break;
207     case TPERCENT:   lit = "%"; break;
208     case TLT:        lit = "<"; break;
209     case TGT:        lit = ">"; break;
210     case TCIRC:      lit = "^"; break;
211     case TBAR:       lit = "|"; break;
212     case TQUEST:     lit = "?"; break;  
213     case QOUT:       lit = "out"; break;
214     case QONLY:      lit = "only"; break;
215     case QKEEP:      lit = "keep"; break;
216     case QKEPT:      lit = "kept"; break;
217     case QTEMP:      lit = "temp"; break;
218     case QSHARED:    lit = "shared"; break;
219     case QUNIQUE:    lit = "unique"; break;
220     case QREF:       lit = "ref"; break;
221     case QCHECKED:   lit = "checked"; break;
222     case QCHECKEDSTRICT: lit = "checkedstrict"; break;
223     case QCHECKMOD:  lit = "checkmod"; break;
224     case QUNCHECKED: lit = "unchecked"; break;
225     case QTRUENULL:  lit = "truenull"; break;
226     case QFALSENULL: lit = "falsenull"; break;
227     case QRETURNED:  lit = "returned"; break;
228     case QEXPOSED:   lit = "exposed"; break;
229     case QNULL:      lit = "null"; break;
230     case QRELNULL:   lit = "refnull"; break;
231     case QOBSERVER:  lit = "observer"; break;
232     case QPARTIAL:   lit = "partial"; break;
233     case QSPECIAL:   lit = "special"; break;
234     case QUSES:      lit = "uses"; break;
235     case QDEFINES:   lit = "defines"; break;
236     case QALLOCATES: lit = "allocates"; break;
237     case QSETS:      lit = "sets"; break;
238     case QRELEASES:  lit = "releases"; break;
239     case QSETBUFFERSIZE: lit = "setBufferSize"; break;
240     case QSETSTRINGLENGTH: lit = "setStringLength"; break;
241     BADDEFAULT;
242     }
243  
244   return cstring_makeLiteralTemp (lit);
245 }
246
247 lltok
248 lltok_create (int tok, fileloc loc)
249 {
250   lltok l;
251
252   l.tok = tok;
253   l.loc = loc;
254
255   return (l);
256 }
257
258 void lltok_release (lltok t) 
259 {
260   fileloc_free (t.loc);
261 }
262
263 fileloc lltok_stealLoc (lltok t)
264 {
265   fileloc res = t.loc;
266   t.loc = fileloc_undefined;
267   return res;
268 }
This page took 0.057411 seconds and 5 git commands to generate.