adding config for model_print
[satune.git] / src / AST / function.h
index 6b0cd134f4660663e4d59e24f959f9a42a6e0029..b8d0c78267cd22d4850b342d93a71fed303d56fd 100644 (file)
@@ -3,17 +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;
        virtual ~Function() {}
-       virtual Function *clone(CSolver *solver, CloneMap *map);
-       MEMALLOC;
+       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 {
@@ -26,7 +28,10 @@ public:
        uint64_t applyFunctionOperator(uint numVals, uint64_t *values);
        bool isInRangeFunction(uint64_t val);
        Function *clone(CSolver *solver, CloneMap *map);
-       MEMALLOC;
+       virtual void serialize(Serializer* serialiezr);
+        virtual void print();
+       Set * getRange() {return range;}
+       CMEMALLOC;
 };
 
 class FunctionTable : public Function {
@@ -35,7 +40,10 @@ public:
        UndefinedBehavior undefBehavior;
        FunctionTable (Table *table, UndefinedBehavior behavior);
        Function *clone(CSolver *solver, CloneMap *map);
-       MEMALLOC;
+       virtual void serialize(Serializer* serialiezr);
+        virtual void print();
+       Set * getRange();
+       CMEMALLOC;
 };
 
 #endif