adding config for model_print
[satune.git] / src / AST / function.h
index 2cd5ccae7f7ef699cfa2b5c3ea080e11ac912069..b8d0c78267cd22d4850b342d93a71fed303d56fd 100644 (file)
@@ -3,16 +3,19 @@
 #include "classlist.h"
 #include "mymemory.h"
 #include "ops.h"
+#include "astops.h"
 #include "structs.h"
 
-#define GETFUNCTIONTYPE(o) (((Function *)o)->type)
-
 class Function {
 public:
        Function(FunctionType _type) : type(_type) {}
        FunctionType type;
-       MEMALLOC;
        virtual ~Function() {}
+       virtual Function *clone(CSolver *solver, CloneMap *map) {ASSERT(0); return NULL;}
+       virtual void serialize(Serializer* serialiezr) =0;
+        virtual void print() = 0;
+       virtual Set * getRange() = 0;
+       CMEMALLOC;
 };
 
 class FunctionOperator : public Function {
@@ -24,7 +27,11 @@ public:
        FunctionOperator(ArithOp op, Set **domain, uint numDomain, Set *range, OverFlowBehavior overflowbehavior);
        uint64_t applyFunctionOperator(uint numVals, uint64_t *values);
        bool isInRangeFunction(uint64_t val);
-       MEMALLOC;
+       Function *clone(CSolver *solver, CloneMap *map);
+       virtual void serialize(Serializer* serialiezr);
+        virtual void print();
+       Set * getRange() {return range;}
+       CMEMALLOC;
 };
 
 class FunctionTable : public Function {
@@ -32,7 +39,11 @@ public:
        Table *table;
        UndefinedBehavior undefBehavior;
        FunctionTable (Table *table, UndefinedBehavior behavior);
-       MEMALLOC;
+       Function *clone(CSolver *solver, CloneMap *map);
+       virtual void serialize(Serializer* serialiezr);
+        virtual void print();
+       Set * getRange();
+       CMEMALLOC;
 };
 
 #endif