#include "hash.h"
#include "keydb.h"
+#include "keyid.h"
#include "ll.h"
+#include "mem.h"
#include "stats.h"
/**
elements = 0;
}
+/**
+ * destroyhash - Clean up the hash after use.
+ *
+ * This function destroys the hash after use, freeing any memory that was
+ * used during its lifetime.
+ */
+void destroyhash(void)
+{
+ int i;
+ struct ll *curll = NULL;
+
+ for (i = 0; i < HASHSIZE; i++) {
+ curll = hashtable[i];
+ /*
+ * TODO: The problem is the object has pointers that
+ * need freed too.
+ */
+ llfree(curll, free_statskey);
+ hashtable[i] = NULL;
+ }
+ elements = 0;
+}
+
+/**
+ * addtohash - Adds a key to the hash.
+ * @key: The key to add.
+ *
+ * Takes a key and stores it in the hash.
+ */
void addtohash(struct stats_key *key)
{
++elements;
{
struct stats_key *key = NULL;
+ if (keyid == 0) {
+ return NULL;
+ }
+
key = findinhash(keyid);
if (key == NULL) {
key = malloc(sizeof(*key));