adding config for model_print
[satune.git] / src / AST / function.h
index 914c43991926482ffb48886e5b2215625a236e9c..b8d0c78267cd22d4850b342d93a71fed303d56fd 100644 (file)
@@ -3,36 +3,47 @@
 #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) {}
+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 {
- public:
+public:
        ArithOp op;
-       ArraySet domains;
+       Array<Set *> domains;
        Set *range;
        OverFlowBehavior overflowbehavior;
        FunctionOperator(ArithOp op, Set **domain, uint numDomain, Set *range, OverFlowBehavior overflowbehavior);
        uint64_t applyFunctionOperator(uint numVals, uint64_t *values);
        bool isInRangeFunction(uint64_t val);
-       ~FunctionOperator();
-       MEMALLOC;
+       Function *clone(CSolver *solver, CloneMap *map);
+       virtual void serialize(Serializer* serialiezr);
+        virtual void print();
+       Set * getRange() {return range;}
+       CMEMALLOC;
 };
 
 class FunctionTable : public Function {
- public:
+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