Edits to merge
[satune.git] / src / AST / boolean.cc
index 565e0efa9417d62c7fce30f57758a5847363d2db..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,6 +131,12 @@ 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){
        if(serializer->isSerialized(this))
                return;
@@ -144,10 +159,22 @@ void BooleanPredicate::serialize(Serializer* serializer){
                Element *input = inputs.get(i);
                serializer->mywrite(&input, sizeof(Element *));
        }
-       Boolean* undefStat = undefStatus.getRaw();
+       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){
        if(serializer->isSerialized(this))
                return;
@@ -168,3 +195,17 @@ void BooleanLogic::serialize(Serializer* serializer){
        }
 }
 
+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");
+}
+