]> andersk Git - splint.git/blob - src/constraintExprData.c
24a064b7508c8887fdff4055468e37a4ea55c922
[splint.git] / src / constraintExprData.c
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.
19 **
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
23 */
24
25 /*
26 ** constraintExprData.c
27 */
28
29 # include "splintMacros.nf"
30 # include "basic.h"
31 # include "cgrammar.h"
32 # include "cgrammar_tokens.h"
33
34 # include "exprChecks.h"
35 # include "exprNodeSList.h"
36
37 static /*@out@*/ constraintExprData constraintExprData_alloc (void)
38 {
39   constraintExprData ret;
40
41   ret = dmalloc (sizeof (*ret) );
42
43   return ret;
44 }
45
46 static /*@out@*/ constraintExprData constraintExprData_allocBinaryOp (void)
47 {
48   constraintExprData ret;
49
50   ret = constraintExprData_alloc();
51
52   ret->binaryOp.expr1 = constraintExpr_undefined;
53   ret->binaryOp.expr2 = constraintExpr_undefined;
54
55   return ret;
56 }
57
58 static /*@out@*/ constraintExprData constraintExprData_allocUnaryOp (void)
59 {
60   constraintExprData ret;
61
62   ret = constraintExprData_alloc();
63
64   ret->unaryOp.expr = constraintExpr_undefined;
65
66   return ret;
67 }
68
69 static /*@out@*/ constraintExprData constraintExprData_allocTerm (void)
70 {
71   constraintExprData ret;
72
73   ret = constraintExprData_alloc();
74
75   ret->term = NULL;
76   return ret;
77 }
78
79
80 void constraintExprData_freeBinaryExpr (/*@only@*/constraintExprData data)
81 {
82   constraintExpr_free (data->binaryOp.expr1);
83   constraintExpr_free (data->binaryOp.expr2);
84   free(data);  
85 }
86
87 constraintExprData constraintExprData_copyBinaryExpr(/*@observer@*/ constraintExprData data)
88 {
89   constraintExprData ret;
90   llassert(constraintExprData_isDefined(data));
91
92   ret = constraintExprData_allocBinaryOp();
93   
94   ret->binaryOp.binaryOp = data->binaryOp.binaryOp;
95   ret->binaryOp.expr1 = constraintExpr_copy (data->binaryOp.expr1);
96   ret->binaryOp.expr2 = constraintExpr_copy (data->binaryOp.expr2);
97   return ret;
98 }
99
100 void constraintExprData_freeUnaryExpr (/*@only@*/constraintExprData data)
101 {
102   constraintExpr_free (data->unaryOp.expr);
103   free(data);  
104 }
105
106 constraintExprData constraintExprData_copyUnaryExpr(/*@observer@*/ constraintExprData data)
107 {
108  constraintExprData ret;
109   llassert(constraintExprData_isDefined(data));
110
111   ret = constraintExprData_allocUnaryOp();
112   
113   ret->unaryOp.unaryOp = data->unaryOp.unaryOp;
114   ret->unaryOp.expr = constraintExpr_copy (data->unaryOp.expr);
115   
116   return ret;
117 }
118
119 void constraintExprData_freeTerm (/*@only@*/constraintExprData data)
120 {
121   constraintTerm_free (data->term);
122   free(data);  
123 }
124
125
126 constraintExprData constraintExprData_copyTerm (/*@observer@*/ constraintExprData data)
127 {
128  constraintExprData ret;
129   llassert(constraintExprData_isDefined(data));
130
131   ret = constraintExprData_allocTerm();
132
133   ret->term = constraintTerm_copy (data->term);
134   return ret;
135 }
136
137 constraintExprData constraintExprData_termSetTerm (/*@returned@*/  constraintExprData data,  /*@only@*/constraintTerm term)
138 {
139   llassert (constraintExprData_isDefined(data));
140
141   if (constraintTerm_isDefined(data->term) )
142     constraintTerm_free(data->term);
143
144   data->term = term;
145   return data;
146 }
147
148
149
150 /*@observer@*/ constraintTerm constraintExprData_termGetTerm (/*@observer@*/ constraintExprData data)
151 {
152   llassert (constraintExprData_isDefined(data));
153   /*@i22*/
154   return data->term;
155 }
156
157
158 constraintExprUnaryOpKind constraintExprData_unaryExprGetOp (/*@observer@*/ constraintExprData data)
159 {
160   llassert (constraintExprData_isDefined(data));
161   return (data->unaryOp.unaryOp);
162 }
163
164
165 constraintExpr  constraintExprData_unaryExprGetExpr (/*@observer@*/ constraintExprData data)
166 {
167   llassert (constraintExprData_isDefined (data));
168   return (data->unaryOp.expr);
169 }
170
171
172
173 constraintExprData constraintExprData_unaryExprSetOp ( /*@returned@*/ constraintExprData data, constraintExprUnaryOpKind op)
174 {
175   llassert (constraintExprData_isDefined (data));
176   
177   data->unaryOp.unaryOp = op;
178   return data;
179 }
180
181 constraintExprData  constraintExprData_unaryExprSetExpr (constraintExprData data, /*@only@*/ constraintExpr expr)
182 {
183   llassert (constraintExprData_isDefined(data));
184
185   if (constraintExpr_isDefined(data->unaryOp.expr) )
186     constraintExpr_free(data->unaryOp.expr);
187   
188   data->unaryOp.expr = expr;
189   return data;
190 }
191
192 /*
193 ** binaryExpr stuff
194 */
195
196 constraintExprBinaryOpKind  constraintExprData_binaryExprGetOp (constraintExprData data)
197 {
198   llassert (constraintExprData_isDefined(data));
199   
200   return (data->binaryOp.binaryOp);
201 }
202
203
204 constraintExpr  constraintExprData_binaryExprGetExpr1 (constraintExprData data)
205 {
206   llassert (constraintExprData_isDefined(data));
207
208
209   return (data->binaryOp.expr1);
210 }
211
212
213 constraintExpr  constraintExprData_binaryExprGetExpr2 (constraintExprData data)
214 {
215   llassert (constraintExprData_isDefined(data));
216   /*@i22*/ 
217   return (data->binaryOp.expr2);
218 }
219
220
221 constraintExprData  constraintExprData_binaryExprSetExpr1 (  /*@returned@*/ constraintExprData data, /*@only@*/ constraintExpr expr)
222 {
223   llassert (constraintExprData_isDefined(data));
224
225   if (constraintExpr_isDefined(data->binaryOp.expr1) )
226     constraintExpr_free(data->binaryOp.expr1);
227   
228   data->binaryOp.expr1 = expr;
229   return data;
230 }
231
232 constraintExprData  constraintExprData_binaryExprSetExpr2 (constraintExprData data, constraintExpr expr) 
233 {
234   llassert (constraintExprData_isDefined(data));
235   if (constraintExpr_isDefined(data->binaryOp.expr2) )
236     constraintExpr_free(data->binaryOp.expr2);
237
238   data->binaryOp.expr2 = expr;
239   return data;
240 }
241
242
243 constraintExprData  constraintExprData_binaryExprSetOp (constraintExprData data, constraintExprBinaryOpKind op)
244 {
245   llassert (constraintExprData_isDefined(data));
246   data->binaryOp.binaryOp = op;
247   return data;
248 }
249
This page took 0.04296 seconds and 3 git commands to generate.