Home | History | Annotate | Download | only in util
      1 /*
      2  * Copyright 2001-2004 Brandon Long
      3  * All Rights Reserved.
      4  *
      5  * ClearSilver Templating System
      6  *
      7  * This code is made available under the terms of the ClearSilver License.
      8  * http://www.clearsilver.net/license.hdf
      9  *
     10  */
     11 
     12 #ifndef __NEO_HASH_H_
     13 #define __NEO_HASH_H_ 1
     14 
     15 __BEGIN_DECLS
     16 
     17 #include <stdlib.h>
     18 #include "util/neo_misc.h"
     19 
     20 typedef UINT32 (*NE_HASH_FUNC)(const void *);
     21 typedef int (*NE_COMP_FUNC)(const void *, const void *);
     22 
     23 typedef struct _NE_HASHNODE
     24 {
     25   void *key;
     26   void *value;
     27   UINT32 hashv;
     28   struct _NE_HASHNODE *next;
     29 } NE_HASHNODE;
     30 
     31 typedef struct _HASH
     32 {
     33   UINT32 size;
     34   UINT32 num;
     35 
     36   NE_HASHNODE **nodes;
     37   NE_HASH_FUNC hash_func;
     38   NE_COMP_FUNC comp_func;
     39 } NE_HASH;
     40 
     41 NEOERR *ne_hash_init (NE_HASH **hash, NE_HASH_FUNC hash_func, NE_COMP_FUNC comp_func);
     42 void ne_hash_destroy (NE_HASH **hash);
     43 NEOERR *ne_hash_insert(NE_HASH *hash, void *key, void *value);
     44 void *ne_hash_lookup(NE_HASH *hash, void *key);
     45 int ne_hash_has_key(NE_HASH *hash, void *key);
     46 void *ne_hash_remove(NE_HASH *hash, void *key);
     47 void *ne_hash_next(NE_HASH *hash, void **key);
     48 
     49 int ne_hash_str_comp(const void *a, const void *b);
     50 UINT32 ne_hash_str_hash(const void *a);
     51 
     52 int ne_hash_int_comp(const void *a, const void *b);
     53 UINT32 ne_hash_int_hash(const void *a);
     54 
     55 __END_DECLS
     56 
     57 #endif /* __NEO_HASH_H_ */
     58