]>
Commit | Line | Data |
---|---|---|
616915dd | 1 | /* |
11db3170 | 2 | ** Splint - annotation-assisted static program checker |
c59f5181 | 3 | ** Copyright (C) 1994-2003 University of Virginia, |
616915dd | 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 | ** | |
155af98d | 20 | ** For information on splint: info@splint.org |
21 | ** To report a bug: splint-bug@splint.org | |
11db3170 | 22 | ** For more information: http://www.splint.org |
616915dd | 23 | */ |
24 | /* | |
25 | ** lltok.c | |
26 | */ | |
27 | ||
1b8ae690 | 28 | # include "splintMacros.nf" |
616915dd | 29 | # include "basic.h" |
30 | ||
31 | # include "cgrammar.h" | |
32 | # include "cgrammar_tokens.h" | |
33 | ||
34 | bool | |
35 | lltok_isSemi (lltok tok) | |
36 | { | |
80489f0a | 37 | return (tok->tok == TSEMI); |
616915dd | 38 | } |
39 | ||
40 | bool | |
41 | lltok_isMult (lltok tok) | |
42 | { | |
80489f0a | 43 | return (tok->tok == TMULT); |
616915dd | 44 | } |
45 | ||
16c024b5 | 46 | bool lltok_isIncOp (lltok tok) |
616915dd | 47 | { |
80489f0a | 48 | return (tok->tok == INC_OP); |
616915dd | 49 | } |
50 | ||
16c024b5 | 51 | bool lltok_isDecOp (lltok tok) |
616915dd | 52 | { |
80489f0a | 53 | return (tok->tok == DEC_OP); |
616915dd | 54 | } |
55 | ||
56 | ||
57 | /* DRL added this function 10/23/2000 for boolean stuff */ | |
16c024b5 | 58 | bool lltok_isEqOp (lltok tok) |
616915dd | 59 | { |
80489f0a | 60 | return (tok->tok == EQ_OP); |
616915dd | 61 | } |
62 | ||
16c024b5 | 63 | bool lltok_isNotEqOp (lltok tok) |
64 | { | |
65 | return (tok->tok == NE_OP); | |
66 | } | |
67 | ||
616915dd | 68 | /* DRL added this function 10/25/2000 for boolean stuff */ |
16c024b5 | 69 | bool lltok_isAndOp (lltok tok) |
616915dd | 70 | { |
80489f0a | 71 | return (tok->tok == AND_OP); |
616915dd | 72 | } |
73 | ||
16c024b5 | 74 | bool lltok_isOrOp (lltok tok) |
616915dd | 75 | { |
80489f0a | 76 | return (tok->tok == OR_OP); |
616915dd | 77 | } |
78 | ||
16c024b5 | 79 | bool lltok_isNotOp (lltok tok) |
616915dd | 80 | { |
80489f0a | 81 | return (tok->tok == TEXCL); |
616915dd | 82 | } |
83 | /*drl7x added this function 11/20/00 */ | |
84 | ||
85 | bool lltok_isLt_Op (lltok tok) | |
86 | { | |
80489f0a | 87 | return (tok->tok == TLT); |
616915dd | 88 | } |
89 | ||
90 | bool lltok_isGt_Op (lltok tok) | |
91 | { | |
80489f0a | 92 | return (tok->tok == TGT); |
616915dd | 93 | } |
94 | ||
95 | bool lltok_isGe_Op (lltok tok) | |
96 | { | |
80489f0a | 97 | return (tok->tok == GE_OP); |
616915dd | 98 | } |
99 | ||
100 | bool lltok_isLe_Op (lltok tok) | |
101 | { | |
80489f0a | 102 | return (tok->tok == LE_OP); |
616915dd | 103 | } |
104 | ||
105 | /* end drl7x added */ | |
106 | ||
107 | ||
108 | /*drl7x added 11 30 2000*/ | |
109 | bool lltok_isPlus_Op (lltok tok) | |
110 | { | |
80489f0a | 111 | return (tok->tok == TPLUS); |
616915dd | 112 | } |
113 | ||
114 | bool lltok_isMinus_Op (lltok tok) | |
115 | { | |
80489f0a | 116 | return (tok->tok == TMINUS); |
616915dd | 117 | } |
118 | ||
84c9ffbf | 119 | /*drl7x added 6 6 2001 */ |
120 | ||
4ab867d6 | 121 | |
84c9ffbf | 122 | bool lltok_isAmpersand_Op (lltok tok) |
123 | { | |
80489f0a | 124 | return (tok->tok == TAMPERSAND); |
84c9ffbf | 125 | } |
126 | ||
616915dd | 127 | /*end drl added */ |
128 | ||
4ab867d6 | 129 | /*drl7x added 6 15 2001 */ |
130 | ||
131 | bool lltok_isExcl_Op (lltok tok) | |
132 | { | |
80489f0a | 133 | return (tok->tok == TEXCL); |
4ab867d6 | 134 | } |
135 | ||
136 | bool lltok_isTilde_Op (lltok tok) | |
137 | { | |
80489f0a | 138 | return (tok->tok == TTILDE); |
4ab867d6 | 139 | } |
4ab867d6 | 140 | /*end drl added */ |
141 | ||
142 | ||
d9a28762 | 143 | bool lltok_isEnsures (lltok tok) |
144 | { | |
80489f0a | 145 | return (tok->tok == QPOSTCLAUSE); |
d9a28762 | 146 | } |
147 | ||
148 | bool lltok_isRequires (lltok tok) | |
149 | { | |
80489f0a | 150 | return (tok->tok == QPRECLAUSE); |
d9a28762 | 151 | } |
4ab867d6 | 152 | |
616915dd | 153 | cstring |
154 | lltok_unparse (lltok tok) | |
155 | { | |
156 | char *lit; | |
157 | ||
80489f0a | 158 | switch (tok->tok) |
616915dd | 159 | { |
160 | case BREAK: lit = "break"; break; | |
161 | case CASE: lit = "case"; break; | |
162 | case CONTINUE: lit = "continue"; break; | |
163 | case DEFAULT: lit = "default"; break; | |
164 | case DO: lit = "do"; break; | |
165 | case CDOUBLE: lit = "double"; break; | |
166 | case CELSE: lit = "else"; break; | |
167 | case CFOR: lit = "for"; break; | |
168 | case GOTO: lit = "goto"; break; | |
169 | case CIF: lit = "if"; break; | |
170 | case RETURN: lit = "return"; break; | |
171 | case CSIZEOF: lit = "sizeof"; break; | |
172 | case SWITCH: lit = "switch"; break; | |
173 | case WHILE: lit = "while"; break; | |
174 | case CSTRUCT: lit = "struct"; break; | |
175 | case CTYPEDEF: lit = "typedef"; break; | |
176 | case CUNION: lit = "union"; break; | |
177 | case CENUM: lit = "enum"; break; | |
178 | case QEXTERN: lit = "extern"; break; | |
179 | case QAUTO: lit = "auto"; break; | |
180 | case QSTATIC: lit = "static"; break; | |
181 | case RIGHT_ASSIGN: lit = ">>="; break; | |
182 | case LEFT_ASSIGN: lit = "<<="; break; | |
183 | case ADD_ASSIGN: lit = "+="; break; | |
184 | case SUB_ASSIGN: lit = "-="; break; | |
185 | case MUL_ASSIGN: lit = "*="; break; | |
186 | case DIV_ASSIGN: lit = "/="; break; | |
187 | case MOD_ASSIGN: lit = "%="; break; | |
188 | case AND_ASSIGN: lit = "&="; break; | |
189 | case XOR_ASSIGN: lit = "^="; break; | |
190 | case OR_ASSIGN: lit = "|="; break; | |
191 | case RIGHT_OP: lit = ">>"; break; | |
192 | case LEFT_OP: lit = "<<"; break; | |
193 | case INC_OP: lit = "++"; break; | |
194 | case DEC_OP: lit = "--"; break; | |
195 | case ARROW_OP: lit = "->"; break; | |
196 | case AND_OP: lit = "&&"; break; | |
197 | case OR_OP: lit = "||"; break; | |
198 | case LE_OP: lit = "<="; break; | |
199 | case GE_OP: lit = ">="; break; | |
200 | case EQ_OP: lit = "=="; break; | |
201 | case NE_OP: lit = "!="; break; | |
202 | case TSEMI: lit = ";"; break; | |
203 | case TLBRACE: lit = "{"; break; | |
204 | case TRBRACE: lit = "}"; break; | |
205 | case TCOMMA: lit = ","; break; | |
206 | case TCOLON: lit = ":"; break; | |
c09ebffe | 207 | case TASSIGN: lit = "="; break; |
616915dd | 208 | case TLPAREN: lit = "("; break; |
209 | case TRPAREN: lit = ")"; break; | |
210 | case TLSQBR: lit = "["; break; | |
211 | case TRSQBR: lit = "]"; break; | |
c09ebffe | 212 | case TDOT: lit = "."; break; /* evans 2003-05-31: Fix reported by psanzani. */ |
616915dd | 213 | case TAMPERSAND: lit = "&"; break; |
214 | case TEXCL: lit = "!"; break; | |
215 | case TTILDE: lit = "~"; break; | |
216 | case TMINUS: lit = "-"; break; | |
217 | case TPLUS: lit = "+"; break; | |
218 | case TMULT: lit = "*"; break; | |
219 | case TDIV: lit = "/"; break; | |
220 | case TPERCENT: lit = "%"; break; | |
221 | case TLT: lit = "<"; break; | |
222 | case TGT: lit = ">"; break; | |
223 | case TCIRC: lit = "^"; break; | |
224 | case TBAR: lit = "|"; break; | |
225 | case TQUEST: lit = "?"; break; | |
226 | case QOUT: lit = "out"; break; | |
227 | case QONLY: lit = "only"; break; | |
228 | case QKEEP: lit = "keep"; break; | |
229 | case QKEPT: lit = "kept"; break; | |
230 | case QTEMP: lit = "temp"; break; | |
231 | case QSHARED: lit = "shared"; break; | |
232 | case QUNIQUE: lit = "unique"; break; | |
233 | case QREF: lit = "ref"; break; | |
234 | case QCHECKED: lit = "checked"; break; | |
235 | case QCHECKEDSTRICT: lit = "checkedstrict"; break; | |
236 | case QCHECKMOD: lit = "checkmod"; break; | |
237 | case QUNCHECKED: lit = "unchecked"; break; | |
d9a28762 | 238 | case QPRECLAUSE: lit = "requires"; break; |
239 | case QPOSTCLAUSE: lit = "ensures"; break; | |
616915dd | 240 | case QTRUENULL: lit = "truenull"; break; |
241 | case QFALSENULL: lit = "falsenull"; break; | |
242 | case QRETURNED: lit = "returned"; break; | |
243 | case QEXPOSED: lit = "exposed"; break; | |
244 | case QNULL: lit = "null"; break; | |
245 | case QRELNULL: lit = "refnull"; break; | |
246 | case QOBSERVER: lit = "observer"; break; | |
247 | case QPARTIAL: lit = "partial"; break; | |
248 | case QSPECIAL: lit = "special"; break; | |
249 | case QUSES: lit = "uses"; break; | |
250 | case QDEFINES: lit = "defines"; break; | |
251 | case QALLOCATES: lit = "allocates"; break; | |
252 | case QSETS: lit = "sets"; break; | |
253 | case QRELEASES: lit = "releases"; break; | |
254 | case QSETBUFFERSIZE: lit = "setBufferSize"; break; | |
255 | case QSETSTRINGLENGTH: lit = "setStringLength"; break; | |
28bf4b0b | 256 | BADDEFAULT; |
616915dd | 257 | } |
258 | ||
259 | return cstring_makeLiteralTemp (lit); | |
260 | } | |
261 | ||
262 | lltok | |
263 | lltok_create (int tok, fileloc loc) | |
264 | { | |
80489f0a | 265 | lltok l = (lltok) dmalloc (sizeof (*l)); |
616915dd | 266 | |
80489f0a | 267 | l->tok = tok; |
268 | l->loc = loc; | |
269 | DPRINTF (("Create: %s [%p]", lltok_unparse (l), loc)); | |
616915dd | 270 | return (l); |
271 | } | |
272 | ||
80489f0a | 273 | void lltok_free (lltok t) |
616915dd | 274 | { |
80489f0a | 275 | fileloc_free (t->loc); |
276 | sfree (t); | |
616915dd | 277 | } |
278 | ||
6fcd0b1e | 279 | void lltok_free2 (lltok t1, lltok t2) |
280 | { | |
281 | lltok_free (t1); | |
282 | lltok_free (t2); | |
283 | } | |
284 | ||
285 | void lltok_free3 (lltok t1, lltok t2, lltok t3) | |
286 | { | |
287 | lltok_free (t1); | |
288 | lltok_free (t2); | |
289 | lltok_free (t3); | |
290 | } | |
291 |