| author | Darkvater | 
| Sat, 18 Nov 2006 17:04:44 +0000 | |
| changeset 5125 | 60b21cf18b50 | 
| parent 3012 | e6d8dd948cb4 | 
| permissions | -rw-r--r-- | 
| 2186 | 1 | /* $Id$ */ | 
| 2 | ||
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 3 | #ifndef QUEUE_H | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 4 | #define QUEUE_H | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 5 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 6 | //#define NOFREE | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 7 | //#define QUEUE_DEBUG | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 8 | //#define HASH_DEBUG | 
| 1661 
6af0c4416154
(svn r2165) - Codechange: [NPF] Properly enummed NPF hash size, it is easily changable now.
 matthijs parents: 
1093diff
changeset | 9 | //#define HASH_STATS | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 10 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 11 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 12 | typedef struct Queue Queue; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 13 | typedef bool Queue_PushProc(Queue* q, void* item, int priority); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 14 | typedef void* Queue_PopProc(Queue* q); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 15 | typedef bool Queue_DeleteProc(Queue* q, void* item, int priority); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 16 | typedef void Queue_ClearProc(Queue* q, bool free_values); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 17 | typedef void Queue_FreeProc(Queue* q, bool free_values); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 18 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 19 | typedef struct InsSortNode InsSortNode; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 20 | struct InsSortNode {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 21 | void* item; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 22 | int priority; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 23 | InsSortNode* next; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 24 | }; | 
| 3012 
e6d8dd948cb4
(svn r3592) Miscellaneous smaller changes, most notably replacing sizeof(type) by sizeof(*variable)
 tron parents: 
2186diff
changeset | 25 | |
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 26 | typedef struct BinaryHeapNode BinaryHeapNode; | 
| 3012 
e6d8dd948cb4
(svn r3592) Miscellaneous smaller changes, most notably replacing sizeof(type) by sizeof(*variable)
 tron parents: 
2186diff
changeset | 27 | struct BinaryHeapNode {
 | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 28 | void* item; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 29 | int priority; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 30 | }; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 31 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 32 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 33 | struct Queue{
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 34 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 35 | * Pushes an element into the queue, at the appropriate place for the queue. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 36 | * Requires the queue pointer to be of an appropriate type, of course. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 37 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 38 | Queue_PushProc* push; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 39 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 40 | * Pops the first element from the queue. What exactly is the first element, | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 41 | * is defined by the exact type of queue. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 42 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 43 | Queue_PopProc* pop; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 44 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 45 | * Deletes the item from the queue. priority should be specified if | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 46 | * known, which speeds up the deleting for some queue's. Should be -1 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 47 | * if not known. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 48 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 49 | Queue_DeleteProc* del; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 50 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 51 | /* Clears the queue, by removing all values from it. It's state is | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 52 | * effectively reset. If free_items is true, each of the items cleared | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 53 | * in this way are free()'d. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 54 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 55 | Queue_ClearProc* clear; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 56 | /* Frees the queue, by reclaiming all memory allocated by it. After | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 57 | * this it is no longer usable. If free_items is true, any remaining | 
| 201 
c40d343115f8
(svn r202) -Codechange: I missed some files with trailing spaces.. this should be
 truelight parents: 
110diff
changeset | 58 | * items are free()'d too. | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 59 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 60 | Queue_FreeProc* free; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 61 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 62 | 	union {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 63 | 		struct {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 64 | uint max_size; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 65 | uint size; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 66 | void** elements; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 67 | } stack; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 68 | 		struct {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 69 | uint max_size; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 70 | uint head; /* The index where the last element should be inserted */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 71 | uint tail; /* The index where the next element should be read */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 72 | void** elements; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 73 | } fifo; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 74 | 		struct {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 75 | InsSortNode* first; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 76 | } inssort; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 77 | 		struct {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 78 | uint max_size; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 79 | uint size; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 80 | uint blocks; /* The amount of blocks for which space is reserved in elements */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 81 | BinaryHeapNode** elements; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 82 | } binaryheap; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 83 | } data; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 84 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 85 | /* If true, this struct will be free'd when the | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 86 | * Queue is deleted. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 87 | bool freeq; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 88 | }; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 89 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 90 | /* Initializes a stack and allocates internal memory. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 91 | void init_Stack(Queue* q, uint max_size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 92 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 93 | /* Allocate a new stack with a maximum of max_size elements. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 94 | Queue* new_Stack(uint max_size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 95 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 96 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 97 | * Fifo | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 98 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 99 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 100 | /* Initializes a fifo and allocates internal memory for maximum of max_size | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 101 | * elements */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 102 | void init_Fifo(Queue* q, uint max_size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 103 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 104 | /* Allocate a new fifo and initializes it with a maximum of max_size elements. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 105 | Queue* new_Fifo(uint max_size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 106 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 107 | Queue* new_Fifo_in_buffer(uint max_size, void* buffer); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 108 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 109 | int build_Fifo(void* buffer, uint size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 110 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 111 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 112 | * Insertion Sorter | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 113 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 114 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 115 | /* Initializes a inssort and allocates internal memory. There is no maximum | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 116 | * size */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 117 | void init_InsSort(Queue* q); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 118 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 119 | /* Allocate a new fifo and initializes it. There is no maximum size */ | 
| 1093 
e8d26c7dc42f
(svn r1594) Convert all undefined parameter lists to (void) and add the appropriate warning flags in the Makefile
 tron parents: 
201diff
changeset | 120 | Queue* new_InsSort(void); | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 121 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 122 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 123 | * Binary Heap | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 124 | * For information, see: | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 125 | * http://www.policyalmanac.org/games/binaryHeaps.htm | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 126 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 127 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 128 | /* The amount of elements that will be malloc'd at a time */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 129 | #define BINARY_HEAP_BLOCKSIZE_BITS 10 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 130 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 131 | /* Initializes a binary heap and allocates internal memory for maximum of | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 132 | * max_size elements */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 133 | void init_BinaryHeap(Queue* q, uint max_size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 134 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 135 | /* Allocate a new binary heap and initializes it with a maximum of max_size | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 136 | * elements. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 137 | Queue* new_BinaryHeap(uint max_size); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 138 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 139 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 140 | * Hash | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 141 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 142 | typedef struct HashNode HashNode; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 143 | struct HashNode {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 144 | uint key1; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 145 | uint key2; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 146 | void* value; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 147 | HashNode* next; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 148 | }; | 
| 1661 
6af0c4416154
(svn r2165) - Codechange: [NPF] Properly enummed NPF hash size, it is easily changable now.
 matthijs parents: 
1093diff
changeset | 149 | /** | 
| 
6af0c4416154
(svn r2165) - Codechange: [NPF] Properly enummed NPF hash size, it is easily changable now.
 matthijs parents: 
1093diff
changeset | 150 | * Generates a hash code from the given key pair. You should make sure that | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 151 | * the resulting range is clearly defined. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 152 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 153 | typedef uint Hash_HashProc(uint key1, uint key2); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 154 | typedef struct Hash {
 | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 155 | /* The hash function used */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 156 | Hash_HashProc* hash; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 157 | /* The amount of items in the hash */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 158 | uint size; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 159 | /* The number of buckets allocated */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 160 | uint num_buckets; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 161 | /* A pointer to an array of num_buckets buckets. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 162 | HashNode* buckets; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 163 | /* A pointer to an array of numbuckets booleans, which will be true if | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 164 | * there are any Nodes in the bucket */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 165 | bool* buckets_in_use; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 166 | /* If true, buckets will be freed in delete_hash */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 167 | bool freeb; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 168 | /* If true, the pointer to this struct will be freed in delete_hash */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 169 | bool freeh; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 170 | } Hash; | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 171 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 172 | /* Call these function to manipulate a hash */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 173 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 174 | /* Deletes the value with the specified key pair from the hash and returns | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 175 | * that value. Returns NULL when the value was not present. The value returned | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 176 | * is _not_ free()'d! */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 177 | void* Hash_Delete(Hash* h, uint key1, uint key2); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 178 | /* Sets the value associated with the given key pair to the given value. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 179 | * Returns the old value if the value was replaced, NULL when it was not yet present. */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 180 | void* Hash_Set(Hash* h, uint key1, uint key2, void* value); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 181 | /* Gets the value associated with the given key pair, or NULL when it is not | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 182 | * present. */ | 
| 3012 
e6d8dd948cb4
(svn r3592) Miscellaneous smaller changes, most notably replacing sizeof(type) by sizeof(*variable)
 tron parents: 
2186diff
changeset | 183 | void* Hash_Get(const Hash* h, uint key1, uint key2); | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 184 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 185 | /* Call these function to create/destroy a hash */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 186 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 187 | /* Builds a new hash, with num_buckets buckets. Make sure that hash() always | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 188 | * returns a hash less than num_buckets! Call delete_hash after use */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 189 | Hash* new_Hash(Hash_HashProc* hash, int num_buckets); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 190 | /* Builds a new hash in an existing struct. Make sure that hash() always | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 191 | * returns a hash less than num_buckets! Call delete_hash after use */ | 
| 1661 
6af0c4416154
(svn r2165) - Codechange: [NPF] Properly enummed NPF hash size, it is easily changable now.
 matthijs parents: 
1093diff
changeset | 192 | void init_Hash(Hash* h, Hash_HashProc* hash, uint num_buckets); | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 193 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 194 | * Deletes the hash and cleans up. Only cleans up memory allocated by new_Hash | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 195 | * & friends. If free is true, it will call free() on all the values that | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 196 | * are left in the hash. | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 197 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 198 | void delete_Hash(Hash* h, bool free_values); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 199 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 200 | * Cleans the hash, but keeps the memory allocated | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 201 | */ | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 202 | void clear_Hash(Hash* h, bool free_values); | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 203 | /* | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 204 | * Gets the current size of the Hash | 
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 205 | */ | 
| 3012 
e6d8dd948cb4
(svn r3592) Miscellaneous smaller changes, most notably replacing sizeof(type) by sizeof(*variable)
 tron parents: 
2186diff
changeset | 206 | uint Hash_Size(const Hash* h); | 
| 110 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 207 | |
| 
a22a6b07904b
(svn r111) -Fix: converted all linebreaks to UNIX-linebreak (\n)
 truelight parents: 
107diff
changeset | 208 | #endif /* QUEUE_H */ |