Edits to merge
[satune.git] / src / AST / boolean.cc
index 1795f17f3de32f07e48fd5d0a27808707499dd91..fff3658abb16bc404bd0d40f8c3f9c6db5d593aa 100644 (file)
@@ -109,11 +109,20 @@ void BooleanVar::serialize(Serializer* serializer){
        serializer->mywrite(&vtype, sizeof(VarType));
 }
 
+void BooleanVar::print(){
+       model_print("BooleanVar:%lu\n", (uintptr_t)this);
+}
+
+void BooleanConst::print(){
+       model_print("BooleanConst:%s\n", istrue?"TRUE" :"FALSE");
+}
+
 void BooleanOrder::serialize(Serializer* serializer){
        if(serializer->isSerialized(this))
                return;
        serializer->addObject(this);
        order->serialize(serializer);
+       
        serializer->mywrite(&type, sizeof(ASTNodeType));
        BooleanOrder* This = this;
        serializer->mywrite(&This, sizeof(BooleanOrder*));
@@ -122,10 +131,81 @@ void BooleanOrder::serialize(Serializer* serializer){
        serializer->mywrite(&second, sizeof(uint64_t));
 }
 
+void BooleanOrder::print(){
+       model_print("{BooleanOrder: First= %lu, Second = %lu on Order:\n", first, second);
+       order->print();
+       model_print("}\n");
+}
+
 void BooleanPredicate::serialize(Serializer* serializer){
-       ASSERT(0);
+       if(serializer->isSerialized(this))
+               return;
+       serializer->addObject(this);
+       
+       predicate->serialize(serializer);
+       uint size = inputs.getSize();
+       for(uint i=0; i<size; i++){
+               Element* input = inputs.get(i);
+               input->serialize(serializer);
+       }
+       serializeBooleanEdge(serializer, undefStatus);
+       
+       serializer->mywrite(&type, sizeof(ASTNodeType));
+       BooleanPredicate* This = this;
+       serializer->mywrite(&This, sizeof(BooleanPredicate*));
+       serializer->mywrite(&predicate, sizeof(Predicate *));
+       serializer->mywrite(&size, sizeof(uint));
+       for(uint i=0; i<size; i++){
+               Element *input = inputs.get(i);
+               serializer->mywrite(&input, sizeof(Element *));
+       }
+       Boolean* undefStat = undefStatus!= BooleanEdge(NULL)?undefStatus.getRaw() : NULL;
+       serializer->mywrite(&undefStat, sizeof(Boolean*));
+}
+
+void BooleanPredicate::print(){
+       model_print("{BooleanPredicate:\n");
+       predicate->print();
+       model_print("elements:\n");
+       uint size = inputs.getSize();
+       for(uint i=0; i<size; i++){
+               Element *input = inputs.get(i);
+               input->print();
+       }
+       model_print("}\n");
 }
 
 void BooleanLogic::serialize(Serializer* serializer){
-       ASSERT(0);
-}
\ No newline at end of file
+       if(serializer->isSerialized(this))
+               return;
+       serializer->addObject(this);
+       uint size = inputs.getSize();
+       for(uint i=0; i<size; i++){
+               BooleanEdge input = inputs.get(i);
+               serializeBooleanEdge(serializer, input);
+       }
+       serializer->mywrite(&type, sizeof(ASTNodeType));
+       BooleanLogic* This = this;
+       serializer->mywrite(&This, sizeof(BooleanLogic*));
+       serializer->mywrite(&op, sizeof(LogicOp));
+       serializer->mywrite(&size, sizeof(uint));
+       for(uint i=0; i<size; i++){
+               Boolean* input = inputs.get(i).getRaw();
+               serializer->mywrite(&input, sizeof(Boolean*));
+       }
+}
+
+void BooleanLogic::print(){
+       model_print("{BooleanLogic: %s\n", 
+                                                       op ==SATC_AND? "AND": op == SATC_OR? "OR": op==SATC_NOT? "NOT":
+                                                       op == SATC_XOR? "XOR" : op==SATC_IFF? "IFF" : "IMPLIES");
+       uint size = inputs.getSize();
+       for(uint i=0; i<size; i++){
+               BooleanEdge input = inputs.get(i);
+               if(input.isNegated())
+                       model_print("!");
+               input.getBoolean()->print();
+       }
+       model_print("}\n");
+}
+