Implement Hashtable_clear to empty an existing Hashtable

main
Benny Baumann 5 years ago
parent 9549ca8c88
commit c1563337ae
  1. 16
      Hashtable.c
  2. 2
      Hashtable.h

@ -98,21 +98,29 @@ Hashtable* Hashtable_new(unsigned int size, bool owner) {
this->size = size ? nextPrime(size) : 13;
this->buckets = (HashtableItem*) xCalloc(this->size, sizeof(HashtableItem));
this->owner = owner;
assert(Hashtable_isConsistent(this));
return this;
}
void Hashtable_delete(Hashtable* this) {
Hashtable_clear(this);
free(this->buckets);
free(this);
}
void Hashtable_clear(Hashtable* this) {
assert(Hashtable_isConsistent(this));
if (this->owner) {
if (this->owner)
for (unsigned int i = 0; i < this->size; i++)
free(this->buckets[i].value);
}
free(this->buckets);
free(this);
memset(this->buckets, 0, this->size * sizeof(HashtableItem));
this->items = 0;
assert(Hashtable_isConsistent(this));
}
static void insert(Hashtable* this, hkey_t key, void* value) {

@ -37,6 +37,8 @@ Hashtable* Hashtable_new(unsigned int size, bool owner);
void Hashtable_delete(Hashtable* this);
void Hashtable_clear(Hashtable* this);
void Hashtable_setSize(Hashtable* this, unsigned int size);
void Hashtable_put(Hashtable* this, hkey_t key, void* value);

Loading…
Cancel
Save