Compiles
[satune.git] / src / Collections / corestructs.h
index 982e0c5cfed2d397e95a3f1f8bdf486aedfcd8e8..e30a5309b57b0330c37fe9ff307ddc5f02fc1163 100644 (file)
@@ -4,9 +4,33 @@
 #include "cppvector.h"
 #include "hashset.h"
 
-typedef Hashset<Boolean *, uintptr_t, 4> HashsetBoolean;
+class BooleanEdge {
+ public:
+ BooleanEdge() : b(NULL) {}
+ BooleanEdge(Boolean * _b) : b(_b) {}
+       BooleanEdge negate() {return BooleanEdge((Boolean *)(((uintptr_t) b) ^ 1));}
+       bool operator==(BooleanEdge e) { return b==e.b;}
+       bool operator!=(BooleanEdge e) { return b!=e.b;}
+       bool isNegated() { return ((uintptr_t) b) & 1; }
+       Boolean * getBoolean() {return (Boolean *)(((uintptr_t)b) & ~((uintptr_t) 1));}
+       Boolean * getRaw() {return b;}
+       Boolean * operator->() {return getBoolean();}
+       operator bool() const {return b != NULL;}
+ private:
+       Boolean *b;
+};
+
+inline bool boolEdgeEquals(BooleanEdge b1, BooleanEdge b2) {
+       return b1==b2;
+}
+
+inline unsigned int boolEdgeHash(BooleanEdge b) {
+       return (unsigned int) (((uintptr_t)b.getRaw())>>4);
+}
+                                                                       
+typedef Hashset<BooleanEdge, uintptr_t, 4, & boolEdgeHash, & boolEdgeEquals> HashsetBooleanEdge;
 typedef Hashset<Order *, uintptr_t, 4> HashsetOrder;
-typedef SetIterator<Boolean *, uintptr_t, 4> SetIteratorBoolean;
+typedef SetIterator<BooleanEdge, uintptr_t, 4, & boolEdgeHash, & boolEdgeEquals> SetIteratorBooleanEdge;
 typedef SetIterator<Order *, uintptr_t, 4> SetIteratorOrder;
 
 #endif