4 #include "constraint.h"
9 Element::Element(ASTNodeType _type) :
15 ElementSet::ElementSet(Set *s) :
20 ElementSet::ElementSet(ASTNodeType _type, Set *s) :
25 ElementFunction::ElementFunction(Function *_function, Element **array, uint numArrays, BooleanEdge _overflowstatus) :
26 Element(ELEMFUNCRETURN),
27 inputs(array, numArrays),
28 overflowstatus(_overflowstatus),
29 functionencoding(this),
33 ElementConst::ElementConst(uint64_t _value, Set *_set) :
34 ElementSet(ELEMCONST, _set),
38 Element *ElementConst::clone(CSolver *solver, CloneMap *map) {
39 Element *e = solver->getElementConst(type, value);
40 e->anyValue = anyValue;
44 Element *ElementSet::clone(CSolver *solver, CloneMap *map) {
45 Element *e = (Element *) map->get(this);
48 e = solver->getElementVar(set->clone(solver, map));
50 e->anyValue = anyValue;
54 Element *ElementFunction::clone(CSolver *solver, CloneMap *map) {
55 Element *array[inputs.getSize()];
56 for (uint i = 0; i < inputs.getSize(); i++) {
57 array[i] = inputs.get(i)->clone(solver, map);
59 BooleanEdge ofstatus = overflowstatus ? cloneEdge(solver, map, overflowstatus) : BooleanEdge();
60 Element *e = solver->applyFunction(function->clone(solver, map), array, inputs.getSize(), ofstatus);
61 e->anyValue = anyValue;
65 void ElementFunction::updateParents() {
66 for (uint i = 0; i < inputs.getSize(); i++) inputs.get(i)->parents.push(this);
68 overflowstatus->parents.push(this);
71 Set *ElementFunction::getRange() {
72 return function->getRange();
75 void ElementSet::serialize(Serializer *serializer) {
76 if (serializer->isSerialized(this))
78 serializer->addObject(this);
80 set->serialize(serializer);
82 serializer->mywrite(&type, sizeof(ASTNodeType));
83 serializer->mywrite(&anyValue, sizeof(bool));
84 ElementSet *This = this;
85 serializer->mywrite(&This, sizeof(ElementSet *));
86 serializer->mywrite(&set, sizeof(Set *));
89 void ElementSet::print() {
90 model_print("{ElementSet<%p>:", this);
92 model_print(" %p ", this);
93 getElementEncoding()->print();
97 void ElementConst::serialize(Serializer *serializer) {
98 if (serializer->isSerialized(this))
100 serializer->addObject(this);
102 set->serialize(serializer);
104 serializer->mywrite(&type, sizeof(ASTNodeType));
105 serializer->mywrite(&anyValue, sizeof(bool));
106 ElementSet *This = this;
107 serializer->mywrite(&This, sizeof(ElementSet *));
108 VarType type = set->getType();
109 serializer->mywrite(&type, sizeof(VarType));
110 serializer->mywrite(&value, sizeof(uint64_t));
113 void ElementConst::print() {
114 model_print("{ElementConst<%p>: %" PRIu64 "}\n", this, value);
117 void ElementFunction::serialize(Serializer *serializer) {
118 if (serializer->isSerialized(this))
120 serializer->addObject(this);
122 function->serialize(serializer);
123 uint size = inputs.getSize();
124 for (uint i = 0; i < size; i++) {
125 Element *input = inputs.get(i);
126 input->serialize(serializer);
128 serializeBooleanEdge(serializer, overflowstatus);
130 serializer->mywrite(&type, sizeof(ASTNodeType));
131 serializer->mywrite(&anyValue, sizeof(bool));
132 ElementFunction *This = this;
133 serializer->mywrite(&This, sizeof(ElementFunction *));
134 serializer->mywrite(&function, sizeof(Function *));
135 serializer->mywrite(&size, sizeof(uint));
136 for (uint i = 0; i < size; i++) {
137 Element *input = inputs.get(i);
138 serializer->mywrite(&input, sizeof(Element *));
140 Boolean *overflowstat = overflowstatus.getRaw();
141 serializer->mywrite(&overflowstat, sizeof(Boolean *));
144 void ElementFunction::print() {
145 model_print("{ElementFunction<%p>:\n", this);
147 model_print("OverFlow Boolean Flag:\n");
148 overflowstatus.getBoolean()->print();
149 model_print("Range:\n");
151 model_print("Elements:\n");
152 uint size = inputs.getSize();
153 for (uint i = 0; i < size; i++) {
154 Element *input = inputs.get(i);