}
Boolean *BooleanOrder::clone(CSolver *solver, CloneMap *map) {
- Boolean *b = (Boolean *) map->get(this);
- if (b != NULL)
- return b;
Order *ordercopy = order->clone(solver, map);
- b= solver->orderConstraint(ordercopy, first, second).getRaw();
- map->put(this, b);
- return b;
+ return solver->orderConstraint(ordercopy, first, second).getRaw();
}
Boolean *BooleanLogic::clone(CSolver *solver, CloneMap *map) {
- Boolean *b = (Boolean *) map->get(this);
- if (b != NULL)
- return b;
BooleanEdge array[inputs.getSize()];
for (uint i = 0; i < inputs.getSize(); i++) {
array[i] = cloneEdge(solver, map, inputs.get(i));
}
- b= solver->applyLogicalOperation(op, array, inputs.getSize()).getRaw();
- map->put(this, b);
- return b;
+ return solver->applyLogicalOperation(op, array, inputs.getSize()).getRaw();
}
Boolean *BooleanPredicate::clone(CSolver *solver, CloneMap *map) {
- Boolean *b = (Boolean *) map->get(this);
- if (b != NULL)
- return b;
Element *array[inputs.getSize()];
for (uint i = 0; i < inputs.getSize(); i++) {
array[i] = inputs.get(i)->clone(solver, map);
Predicate *pred = predicate->clone(solver, map);
BooleanEdge defstatus = undefStatus ? cloneEdge(solver, map, undefStatus) : BooleanEdge();
- b= solver->applyPredicateTable(pred, array, inputs.getSize(), defstatus).getRaw();
- map->put(this, b);
- return b;
+ return solver->applyPredicateTable(pred, array, inputs.getSize(), defstatus).getRaw();
}
void BooleanPredicate::updateParents() {
}
Element *ElementConst::clone(CSolver *solver, CloneMap *map) {
- Element *e = (Element *) map->get(this);
- if (e != NULL)
- return e;
- e= solver->getElementConst(type, value);
- map->put(this,e);
- return e;
+ return solver->getElementConst(type, value);
}
Element *ElementSet::clone(CSolver *solver, CloneMap *map) {
}
Element *ElementFunction::clone(CSolver *solver, CloneMap *map) {
- Element *e = (Element *) map->get(this);
- if (e != NULL)
- return e;
Element *array[inputs.getSize()];
for (uint i = 0; i < inputs.getSize(); i++) {
array[i] = inputs.get(i)->clone(solver, map);
}
- e = solver->applyFunction(function->clone(solver, map), array, inputs.getSize(), overflowstatus->clone(solver, map));
- map->put(this,e);
+ Element *e = solver->applyFunction(function->clone(solver, map), array, inputs.getSize(), overflowstatus->clone(solver, map));
return e;
}