]> andersk Git - splint.git/blobdiff - src/Headers/constraintTerm.h
Changes to fix malloc size problem.
[splint.git] / src / Headers / constraintTerm.h
index be1c39e4b60595ef3dc006e7f41aff0d9317ea04..1ecd622d62f45dfac1d7f0806a147788623b68b9 100644 (file)
@@ -1,24 +1,83 @@
+#ifndef __constraintTerm_h__
 
-constraintTerm constraintTerm_copy (constraintTerm term);
+#define __constraintTerm_h__
 
-constraintTerm exprNode_makeConstraintTerm (/*@only@*/ exprNode e);
+typedef union
+{
+  /*@exposed@*/ /*@dependent@*/ exprNode expr;
+  /*@only@*/  sRef     sref;
+  long intlit;
+} constraintTermValue;
 
-constraintTerm constraintTerm_makeMaxSetexpr (exprNode e);
+typedef enum
+{
+  CTT_ERRORBADCONSTRAINTTERMTYPE,
+  CTT_EXPR, 
+  CTT_SREF,
+  CTT_INTLITERAL
+} constraintTermType;
 
-constraintTerm constraintTerm_makeMinSetexpr (exprNode e);
+struct s_constraintTerm {
+  /*@only@*/ fileloc loc;
+  constraintTermValue value;
+  constraintTermType kind;
+} ;
 
-constraintTerm constraintTerm_makeMaxReadexpr (exprNode e);
+abst_typedef struct s_constraintTerm *constraintTerm;
 
-constraintTerm constraintTerm_makeMinReadexpr (exprNode e);
 
-constraintTerm constraintTerm_makeValueexpr (exprNode e);
+extern bool constraintTerm_isDefined (constraintTerm p_t) /*@*/ ;
 
-constraintTerm intLit_makeConstraintTerm (int i);
+extern constraintTermType constraintTerm_getKind (constraintTerm) ;
+extern /*@exposed@*/ sRef constraintTerm_getSRef (constraintTerm) ;
 
-constraintTerm constraintTerm_makeIntLitValue (int i);
+void constraintTerm_free (/*@only@*/ constraintTerm p_term);
 
-cstring  constraintType_print (constraintType constrType);
+constraintTerm constraintTerm_simplify (/*@returned@*/ constraintTerm p_term) /*@modifies p_term@*/ ;
 
-cstring constraintTerm_print (constraintTerm term);
+/*@only@*/ constraintTerm constraintTerm_makeExprNode (/*@dependent@*/ exprNode p_e) /*@*/;
 
+constraintTerm constraintTerm_copy (constraintTerm p_term) /*@*/;
 
+bool constraintTerm_similar (constraintTerm p_term1, constraintTerm p_term2) /*@*/;
+
+extern bool constraintTerm_canGetValue (constraintTerm p_term)/*@*/;
+extern long constraintTerm_getValue (constraintTerm p_term) /*@*/;
+extern void constraintTerm_setValue (constraintTerm p_term, long p_value) /*@modifies p_term@*/;
+
+extern fileloc constraintTerm_getFileloc (constraintTerm p_t) /*@*/;
+
+extern bool constraintTerm_isIntLiteral (constraintTerm p_term) /*@*/;
+
+extern constraintTerm constraintTerm_makesRef  (/*@temp@*/ /*@observer@*/ sRef p_s) /*@*/;
+
+/*@unused@*/ bool constraintTerm_probSame (constraintTerm p_term1, constraintTerm p_term2) /*@*/;
+
+constraintTerm constraintTerm_setFileloc (/*@returned@*/ constraintTerm p_term, fileloc p_loc) /*@modifies p_term@*/;
+
+constraintTerm constraintTerm_makeIntLiteral (long p_i) /*@*/;
+
+bool constraintTerm_isStringLiteral (constraintTerm p_c) /*@*/;
+cstring constraintTerm_getStringLiteral (constraintTerm p_c) /*@*/;
+
+
+constraintTerm constraintTerm_doSRefFixBaseParam (/*@returned@*/ constraintTerm p_term, exprNodeList p_arglist) /*@modifies p_term@*/;
+
+extern cstring constraintTerm_unparse (constraintTerm)  /*@*/ ;
+
+extern void constraintTerm_dump ( /*@observer@*/ constraintTerm p_t,  FILE * p_f);
+extern /*@only@*/ constraintTerm constraintTerm_undump ( FILE * p_f);
+extern bool constraintTerm_isInitBlock (/*@observer@*/ /*@temp@*/ constraintTerm p_c) /*@*/;
+extern int constraintTerm_getInitBlockLength (/*@observer@*/ /*@temp@*/ constraintTerm p_c) /*@*/;
+extern bool constraintTerm_isExprNode (/*@observer@*/ /*@temp@*/ constraintTerm p_c) /*@*/;
+extern ctype constraintTerm_getCType (constraintTerm p_term);
+
+extern /*@exposed@*/ exprNode constraintTerm_getExprNode (constraintTerm p_t);
+extern /*@exposed@*/ sRef constraintTerm_getsRef (constraintTerm p_t);
+
+/*drl added 12/19/2002*/
+extern bool constraintTerm_isConstantOnly (constraintTerm p_term);
+     
+#else
+#error "Multiple Include!"
+#endif
This page took 0.040851 seconds and 4 git commands to generate.