summaryrefslogtreecommitdiffstats
path: root/Hashtable.c
diff options
context:
space:
mode:
authorHisham Muhammad <hisham@gobolinux.org>2006-11-08 20:09:48 +0000
committerHisham Muhammad <hisham@gobolinux.org>2006-11-08 20:09:48 +0000
commit110ce71b9b086d3c090a33ed8e3b1c6e8a3d00d9 (patch)
tree198e258fc2fa6dcf36ff217b2960f5daae7d23db /Hashtable.c
parent46b35b2c7f66d31ef639026344da50b7b08d8162 (diff)
Add consistency checks.
Diffstat (limited to 'Hashtable.c')
-rw-r--r--Hashtable.c61
1 files changed, 44 insertions, 17 deletions
diff --git a/Hashtable.c b/Hashtable.c
index 30218a52..0f32601a 100644
--- a/Hashtable.c
+++ b/Hashtable.c
@@ -31,6 +31,22 @@ struct Hashtable_ {
};
}*/
+#ifdef DEBUG
+
+bool Hashtable_isConsistent(Hashtable* this) {
+ int items = 0;
+ for (int i = 0; i < this->size; i++) {
+ HashtableItem* bucket = this->buckets[i];
+ while (bucket) {
+ items++;
+ bucket = bucket->next;
+ }
+ }
+ return items == this->items;
+}
+
+#endif
+
HashtableItem* HashtableItem_new(int key, void* value) {
HashtableItem* this;
@@ -45,13 +61,16 @@ Hashtable* Hashtable_new(int size, bool owner) {
Hashtable* this;
this = (Hashtable*) malloc(sizeof(Hashtable));
+ this->items = 0;
this->size = size;
this->buckets = (HashtableItem**) calloc(sizeof(HashtableItem*), size);
this->owner = owner;
+ assert(Hashtable_isConsistent(this));
return this;
}
void Hashtable_delete(Hashtable* this) {
+ assert(Hashtable_isConsistent(this));
for (int i = 0; i < this->size; i++) {
HashtableItem* walk = this->buckets[i];
while (walk != NULL) {
@@ -67,6 +86,7 @@ void Hashtable_delete(Hashtable* this) {
}
inline int Hashtable_size(Hashtable* this) {
+ assert(Hashtable_isConsistent(this));
return this->items;
}
@@ -85,47 +105,53 @@ void Hashtable_put(Hashtable* this, int key, void* value) {
break;
} else
bucketPtr = &((*bucketPtr)->next);
+ assert(Hashtable_isConsistent(this));
}
void* Hashtable_remove(Hashtable* this, int key) {
int index = key % this->size;
- HashtableItem** bucketPtr = &(this->buckets[index]);
- while (true)
- if (*bucketPtr == NULL) {
- return NULL;
- break;
- } else if ((*bucketPtr)->key == key) {
- void* savedValue = (*bucketPtr)->value;
- HashtableItem* savedNext = (*bucketPtr)->next;
- free(*bucketPtr);
- (*bucketPtr) = savedNext;
+
+ assert(Hashtable_isConsistent(this));
+
+ HashtableItem** bucket;
+ for (bucket = &(this->buckets[index]); *bucket; bucket = &((*bucket)->next) ) {
+ if ((*bucket)->key == key) {
+ void* value = (*bucket)->value;
+ HashtableItem* next = (*bucket)->next;
+ free(*bucket);
+ (*bucket) = next;
this->items--;
if (this->owner) {
- free(savedValue);
+ free(value);
+ assert(Hashtable_isConsistent(this));
return NULL;
} else {
- return savedValue;
+ assert(Hashtable_isConsistent(this));
+ return value;
}
- } else
- bucketPtr = &((*bucketPtr)->next);
+ }
+ }
+ assert(Hashtable_isConsistent(this));
+ return NULL;
}
-//#include <stdio.h>
+
inline void* Hashtable_get(Hashtable* this, int key) {
int index = key % this->size;
HashtableItem* bucketPtr = this->buckets[index];
- // fprintf(stderr, "%d -> %d\n", key, index);
while (true) {
if (bucketPtr == NULL) {
+ assert(Hashtable_isConsistent(this));
return NULL;
} else if (bucketPtr->key == key) {
+ assert(Hashtable_isConsistent(this));
return bucketPtr->value;
} else
bucketPtr = bucketPtr->next;
- // fprintf(stderr, "*\n");
}
}
void Hashtable_foreach(Hashtable* this, Hashtable_PairFunction f, void* userData) {
+ assert(Hashtable_isConsistent(this));
for (int i = 0; i < this->size; i++) {
HashtableItem* walk = this->buckets[i];
while (walk != NULL) {
@@ -133,4 +159,5 @@ void Hashtable_foreach(Hashtable* this, Hashtable_PairFunction f, void* userData
walk = walk->next;
}
}
+ assert(Hashtable_isConsistent(this));
}

© 2014-2024 Faster IT GmbH | imprint | privacy policy