1 /* Copyright (C) 2002 Christopher Clark <firstname.lastname@cl.cam.ac.uk> */
   2 
   3 #include "hashtable.h"
   4 #include "hashtable_private.h"
   5 #include "hashtable_utility.h"
   6 #include <stdlib.h>
   7 #include <stdio.h>
   8 #include <string.h>
   9 
  10 /*****************************************************************************/
  11 /* hashtable_change
  12  *
  13  * function to change the value associated with a key, where there already
  14  * exists a value bound to the key in the hashtable.
  15  * Source due to Holger Schemel.
  16  * 
  17  *  */
  18 int
  19 hashtable_change(struct hashtable *h, void *k, void *v)
  20 {
  21     struct entry *e;
  22     unsigned int hashvalue, index;
  23     hashvalue = hash(h,k);
  24     index = indexFor(h->tablelength,hashvalue);
  25     e = h->table[index];
  26     while (NULL != e)
  27     {
  28         /* Check hash value to short circuit heavier comparison */
  29         if ((hashvalue == e->h) && (h->eqfn(k, e->k)))
  30         {
  31             free(e->v);
  32             e->v = v;
  33             return -1;
  34         }
  35         e = e->next;
  36     }
  37     return 0;
  38 }
  39 
  40 /*
  41  * Copyright (c) 2002, Christopher Clark
  42  * All rights reserved.
  43  * 
  44  * Redistribution and use in source and binary forms, with or without
  45  * modification, are permitted provided that the following conditions
  46  * are met:
  47  * 
  48  * * Redistributions of source code must retain the above copyright
  49  * notice, this list of conditions and the following disclaimer.
  50  * 
  51  * * Redistributions in binary form must reproduce the above copyright
  52  * notice, this list of conditions and the following disclaimer in the
  53  * documentation and/or other materials provided with the distribution.
  54  * 
  55  * * Neither the name of the original author; nor the names of any contributors
  56  * may be used to endorse or promote products derived from this software
  57  * without specific prior written permission.
  58  * 
  59  * 
  60  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  61  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  62  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  63  * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER
  64  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  65  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  66  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
  67  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
  68  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
  69  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
  70  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  71 */