File:  [ELWIX - Embedded LightWeight unIX -] / embedaddon / iftop / hash.c
Revision 1.1.1.1 (vendor branch): download - view: text, annotated - select for diffs - revision graph
Tue Feb 21 16:57:34 2012 UTC (12 years, 4 months ago) by misho
Branches: iftop, MAIN
CVS tags: v0_17p0, v0_17, HEAD
iftop

    1: /* hash table */
    2: 
    3: #include <stdio.h>
    4: #include <stdlib.h>
    5: #include "hash.h"
    6: #include "iftop.h"
    7: 
    8: hash_status_enum hash_insert(hash_type* hash_table, void* key, void* rec) {
    9:     hash_node_type *p, *p0;
   10:     int bucket;
   11: 
   12:    /************************************************
   13:     *  allocate node for data and insert in table  *
   14:     ************************************************/
   15: 
   16: 
   17:     /* insert node at beginning of list */
   18:     bucket = hash_table->hash(key);
   19:     p = xmalloc(sizeof *p);
   20:     p0 = hash_table->table[bucket];
   21:     hash_table->table[bucket] = p;
   22:     p->next = p0;
   23:     p->key = hash_table->copy_key(key);
   24:     p->rec = rec;
   25:     return HASH_STATUS_OK;
   26: }
   27: 
   28: hash_status_enum hash_delete(hash_type* hash_table, void* key) {
   29:     hash_node_type *p0, *p;
   30:     int bucket;
   31: 
   32:    /********************************************
   33:     *  delete node containing data from table  *
   34:     ********************************************/
   35: 
   36:     /* find node */
   37:     p0 = 0;
   38:     bucket = hash_table->hash(key);
   39:     p = hash_table->table[bucket];
   40:     while (p && !hash_table->compare(p->key, key)) {
   41:         p0 = p;
   42:         p = p->next;
   43:     }
   44:     if (!p) return HASH_STATUS_KEY_NOT_FOUND;
   45: 
   46:     /* p designates node to delete, remove it from list */
   47:     if (p0) {
   48:         /* not first node, p0 points to previous node */
   49:         p0->next = p->next;
   50:     }
   51:     else {
   52:         /* first node on chain */
   53:         hash_table->table[bucket] = p->next;
   54:     }
   55: 
   56:     hash_table->delete_key(p->key);
   57:     free (p);
   58:     return HASH_STATUS_OK;
   59: }
   60: 
   61: hash_status_enum hash_find(hash_type* hash_table, void* key, void **rec) {
   62:     hash_node_type *p;
   63: 
   64:    /*******************************
   65:     *  find node containing data  *
   66:     *******************************/
   67:     p = hash_table->table[hash_table->hash(key)];
   68: 
   69:     while (p && !hash_table->compare(p->key, key))  {
   70:         p = p->next;
   71:     }
   72:     if (!p) return HASH_STATUS_KEY_NOT_FOUND;
   73:     *rec = p->rec;
   74:     return HASH_STATUS_OK;
   75: }
   76: 
   77: hash_status_enum hash_next_item(hash_type* hash_table, hash_node_type** ppnode) {
   78:     int i;
   79:     if(*ppnode != NULL) {
   80:         if((*ppnode)->next != NULL) {
   81:             *ppnode = (*ppnode)->next;
   82:             return HASH_STATUS_OK;
   83:         }
   84:         i = hash_table->hash((*ppnode)->key) + 1;
   85:     }
   86:     else {
   87:         /* first node */
   88:         i = 0;
   89:     }
   90:     while(i < hash_table->size && hash_table->table[i] == NULL) {
   91:          i++; 
   92:     }
   93:     if(i == hash_table->size) {
   94:         *ppnode = NULL;
   95:         return HASH_STATUS_KEY_NOT_FOUND;
   96:     }
   97:     *ppnode = hash_table->table[i];
   98:     return HASH_STATUS_OK;
   99: }
  100: 
  101: void hash_delete_all(hash_type* hash_table) {
  102:     int i;
  103:     hash_node_type *n, *nn;
  104:     for(i = 0; i < hash_table->size; i++) {
  105:         n = hash_table->table[i];
  106:         while(n != NULL) {
  107:             nn = n->next;
  108:             hash_table->delete_key(n->key);
  109:             free(n);
  110:             n = nn;
  111:         }
  112:         hash_table->table[i] = NULL;
  113:     }
  114: }
  115: 
  116: 
  117: /*
  118:  * Allocate and return a hash
  119:  */
  120: hash_status_enum hash_initialise(hash_type* hash_table) {
  121:     hash_table->table = xcalloc(hash_table->size, sizeof *hash_table->table);
  122:     return HASH_STATUS_OK;
  123: }
  124: 
  125: hash_status_enum hash_destroy(hash_type* hash_table) {
  126:     free(hash_table->table);
  127:     return HASH_STATUS_OK;
  128: }
  129: 

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>