towards cloning
[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 typedef HashTable<Order *, Order *, uintptr_t, 4> OrderMap;
28 typedef HashTable<Boolean *, Boolean *, uintptr_t, 4> BooleanMap;
29 typedef HashTable<Element *, Element *, uintptr_t, 4> ElementMap;
30 typedef HashTable<Set *, Set *, uintptr_t, 4> SetMap;
31
32 typedef struct CloneMap {
33         OrderMap order;
34         BooleanMap boolean;
35         ElementMap element;
36         SetMap set;
37 } CloneMap;
38
39 typedef HSIterator<TableEntry *, uintptr_t, 4, table_entry_hash_function, table_entry_equals> HSIteratorTableEntry;
40 typedef HSIterator<Boolean *, uintptr_t, 4> HSIteratorBoolean;
41 typedef HSIterator<OrderEdge *, uintptr_t, 4, order_edge_hash_function, order_edge_equals> HSIteratorOrderEdge;
42 typedef HSIterator<OrderNode *, uintptr_t, 4, order_node_hash_function, order_node_equals> HSIteratorOrderNode;
43
44
45 #endif