memoize timeouts
[satune.git] / src / AST / function.h
index 0ed79cec7a09058f06be76ffd58c9582711df20f..2d65f61a009d0e4d6d744b527bbb7aadf37edf21 100644 (file)
@@ -3,30 +3,34 @@
 #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) {ASSERT(0); return NULL;}
-       MEMALLOC;
+       virtual void serialize(Serializer *serialiezr) = 0;
+       virtual void print() = 0;
+       virtual Set *getRange() = 0;
+       CMEMALLOC;
 };
 
 class FunctionOperator : public Function {
 public:
        ArithOp op;
-       Array<Set *> domains;
        Set *range;
        OverFlowBehavior overflowbehavior;
-       FunctionOperator(ArithOp op, Set **domain, uint numDomain, Set *range, OverFlowBehavior overflowbehavior);
+       FunctionOperator(ArithOp op, Set *range, OverFlowBehavior overflowbehavior);
        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 +39,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