Don't try calling lsl when file is missing.
[splint-patched.git] / src / stateCombinationTable.c
blob2af779f43606e7d3bb45a1edff233fb0d46f2925
1 /*
2 ** Splint - annotation-assisted static program checker
3 ** Copyright (C) 1994-2003 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.
20 ** For information on splint: info@splint.org
21 ** To report a bug: splint-bug@splint.org
22 ** For more information: http://www.splint.org
25 ** stateCombinationTable.c
27 ** A stateCombinationTable is a mapping from keys to value tables.
30 # include "splintMacros.nf"
31 # include "basic.h"
34 ** (key, value, value) => value
37 static stateEntry stateEntry_create (void)
39 stateEntry res = (stateEntry) dmalloc (sizeof (*res));
40 res->value = 0;
41 res->msg = cstring_undefined;
42 return res;
45 static cstring stateEntry_unparse (stateEntry e)
47 if (cstring_isDefined (e->msg))
49 return message ("[%d: %s]", e->value, e->msg);
51 else
53 return message ("%d", e->value);
57 stateCombinationTable stateCombinationTable_create (int size)
59 stateCombinationTable res = (stateCombinationTable) dmalloc (sizeof (*res));
60 int i;
62 res->size = size;
63 res->rows = (stateRow *) dmalloc (sizeof (*(res->rows)) * size);
65 for (i = 0; i < size; i++)
67 int j;
69 res->rows[i] = (stateRow) dmalloc (sizeof (*res->rows[i]));
70 res->rows[i]->size = size;
72 /* Rows have an extra entry (for lose ref transfers) */
73 res->rows[i]->entries = (stateEntry *)
74 dmalloc (sizeof (*res->rows[i]->entries) * (size + 1));
76 for (j = 0; j < size + 1; j++)
78 stateEntry s = stateEntry_create ();
80 /* Default transfer changes no state and is permitted without error. */
82 s->value = i;
83 llassert (cstring_isUndefined (s->msg));
85 /*@-usedef@*/
86 res->rows[i]->entries[j] = s;
87 /*@=usedef@*/
91 /*@-compmempass@*/ /*@-compdef@*/
92 return res;
93 /*@=compmempass@*/ /*@=compdef@*/
96 cstring stateCombinationTable_unparse (stateCombinationTable t)
98 int i;
99 cstring res = cstring_newEmpty ();
101 for (i = 0; i < t->size; i++)
103 int j;
105 for (j = 0; j < (t->size + 1); j++)
107 if (j == 0)
109 res = message ("%q[%d: ] %q", res, i,
110 stateEntry_unparse (t->rows[i]->entries[j]));
112 else
114 res = message ("%q . %q", res,
115 stateEntry_unparse (t->rows[i]->entries[j]));
119 res = cstring_appendChar (res, '\n');
122 return res;
125 static void stateEntry_free (/*@only@*/ stateEntry s)
127 cstring_free (s->msg);
128 sfree (s);
131 static void stateRow_free (/*@only@*/ stateRow r)
133 int i;
135 for (i = 0; i < r->size + 1; i++)
137 stateEntry_free (r->entries[i]);
140 sfree (r->entries);
141 sfree (r);
144 void stateCombinationTable_free (/*@only@*/ stateCombinationTable t)
146 int i;
148 for (i = 0; i < t->size; i++) {
149 stateRow_free (t->rows[i]);
152 sfree (t->rows);
153 sfree (t);
156 static /*@exposed@*/ stateEntry
157 stateCombintationTable_getEntry (stateCombinationTable h,
158 int rkey, int ckey)
160 llassert (rkey < h->size);
161 llassert (ckey < h->size + 1);
163 return h->rows[rkey]->entries[ckey];
166 void stateCombinationTable_set (stateCombinationTable h,
167 int p_from, int p_to,
168 int value, cstring msg)
170 stateEntry entry = stateCombintationTable_getEntry (h, p_from, p_to);
172 llassert (entry != NULL);
174 entry->value = value;
175 llassert (cstring_isUndefined (entry->msg));
176 entry->msg = msg;
178 DPRINTF (("Set entry: [%p] %d / %d => %s", entry,
179 p_from, p_to, cstring_toCharsSafe (msg)));
184 ** Like set, but may already have value.
185 ** (Only different is error checking.)
188 void stateCombinationTable_update (stateCombinationTable h,
189 int p_from, int p_to,
190 int value, cstring msg)
192 stateEntry entry = stateCombintationTable_getEntry (h, p_from, p_to);
194 llassert (entry != NULL);
196 entry->value = value;
197 cstring_free (entry->msg);
198 entry->msg = msg;
200 DPRINTF (("Update entry: [%p] %d / %d => %s", entry,
201 p_from, p_to, cstring_toCharsSafe (msg)));
204 int stateCombinationTable_lookup (stateCombinationTable h, int p_from, int p_to, /*@out@*/ ob_cstring *msg)
206 stateEntry entry;
207 llassert (p_from != stateValue_error);
208 llassert (p_to != stateValue_error);
210 entry = stateCombintationTable_getEntry (h, p_from, p_to);
211 llassert (entry != NULL);
213 *msg = entry->msg;
214 return entry->value;