Run tabbing pass
[satune.git] / src / Collections / structs.h
1 #ifndef STRUCTS_H
2 #define STRUCTS_H
3 #include "cppvector.h"
4 #include "hashtable.h"
5 #include "hashset.h"
6 #include "classlist.h"
7 #include "array.h"
8
9 unsigned int table_entry_hash_function(TableEntry *This);
10 bool table_entry_equals(TableEntry *key1, TableEntry *key2);
11 unsigned int order_node_hash_function(OrderNode *This);
12 bool order_node_equals(OrderNode *key1, OrderNode *key2);
13 unsigned int order_edge_hash_function(OrderEdge *This);
14 bool order_edge_equals(OrderEdge *key1, OrderEdge *key2);
15 unsigned int order_element_hash_function(OrderElement *This);
16 bool order_element_equals(OrderElement *key1, OrderElement *key2);
17 unsigned int order_pair_hash_function(OrderPair *This);
18 bool order_pair_equals(OrderPair *key1, OrderPair *key2);
19
20 typedef HashSet<Boolean *, uintptr_t, 4> HashSetBoolean;
21 typedef HashSet<TableEntry *, uintptr_t, 4, table_entry_hash_function, table_entry_equals> HashSetTableEntry;
22 typedef HashSet<OrderNode *, uintptr_t, 4, order_node_hash_function, order_node_equals> HashSetOrderNode;
23 typedef HashSet<OrderEdge *, uintptr_t, 4, order_edge_hash_function, order_edge_equals> HashSetOrderEdge;
24 typedef HashSet<OrderElement *, uintptr_t, 4, order_element_hash_function, order_element_equals> HashSetOrderElement;
25 typedef HashTable<OrderNode *, HashSetOrderNode *, uintptr_t, 4> HashTableNodeToNodeSet;
26 typedef HashTable<OrderPair *, OrderPair *, uintptr_t, 4, order_pair_hash_function, order_pair_equals> HashTableOrderPair;
27
28 typedef HSIterator<TableEntry *, uintptr_t, 4, table_entry_hash_function, table_entry_equals> HSIteratorTableEntry;
29 typedef HSIterator<Boolean *, uintptr_t, 4> HSIteratorBoolean;
30 typedef HSIterator<OrderEdge *, uintptr_t, 4, order_edge_hash_function, order_edge_equals> HSIteratorOrderEdge;
31 typedef HSIterator<OrderNode *, uintptr_t, 4, order_node_hash_function, order_node_equals> HSIteratorOrderNode;
32
33 #endif