]> andersk Git - splint.git/blob - src/Headers/usymtab.h
Merged code tree with Dave Evans's version. Many changes to numberous to list....
[splint.git] / src / Headers / usymtab.h
1 /*
2 ** Copyright (C) University of Virginia, Massachusetts Institue of Technology 1994-2001.
3 ** See ../LICENSE for license information.
4 */
5 /*
6 ** usymtab.h
7 */
8
9 # ifndef USYMTAB_H
10 # define USYMTAB_H
11
12 /*@constant null usymtab GLOBAL_ENV; @*/ 
13 # define GLOBAL_ENV usymtab_undefined
14
15 typedef enum { 
16   US_GLOBAL, 
17   US_NORMAL, 
18   US_TBRANCH, US_FBRANCH, 
19   US_CBRANCH, US_SWITCH
20 } uskind;
21
22 typedef struct { int level; int index; } *refentry;
23 typedef /*@only@*/ refentry o_refentry;
24 typedef o_refentry *refTable;
25
26 struct s_usymtab
27 {
28   uskind   kind;
29   int      nentries;
30   int      nspace;
31   int      lexlevel;
32   bool     mustBreak;
33   exitkind exitCode;
34   /*@reldef@*/ /*@only@*/ o_uentry  *entries;
35   /*@null@*/ /*@only@*/ cstringTable htable;   /* for the global environment */
36   /*@null@*/ /*@only@*/ refTable  reftable; /* for branched environments */
37              /*@only@*/ guardSet  guards;   /* guarded references (not null) */
38   aliasTable aliases;
39   /*@owned@*/ usymtab env;
40 } ; 
41
42 /*
43 ** rep invariant:
44 **
45 ** (left as exercise to reader)  ;) 
46 */
47
48 extern void usymtab_printTypes (void) 
49   /*@globals internalState@*/
50   /*@modifies g_msgstream@*/ ;
51
52 extern void usymtab_setMustBreak (void) /*@modifies internalState@*/ ;
53
54 extern bool usymtab_inGlobalScope (void) /*@globals internalState@*/ ;
55 extern bool usymtab_inFunctionScope (void) /*@globals internalState@*/ ;
56 extern bool usymtab_inFileScope (void) /*@globals internalState@*/ ;
57 extern void usymtab_checkFinalScope (bool p_isReturn) 
58   /*@globals internalState@*/ 
59   /*@modifies *g_msgstream@*/ ;
60
61 extern void usymtab_allUsed (void)
62    /*@globals internalState@*/ 
63    /*@modifies *g_msgstream@*/ ;
64
65 extern void usymtab_allDefined (void)
66    /*@globals internalState@*/
67    /*@modifies *g_msgstream@*/ ;
68
69 extern void usymtab_prepareDump (void)
70    /*@modifies internalState@*/ ;
71
72 extern void usymtab_dump (FILE *p_fout)
73    /*@globals internalState@*/
74    /*@modifies *p_fout@*/ ;
75
76
77 extern void usymtab_load (FILE *p_f) /*@modifies p_f, internalState@*/ ;
78
79 extern /*@exposed@*/ /*@dependent@*/ uentry 
80   usymtab_getRefQuiet (int p_level, usymId p_index)
81   /*@globals internalState@*/ ;
82
83 extern void usymtab_printLocal (void) 
84   /*@globals internalState@*/ 
85   /*@modifies stdout@*/ ;
86
87 extern /*@exposed@*/ /*@dependent@*/ uentry usymtab_getParam (int p_paramno)
88    /*@globals internalState@*/;
89 extern void usymtab_free (void) /*@modifies internalState@*/ ;
90 extern bool usymtab_inDeepScope (void) /*@globals internalState@*/ ;
91
92 extern /*@exposed@*/  uentry usymtab_lookupExpose (cstring p_k)
93    /*@globals internalState@*/ ;
94
95 extern /*@observer@*/ uentry usymtab_lookup (cstring p_k)
96    /*@globals internalState@*/ ;
97
98 # define usymtab_lookup(s) (usymtab_lookupExpose (s))
99
100 extern /*@observer@*/ uentry usymtab_lookupGlob (cstring p_k)
101    /*@globals internalState@*/ ;
102 extern /*@exposed@*/ uentry usymtab_lookupExposeGlob (cstring p_k)
103    /*@globals internalState@*/ ;
104 extern /*@observer@*/ uentry usymtab_lookupUnionTag (cstring p_k)
105    /*@globals internalState@*/ ;
106 extern /*@observer@*/ uentry usymtab_lookupStructTag (cstring p_k)
107    /*@globals internalState@*/ ;
108 extern /*@observer@*/ uentry usymtab_lookupEither (cstring p_k)
109    /*@globals internalState@*/ ;
110
111 # ifndef NOLCL
112 extern ctype usymtab_lookupType (cstring p_k)
113    /*@globals internalState@*/ ;
114 # endif
115
116 extern bool usymtab_isDefinitelyNull (sRef p_s)
117    /*@globals internalState@*/ ;
118 extern bool usymtab_isDefinitelyNullDeep (sRef p_s)
119    /*@globals internalState@*/ ;
120
121 # ifndef NOLCL
122 extern usymId usymtab_supExposedTypeEntry (/*@only@*/ uentry p_e, bool p_dodef)
123    /*@modifies internalState, p_e@*/ ;
124 # endif
125
126 extern ctype usymtab_supTypeEntry (/*@only@*/ uentry p_e)
127    /*@modifies internalState, p_e@*/ ;
128
129 extern /*@exposed@*/ uentry usymtab_supReturnTypeEntry (/*@only@*/ uentry p_e)
130    /*@modifies internalState@*/ ;
131
132 extern /*@observer@*/ uentry usymtab_lookupSafe (cstring p_k)
133    /*@globals internalState@*/ ;
134
135 extern /*@observer@*/ uentry usymtab_getGlobalEntry (usymId p_uid)
136   /*@globals internalState@*/ ;
137
138 extern bool usymtab_exists (cstring p_k)
139    /*@globals internalState@*/ ;
140
141 # ifndef NOLCL
142 extern bool usymtab_existsVar (cstring p_k)
143    /*@globals internalState@*/ ;
144 # endif
145
146 extern bool usymtab_existsGlob (cstring p_k)
147    /*@globals internalState@*/ ;
148
149 extern bool usymtab_existsType (cstring p_k)
150    /*@globals internalState@*/ ;
151
152 # ifndef NOLCL
153 extern bool usymtab_existsEither (cstring p_k)
154    /*@globals internalState@*/ ;
155 # endif
156
157 extern bool usymtab_existsTypeEither (cstring p_k)
158    /*@globals internalState@*/ ;
159
160 extern usymId usymtab_getId (cstring p_k) /*@globals internalState@*/ ;
161 extern usymId usymtab_getTypeId (cstring p_k) /*@globals internalState@*/ ;
162
163 extern void usymtab_supEntry (/*@only@*/ uentry p_e)
164   /*@modifies internalState, p_e@*/ ;
165
166 # ifndef NOLCL
167 extern void usymtab_replaceEntry (/*@only@*/ uentry p_s)
168   /*@modifies internalState, p_s@*/ ;
169 # endif
170
171 extern void usymtab_supEntrySref (/*@only@*/ uentry p_e)
172   /*@modifies internalState, p_e@*/ ;
173
174 extern void usymtab_supGlobalEntry (/*@only@*/ uentry p_e)
175   /*@modifies internalState@*/ ;
176
177 extern void usymtab_addGlobalEntry (/*@only@*/ uentry p_e) 
178   /*@modifies internalState, p_e@*/ ;
179
180 extern /*@exposed@*/ uentry 
181   usymtab_supEntryReturn (/*@only@*/ uentry p_e)
182   /*@modifies internalState, p_e@*/ ;
183
184 extern usymId usymtab_addEntry (/*@only@*/ uentry p_e)
185   /*@modifies internalState, p_e@*/ ;
186
187 extern ctype usymtab_lookupAbstractType (cstring p_k) 
188      /*@globals internalState@*/ /*@modifies nothing@*/ ;
189
190 extern bool usymtab_matchForwardStruct (usymId p_u1, usymId p_u2)
191      /*@globals internalState@*/ ;
192
193 extern bool usymtab_existsEnumTag (cstring p_k)
194   /*@globals internalState@*/ ;
195 extern bool usymtab_existsUnionTag (cstring p_k) 
196   /*@globals internalState@*/ ;
197 extern bool usymtab_existsStructTag (cstring p_k) 
198   /*@globals internalState@*/ ;
199
200 extern usymId usymId_fromInt (int p_i) /*@*/ ;
201 # define usymId_fromInt(i)   ((usymId)(i))
202
203 extern bool usymId_isInvalid (usymId p_u) /*@*/ ;
204 # define usymId_isInvalid(u) ((u) == USYMIDINVALID)
205
206 extern bool usymId_isValid (usymId p_u) /*@*/ ;
207 # define usymId_isValid(u)   ((u) != USYMIDINVALID)
208
209 extern bool typeId_isInvalid (typeId p_u) /*@*/ ;
210 # define typeId_isInvalid(u) ((u) == typeId_invalid)
211
212 extern bool typeId_isValid (typeId p_u) /*@*/ ;
213 # define typeId_isValid(u)   ((u) != typeId_invalid)
214
215 extern bool typeId_equal (typeId p_u1, typeId p_u2) /*@*/ ;
216 # define typeId_equal(u1,u2) ((u1) == (u2))
217
218 extern typeId typeId_fromInt (int p_i);
219 # define typeId_fromInt(i)   ((typeId)(i))
220
221 /*@iter usymtab_entries (sef usymtab u, yield exposed uentry el); @*/
222 # define usymtab_entries(x, m_i)   \
223     { int m_ind; \
224       if (usymtab_isDefined (x)) \
225         for (m_ind = 0; m_ind < (x)->nentries; m_ind++) \
226            { uentry m_i = (x)->entries[m_ind]; 
227
228 # define end_usymtab_entries }}
229
230 extern /*@unused@*/ void usymtab_displayAllUses (void)
231    /*@globals internalState@*/ 
232    /*@modifies *g_msgstream@*/ ;
233
234 extern /*@unused@*/ void usymtab_printOut (void)
235    /*@globals internalState@*/ 
236    /*@modifies *g_msgstream@*/ ;
237
238 extern /*@unused@*/ void usymtab_printAll (void)
239    /*@globals internalState@*/ 
240    /*@modifies *g_msgstream@*/ ;
241
242 extern void usymtab_enterScope (void) 
243   /*@modifies internalState;@*/ ;
244 extern void usymtab_enterFunctionScope (uentry p_fcn) 
245   /*@modifies internalState;@*/ ;
246 extern void usymtab_quietExitScope (fileloc p_loc)
247   /*@modifies internalState;@*/ ;
248 extern void usymtab_exitScope (exprNode p_expr) /*@modifies internalState@*/ ;
249 extern void usymtab_addGuards (guardSet p_guards) /*@modifies internalState@*/ ;
250 extern void usymtab_setExitCode (exitkind p_ex) /*@modifies internalState@*/ ;
251 extern void usymtab_exitFile (void) /*@modifies internalState@*/ ;
252 extern void usymtab_enterFile (void) /*@modifies internalState@*/ ;
253
254 extern /*@observer@*/ uentry usymtab_lookupEnumTag (cstring p_k)
255   /*@globals internalState@*/ ; 
256
257 extern usymId usymtab_convertId (usymId p_uid) /*@globals internalState@*/ ;
258 extern void usymtab_initMod (void) /*@modifies internalState@*/ ;
259 extern void usymtab_initBool (void) /*@modifies internalState@*/ ;
260 extern void usymtab_initGlobalMarker (void) /*@modifies internalState@*/ ;
261
262 extern void usymtab_exportHeader (void)
263    /*@modifies internalState@*/ ;
264
265 extern ctype usymtab_structFieldsType (uentryList p_f)
266    /*@globals internalState@*/ ;
267
268 extern ctype usymtab_unionFieldsType (uentryList p_f)
269    /*@globals internalState@*/ ;
270
271 extern ctype usymtab_enumEnumNameListType (enumNameList p_f)
272    /*@globals internalState@*/ ;
273
274 extern /*@exposed@*/ uentry usymtab_getTypeEntrySafe (typeId p_uid)
275    /*@globals internalState@*/ ;
276
277 extern void usymtab_popOrBranch (exprNode p_pred, exprNode p_expr)
278   /*@modifies internalState@*/ ;
279 extern void usymtab_popAndBranch (exprNode p_pred, exprNode p_expr)
280   /*@modifies internalState@*/ ;
281
282 extern void usymtab_trueBranch (/*@only@*/ guardSet p_guards)
283   /*@modifies internalState@*/ ;
284 extern void usymtab_altBranch (/*@only@*/ guardSet p_guards)
285   /*@modifies internalState@*/ ;
286
287 extern void usymtab_popTrueBranch (exprNode p_pred, exprNode p_expr, clause p_cl)
288   /*@modifies internalState@*/ ;
289
290 extern void
291   usymtab_popTrueExecBranch (exprNode p_pred, exprNode p_expr, clause p_cl)
292   /*@modifies internalState@*/ ;
293
294 extern void 
295   usymtab_popBranches (exprNode p_pred, exprNode p_tbranch, exprNode p_fbranch, 
296                        bool p_isOpt, clause p_cl)
297    /*@modifies internalState@*/ ;
298
299 extern void usymtab_unguard (sRef p_s) /*@modifies internalState@*/ ;
300 extern bool usymtab_isGuarded (sRef p_s) /*@globals internalState@*/ ;
301 extern void usymtab_printGuards (void) /*@globals internalState@*/ /*@modifies *g_msgstream@*/ ;
302 extern void usymtab_quietPlainExitScope (void) /*@modifies internalState@*/ ;
303 extern void usymtab_printComplete (void) /*@globals internalState@*/ /*@modifies *stdout@*/ ;
304
305 # ifndef NOLCL
306 extern bool usymtab_existsGlobEither (cstring p_k) /*@globals internalState@*/ ;
307 # endif
308
309 extern bool usymtab_isBoolType (typeId p_uid) /*@globals internalState@*/ ;
310 extern /*@only@*/ cstring usymtab_getTypeEntryName (typeId p_uid)
311   /*@globals internalState@*/ ;
312 extern /*@exposed@*/ uentry usymtab_getTypeEntry (typeId p_uid)
313   /*@globals internalState@*/ ;
314
315 extern typeId
316   usymtab_supAbstractTypeEntry (/*@only@*/ uentry p_e, bool p_dodef)
317   /*@modifies internalState, p_e@*/ ;
318 extern ctype usymtab_supForwardTypeEntry (/*@only@*/ uentry p_e)
319   /*@modifies internalState, p_e@*/ ;
320
321 extern /*@exposed@*/ uentry 
322   usymtab_supGlobalEntryReturn (/*@only@*/ uentry p_e)
323   /*@modifies internalState, p_e@*/ ;
324
325 extern /*@exposed@*/ uentry 
326   usymtab_supEntrySrefReturn (/*@only@*/ uentry p_e)
327   /*@modifies internalState, p_e@*/ ;
328
329 extern int uentry_directParamNo (uentry p_ue)
330   /*@globals internalState@*/ ;
331
332 extern bool usymtab_newCase (exprNode p_pred, exprNode p_last)
333   /*@modifies internalState@*/ ;
334
335 extern void usymtab_switchBranch (exprNode p_s) 
336   /*@modifies internalState@*/ ;
337
338 extern /*@only@*/ cstring usymtab_unparseStack (void)
339   /*@globals internalState@*/ ;
340 extern void usymtab_exitSwitch (exprNode p_sw, bool p_allpaths)
341   /*@modifies internalState@*/ ;
342
343 extern /*@observer@*/ uentry usymtab_lookupGlobSafe (cstring p_k)
344   /*@globals internalState@*/ ;
345
346 extern /*@only@*/ sRefSet usymtab_aliasedBy (sRef p_s)
347   /*@globals internalState@*/ ;
348
349 extern /*@only@*/ sRefSet usymtab_canAlias (sRef p_s)
350   /*@globals internalState@*/ ;
351
352 extern void usymtab_clearAlias (sRef p_s)
353   /*@modifies internalState, p_s@*/ ;
354
355 extern void usymtab_addMustAlias (/*@exposed@*/ sRef p_s, /*@exposed@*/ sRef p_al)
356   /*@modifies internalState@*/ ;
357
358 extern void usymtab_addForceMustAlias (/*@exposed@*/ sRef p_s, /*@exposed@*/ sRef p_al)
359   /*@modifies internalState@*/ ;
360
361 extern /*@only@*/ cstring usymtab_unparseAliases (void)
362   /*@globals internalState@*/ ;
363
364 extern /*@exposed@*/ uentry
365   usymtab_supReturnFileEntry (/*@only@*/ uentry p_e)
366    /*@modifies internalState@*/ ;
367
368 extern bool usymtab_isAltDefinitelyNullDeep (sRef p_s)
369    /*@globals internalState@*/ ;
370
371 extern bool usymtab_existsReal (cstring p_k)
372    /*@globals internalState@*/ ;
373
374 extern /*@only@*/ sRefSet usymtab_allAliases (sRef p_s)
375    /*@globals internalState@*/ ;
376
377 extern void usymtab_exportLocal (void)
378    /*@modifies internalState@*/ ;
379
380 extern void usymtab_popCaseBranch (void)
381      /*@modifies internalState@*/ ;
382
383 /* special scopes */
384
385 /*@constant int globScope;@*/
386 # define globScope 0  /* global variables */
387
388 /*@constant int fileScope;@*/
389 # define fileScope   1  /* file-level static variables */
390
391 /*@constant int paramsScope;@*/
392 # define paramsScope 2  /* function parameters */
393
394 /*@constant int functionScope;@*/
395 # define functionScope 3
396
397 extern /*@falsenull@*/ bool usymtab_isDefined (usymtab p_u) /*@*/ ;
398
399 /*@constant null usymtab usymtab_undefined; @*/
400 # define usymtab_undefined ((usymtab)NULL)
401 # define usymtab_isDefined(u) ((u) != usymtab_undefined)
402
403 extern void usymtab_checkDistinctName (uentry p_e, int p_scope)
404   /*@globals internalState@*/
405   /*@modifies *g_msgstream, p_e@*/ ;
406
407 extern /*@exposed@*/ sRef usymtab_lookupGlobalMarker (void) /*@globals internalState@*/ ;
408
409 extern int usymtab_getCurrentDepth (void) /*@globals internalState@*/ ;
410
411 # else
412 # error "Multiple include"
413 # endif
414
415
416
This page took 0.087826 seconds and 5 git commands to generate.