Big Tabbing Change
[satune.git] / src / AST / boolean.h
index 928ba41bc78fec2d252e5bb0b6da2cb559752dba..cdc05a6be55487fd5fcc5db483be2067fc920562 100644 (file)
 
 #define GETBOOLEANTYPE(o) GETASTNODETYPE(o)
 #define GETBOOLEANPARENTS(o) (&((Boolean *)(o))->parents)
+#define GETBOOLEANPOLARITY(b) (((Boolean *)b)->polarity)
+#define GETBOOLEANVALUE(b) (((Boolean *)b)->boolVal)
 
 struct Boolean {
        ASTNode base;
+       Polarity polarity;
+       BooleanValue boolVal;
        VectorBoolean parents;
 };
 
 struct BooleanOrder {
        Boolean base;
-       Orderorder;
+       Order *order;
        uint64_t first;
        uint64_t second;
 };
@@ -41,18 +45,18 @@ struct BooleanLogic {
 
 struct BooleanPredicate {
        Boolean base;
-       Predicate * predicate;
+       Predicate *predicate;
        FunctionEncoding encoding;
        ArrayElement inputs;
+       Boolean *undefStatus;
 };
 
-Boolean * allocBooleanVar(VarType t);
-Boolean * allocBooleanOrder(Order * order, uint64_t first, uint64_t second);
-Boolean * allocBooleanPredicate(Predicate * predicate, Element ** inputs, uint numInputs);
-Boolean * allocBooleanLogicArray(CSolver *solver, LogicOp op, Boolean ** array, uint asize);
-void deleteBoolean(Boolean * This);
-
-static inline FunctionEncoding* getPredicateFunctionEncoding(BooleanPredicate* func){
+Boolean *allocBooleanVar(VarType t);
+Boolean *allocBooleanOrder(Order *order, uint64_t first, uint64_t second);
+Boolean *allocBooleanPredicate(Predicate *predicate, Element **inputs, uint numInputs, Boolean *undefinedStatus);
+Boolean *allocBooleanLogicArray(CSolver *solver, LogicOp op, Boolean **array, uint asize);
+void deleteBoolean(Boolean *This);
+static inline FunctionEncoding *getPredicateFunctionEncoding(BooleanPredicate *func) {
        return &func->encoding;
 }