diff options
| author | Uros Majstorovic <majstor@majstor.org> | 2020-08-05 03:38:22 +0200 | 
|---|---|---|
| committer | Uros Majstorovic <majstor@majstor.org> | 2020-08-05 03:38:22 +0200 | 
| commit | 5cd610a07468137066ea4daa5176c3e7045113b0 (patch) | |
| tree | a6a5b572572f8f37ec2cb87332fa46e9bcc53aa7 /code/ecp/htable | |
| parent | 2473a7d5c51806ab8651cd3c4e07a15b62084eb5 (diff) | |
ecp moved to root; fixed utils and tests
Diffstat (limited to 'code/ecp/htable')
| -rw-r--r-- | code/ecp/htable/Makefile | 14 | ||||
| -rwxr-xr-x | code/ecp/htable/hashtable.c | 274 | ||||
| -rwxr-xr-x | code/ecp/htable/hashtable.h | 206 | ||||
| -rwxr-xr-x | code/ecp/htable/hashtable_itr.c | 214 | ||||
| -rwxr-xr-x | code/ecp/htable/hashtable_itr.h | 121 | ||||
| -rwxr-xr-x | code/ecp/htable/hashtable_private.h | 84 | ||||
| -rw-r--r-- | code/ecp/htable/htable.c | 28 | 
7 files changed, 0 insertions, 941 deletions
| diff --git a/code/ecp/htable/Makefile b/code/ecp/htable/Makefile deleted file mode 100644 index 7ef95d5..0000000 --- a/code/ecp/htable/Makefile +++ /dev/null @@ -1,14 +0,0 @@ -include ../Makefile.platform -CFLAGS += $(PIC) -I.. -std=gnu89 - -obj = htable.o hashtable.o hashtable_itr.o - - -%.o: %.c -	$(CC) $(CFLAGS) -c $< - -all: $(obj) -	$(AR) rcs libecpht.a $(obj) - -clean: -	rm -f *.o *.a diff --git a/code/ecp/htable/hashtable.c b/code/ecp/htable/hashtable.c deleted file mode 100755 index de15827..0000000 --- a/code/ecp/htable/hashtable.c +++ /dev/null @@ -1,274 +0,0 @@ -/* Copyright (C) 2004 Christopher Clark <firstname.lastname@cl.cam.ac.uk> */ - -#include "hashtable.h" -#include "hashtable_private.h" -#include <stdio.h> -#include <string.h> -#include <math.h> - -/* -Credit for primes table: Aaron Krowne - http://br.endernet.org/~akrowne/ - http://planetmath.org/encyclopedia/GoodHashTablePrimes.html -*/ -static const unsigned int primes[] = { -53, 97, 193, 389, -769, 1543, 3079, 6151, -12289, 24593, 49157, 98317, -196613, 393241, 786433, 1572869, -3145739, 6291469, 12582917, 25165843, -50331653, 100663319, 201326611, 402653189, -805306457, 1610612741 -}; -const unsigned int prime_table_length = sizeof(primes)/sizeof(primes[0]); -const float max_load_factor = 0.65; - -/*****************************************************************************/ -struct hashtable * -create_hashtable(unsigned int minsize, -                 unsigned int (*hash_fn) (void*), -                 int (*eq_fn) (void*,void*), -                 void *(*malloc_fn) (size_t), -                 void *(*realloc_fn) (void*,size_t), -                 void (*free_fn) (void*)) -{ -    struct hashtable *h = NULL; -    unsigned int pindex, size = primes[0]; -     -    /* Check requested hashtable isn't too large */ -    if (minsize > (1u << 30)) return NULL; - -    malloc_fn = malloc_fn ? malloc_fn : malloc; -    realloc_fn = realloc_fn ? realloc_fn : realloc; -    free_fn = free_fn ? free_fn : free; -    h = malloc_fn(sizeof(struct hashtable)); -    if (NULL == h) return NULL; -    memset(h, 0, sizeof(struct hashtable)); -     -    /* Enforce size as prime */ -    for (pindex=0; pindex < prime_table_length; pindex++) { -        if (primes[pindex] > minsize) { size = primes[pindex]; break; } -    } -    h->fn_malloc    = malloc_fn; -    h->fn_realloc   = realloc_fn; -    h->fn_free      = free_fn; -    h->tablelength  = size; -    h->primeindex   = pindex; -    h->entrycount   = 0; -    h->fn_hash      = hash_fn; -    h->fn_eq        = eq_fn; -    h->loadlimit    = (unsigned int) ceil(size * max_load_factor); -    h->table = malloc_fn(sizeof(struct entry *) * size); -    if (NULL == h->table) { free_fn(h); return NULL; } /*oom*/ -    memset(h->table, 0, size * sizeof(struct entry *)); -    return h; -} - -/*****************************************************************************/ -unsigned int -hashtable_hash(struct hashtable *h, void *k) -{ -    /* Aim to protect against poor hash functions by adding logic here -     * - logic taken from java 1.4 hashtable source */ -    unsigned int i = h->fn_hash(k); -    i += ~(i << 9); -    i ^=  ((i >> 14) | (i << 18)); /* >>> */ -    i +=  (i << 4); -    i ^=  ((i >> 10) | (i << 22)); /* >>> */ -    return i; -} - -/*****************************************************************************/ -static int -hashtable_expand(struct hashtable *h) -{ -    /* Double the size of the table to accomodate more entries */ -    struct entry **newtable; -    struct entry *e; -    struct entry **pE; -    unsigned int newsize, i, index; -    /* Check we're not hitting max capacity */ -    if (h->primeindex == (prime_table_length - 1)) return 0; -    newsize = primes[++(h->primeindex)]; - -    newtable = h->fn_malloc(sizeof(struct entry *) * newsize); -    if (NULL != newtable) -    { -        memset(newtable, 0, newsize * sizeof(struct entry *)); -        /* This algorithm is not 'stable'. ie. it reverses the list -         * when it transfers entries between the tables */ -        for (i = 0; i < h->tablelength; i++) { -            while (NULL != (e = h->table[i])) { -                h->table[i] = e->next; -                index = indexFor(newsize,e->h); -                e->next = newtable[index]; -                newtable[index] = e; -            } -        } -        h->fn_free(h->table); -        h->table = newtable; -    } -    /* Plan B: realloc instead */ -    else  -    { -        newtable = h->fn_realloc(h->table, newsize * sizeof(struct entry *)); -        if (NULL == newtable) { (h->primeindex)--; return 0; } -        h->table = newtable; -        memset(newtable[h->tablelength], 0, newsize - h->tablelength); -        for (i = 0; i < h->tablelength; i++) { -            for (pE = &(newtable[i]), e = *pE; e != NULL; e = *pE) { -                index = indexFor(newsize,e->h); -                if (index == i) -                { -                    pE = &(e->next); -                } -                else -                { -                    *pE = e->next; -                    e->next = newtable[index]; -                    newtable[index] = e; -                } -            } -        } -    } -    h->tablelength = newsize; -    h->loadlimit   = (unsigned int) ceil(newsize * max_load_factor); -    return -1; -} - -/*****************************************************************************/ -unsigned int -hashtable_count(struct hashtable *h) -{ -    return h->entrycount; -} - -/*****************************************************************************/ -int -hashtable_insert(struct hashtable *h, void *k, void *v) -{ -    /* This method allows duplicate keys - but they shouldn't be used */ -    unsigned int index; -    struct entry *e; -    if (++(h->entrycount) > h->loadlimit) -    { -        /* Ignore the return value. If expand fails, we should -         * still try cramming just this value into the existing table -         * -- we may not have memory for a larger table, but one more -         * element may be ok. Next time we insert, we'll try expanding again.*/ -        hashtable_expand(h); -    } -    e = h->fn_malloc(sizeof(struct entry)); -    if (NULL == e) { --(h->entrycount); return 0; } /*oom*/ -    e->h = hashtable_hash(h,k); -    index = indexFor(h->tablelength,e->h); -    e->k = k; -    e->v = v; -    e->next = h->table[index]; -    h->table[index] = e; -    return -1; -} - -/*****************************************************************************/ -void * /* returns value associated with key */ -hashtable_search(struct hashtable *h, void *k) -{ -    struct entry *e; -    unsigned int hashvalue, index; -    hashvalue = hashtable_hash(h,k); -    index = indexFor(h->tablelength,hashvalue); -    e = h->table[index]; -    while (NULL != e) -    { -        /* Check hash value to short circuit heavier comparison */ -        if ((hashvalue == e->h) && (h->fn_eq(k, e->k))) return e->v; -        e = e->next; -    } -    return NULL; -} - -/*****************************************************************************/ -void * /* returns value associated with key --- modified by majstor */ -hashtable_remove(struct hashtable *h, void *k) -{ -    /* TODO: consider compacting the table when the load factor drops enough, -     *       or provide a 'compact' method. */ - -    struct entry *e; -    struct entry **pE; -    void *v; -    unsigned int hashvalue, index; - -    hashvalue = hashtable_hash(h,k); -    index = indexFor(h->tablelength,hashvalue); -    pE = &(h->table[index]); -    e = *pE; -    while (NULL != e) -    { -        /* Check hash value to short circuit heavier comparison */ -        if ((hashvalue == e->h) && (h->fn_eq(k, e->k))) -        { -            *pE = e->next; -            h->entrycount--; -            v = e->v; -            if (h->fn_free_k) h->fn_free_k(e->k); -            h->fn_free(e); -            return v; -        } -        pE = &(e->next); -        e = e->next; -    } -    return NULL; -} - -/*****************************************************************************/ -/* destroy --- modified by majstor */ -void -hashtable_destroy(struct hashtable *h) -{ -    unsigned int i; -    struct entry *e, *f; -    struct entry **table = h->table; - -    for (i = 0; i < h->tablelength; i++) -    { -        e = table[i]; -        while (NULL != e) -        { f = e; e = e->next; if (h->fn_free_k) h->fn_free_k(f->k); if (h->fn_free_v) h->fn_free_v(f->v); h->fn_free(f); } -    } -    h->fn_free(h->table); -    h->fn_free(h); -} - -/* - * Copyright (c) 2002, Christopher Clark - * All rights reserved. - *  - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - *  - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - *  - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - *  - * * Neither the name of the original author; nor the names of any contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - *  - *  - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER - * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, - * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, - * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF - * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING - * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ diff --git a/code/ecp/htable/hashtable.h b/code/ecp/htable/hashtable.h deleted file mode 100755 index 046f740..0000000 --- a/code/ecp/htable/hashtable.h +++ /dev/null @@ -1,206 +0,0 @@ -/* Copyright (C) 2002 Christopher Clark <firstname.lastname@cl.cam.ac.uk> */ - -#ifndef __HASHTABLE_CWC22_H__ -#define __HASHTABLE_CWC22_H__ - -#include <stdlib.h> - -struct hashtable; - -/* Example of use: - * - *      struct hashtable  *h; - *      struct some_key   *k; - *      struct some_value *v; - * - *      static unsigned int         hash_from_key_fn( void *k ); - *      static int                  keys_equal_fn ( void *key1, void *key2 ); - * - *      h = create_hashtable(16, hash_from_key_fn, keys_equal_fn); - *      k = (struct some_key *)     malloc(sizeof(struct some_key)); - *      v = (struct some_value *)   malloc(sizeof(struct some_value)); - * - *      (initialise k and v to suitable values) - *  - *      if (! hashtable_insert(h,k,v) ) - *      {     exit(-1);               } - * - *      if (NULL == (found = hashtable_search(h,k) )) - *      {    printf("Not found!");                  } - * - *      if (NULL == (found = hashtable_remove(h,k) )) - *      {    printf("Not found\n");                 } - * - */ - -/* Macros may be used to define type-safe(r) hashtable access functions, with - * methods specialized to take known key and value types as parameters. - *  - * Example: - * - * Insert this at the start of your file: - * - * DEFINE_HASHTABLE_INSERT(insert_some, struct some_key, struct some_value); - * DEFINE_HASHTABLE_SEARCH(search_some, struct some_key, struct some_value); - * DEFINE_HASHTABLE_REMOVE(remove_some, struct some_key, struct some_value); - * - * This defines the functions 'insert_some', 'search_some' and 'remove_some'. - * These operate just like hashtable_insert etc., with the same parameters, - * but their function signatures have 'struct some_key *' rather than - * 'void *', and hence can generate compile time errors if your program is - * supplying incorrect data as a key (and similarly for value). - * - * Note that the hash and key equality functions passed to create_hashtable - * still take 'void *' parameters instead of 'some key *'. This shouldn't be - * a difficult issue as they're only defined and passed once, and the other - * functions will ensure that only valid keys are supplied to them. - * - * The cost for this checking is increased code size and runtime overhead - * - if performance is important, it may be worth switching back to the - * unsafe methods once your program has been debugged with the safe methods. - * This just requires switching to some simple alternative defines - eg: - * #define insert_some hashtable_insert - * - */ - -/***************************************************************************** - * create_hashtable -    - * @name                    create_hashtable - * @param   minsize         minimum initial size of hashtable - * @param   hash_fn         function for hashing keys - * @param   eq_fn           function for determining key equality - * @param   malloc_fn       function malloc - * @param   realloc_fn      function realloc - * @param   free_fn         function free - * @return                  hashtable created - */ - -struct hashtable * -create_hashtable(unsigned int minsize, -                 unsigned int (*hash_fn) (void*), -                 int (*eq_fn) (void*,void*), -                 void *(*malloc_fn) (size_t), -                 void *(*realloc_fn) (void*,size_t), -                 void (*free_fn) (void*)); - -/***************************************************************************** - * hashtable_insert -    - * @name        hashtable_insert - * @param   h   the hashtable to insert into - * @param   k   the key - hashtable claims ownership and will free on removal - * @param   v   the value - does not claim ownership - * @return      non-zero for successful insertion - * - * This function will cause the table to expand if the insertion would take - * the ratio of entries to table size over the maximum load factor. - * - * This function does not check for repeated insertions with a duplicate key. - * The value returned when using a duplicate key is undefined -- when - * the hashtable changes size, the order of retrieval of duplicate key - * entries is reversed. - * If in doubt, remove before insert. - */ - -int  -hashtable_insert(struct hashtable *h, void *k, void *v); - -#define DEFINE_HASHTABLE_INSERT(fnname, keytype, valuetype) \ -int fnname (struct hashtable *h, keytype *k, valuetype *v) \ -{ \ -    return hashtable_insert(h,k,v); \ -} - -/***************************************************************************** - * hashtable_search -    - * @name        hashtable_search - * @param   h   the hashtable to search - * @param   k   the key to search for  - does not claim ownership - * @return      the value associated with the key, or NULL if none found - */ - -void * -hashtable_search(struct hashtable *h, void *k); - -#define DEFINE_HASHTABLE_SEARCH(fnname, keytype, valuetype) \ -valuetype * fnname (struct hashtable *h, keytype *k) \ -{ \ -    return (valuetype *) (hashtable_search(h,k)); \ -} - -/***************************************************************************** - * hashtable_remove -    - * @name        hashtable_remove - * @param   h   the hashtable to remove the item from - * @param   k   the key to search for  - does not claim ownership - * @return      the value associated with the key, or NULL if none found - */ - -void * /* returns value */ -hashtable_remove(struct hashtable *h, void *k); - -#define DEFINE_HASHTABLE_REMOVE(fnname, keytype, valuetype) \ -valuetype * fnname (struct hashtable *h, keytype *k, void (*f) (void *)) \ -{ \ -    return (valuetype *) (hashtable_remove(h,k,f)); \ -} - - -/***************************************************************************** - * hashtable_count -    - * @name        hashtable_count - * @param   h   the hashtable - * @return      the number of items stored in the hashtable - */ -unsigned int -hashtable_count(struct hashtable *h); - - -/***************************************************************************** - * hashtable_destroy -    - * @name        hashtable_destroy - * @param   h   the hashtable - */ - -void -hashtable_destroy(struct hashtable *h); - -#endif /* __HASHTABLE_CWC22_H__ */ - -/* - * Copyright (c) 2002, Christopher Clark - * All rights reserved. - *  - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - *  - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - *  - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - *  - * * Neither the name of the original author; nor the names of any contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - *  - *  - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER - * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, - * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, - * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF - * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING - * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ diff --git a/code/ecp/htable/hashtable_itr.c b/code/ecp/htable/hashtable_itr.c deleted file mode 100755 index 3ee8fe2..0000000 --- a/code/ecp/htable/hashtable_itr.c +++ /dev/null @@ -1,214 +0,0 @@ -/* Copyright (C) 2002, 2004 Christopher Clark  <firstname.lastname@cl.cam.ac.uk> */ - -#include "hashtable.h" -#include "hashtable_private.h" -#include "hashtable_itr.h" -#include <stdlib.h> /* defines NULL */ - -/*****************************************************************************/ -/* hashtable_iterator    - iterator constructor */ - -int -hashtable_iterator(struct hashtable_itr *itr, struct hashtable *h) -{ -    unsigned int i, tablelength; -    itr->h = h; -    itr->e = NULL; -    itr->parent = NULL; -    tablelength = h->tablelength; -    itr->index = tablelength; -    if (0 == h->entrycount) return -1; - -    for (i = 0; i < tablelength; i++) -    { -        if (NULL != h->table[i]) -        { -            itr->e = h->table[i]; -            itr->index = i; -            break; -        } -    } -    return -1; -} - -/*****************************************************************************/ -/* key      - return the key of the (key,value) pair at the current position */ -/* value    - return the value of the (key,value) pair at the current position */ - -void * -hashtable_iterator_key(struct hashtable_itr *i) -{ return i->e->k; } - -void * -hashtable_iterator_value(struct hashtable_itr *i) -{ return i->e->v; } - -/*****************************************************************************/ -/* advance - advance the iterator to the next element - *           returns zero if advanced to end of table */ - -int -hashtable_iterator_advance(struct hashtable_itr *itr) -{ -    unsigned int j,tablelength; -    struct entry **table; -    struct entry *next; -    if (NULL == itr->e) return 0; /* stupidity check */ - -    next = itr->e->next; -    if (NULL != next) -    { -        itr->parent = itr->e; -        itr->e = next; -        return -1; -    } -    tablelength = itr->h->tablelength; -    itr->parent = NULL; -    if (tablelength <= (j = ++(itr->index))) -    { -        itr->e = NULL; -        return 0; -    } -    table = itr->h->table; -    while (NULL == (next = table[j])) -    { -        if (++j >= tablelength) -        { -            itr->index = tablelength; -            itr->e = NULL; -            return 0; -        } -    } -    itr->index = j; -    itr->e = next; -    return -1; -} - -/*****************************************************************************/ -/* remove - remove the entry at the current iterator position - *          and advance the iterator, if there is a successive - *          element. - *          If you want the value, read it before you remove: - *          beware memory leaks if you don't. - *          Returns zero if end of iteration. --- modified by majstor */ - -int -hashtable_iterator_remove(struct hashtable_itr *itr) -{ -    struct entry *remember_e, *remember_parent; -    int ret; - -    /* Do the removal */ -    if (NULL == (itr->parent)) -    { -        /* element is head of a chain */ -        itr->h->table[itr->index] = itr->e->next; -    } else { -        /* element is mid-chain */ -        itr->parent->next = itr->e->next; -    } -    /* itr->e is now outside the hashtable */ -    remember_e = itr->e; -    itr->h->entrycount--; -    if (itr->h->fn_free_k) itr->h->fn_free_k(remember_e->k); -    if (itr->h->fn_free_v) itr->h->fn_free_v(remember_e->v); - -    /* Advance the iterator, correcting the parent */ -    remember_parent = itr->parent; -    ret = hashtable_iterator_advance(itr); -    if (itr->parent == remember_e) { itr->parent = remember_parent; } -    itr->h->fn_free(remember_e); -    return ret; -} - -/*****************************************************************************/ -int /* returns zero if not found */ -hashtable_iterator_search(struct hashtable_itr *itr, void *k) -{ -    struct entry *e, *parent; -    unsigned int hashvalue, index; -    struct hashtable *h = itr->h; -     -    hashvalue = hashtable_hash(h,k); -    index = indexFor(h->tablelength,hashvalue); - -    e = h->table[index]; -    parent = NULL; -    while (NULL != e) -    { -        /* Check hash value to short circuit heavier comparison */ -        if ((hashvalue == e->h) && (h->fn_eq(k, e->k))) -        { -            itr->index = index; -            itr->e = e; -            itr->parent = parent; -            itr->h = h; -            return -1; -        } -        parent = e; -        e = e->next; -    } -    return 0; -} - - -/*****************************************************************************/ -int /* returns zero if not found */ -hashtable_iterator_search_next(struct hashtable_itr *itr, void *k) -{ -    struct entry *e, *parent; -    unsigned int hashvalue; -    struct hashtable *h = itr->h; -    if (NULL == itr->e) return 0; /* stupidity check */ - -    hashvalue = hashtable_hash(h,k); -    parent = itr->e; -    e = itr->e->next; -    while (NULL != e) -    { -        /* Check hash value to short circuit heavier comparison */ -        if ((hashvalue == e->h) && (h->fn_eq(k, e->k))) -        { -            itr->parent = parent; -            itr->e = e; -            return -1; -        } -        parent = e; -        e = e->next; -    } -    return 0; -} - - -/* - * Copyright (c) 2002, 2004, Christopher Clark - * All rights reserved. - *  - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - *  - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - *  - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - *  - * * Neither the name of the original author; nor the names of any contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - *  - *  - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER - * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, - * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, - * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF - * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING - * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ diff --git a/code/ecp/htable/hashtable_itr.h b/code/ecp/htable/hashtable_itr.h deleted file mode 100755 index 658ae83..0000000 --- a/code/ecp/htable/hashtable_itr.h +++ /dev/null @@ -1,121 +0,0 @@ -/* Copyright (C) 2002, 2004 Christopher Clark <firstname.lastname@cl.cam.ac.uk> */ - -#ifndef __HASHTABLE_ITR_CWC22__ -#define __HASHTABLE_ITR_CWC22__ -#include "hashtable.h" -#include "hashtable_private.h" /* needed to enable inlining */ - -/*****************************************************************************/ -/* This struct is only concrete here to allow the inlining of two of the - * accessor functions. */ -struct hashtable_itr -{ -    struct hashtable *h; -    struct entry *e; -    struct entry *parent; -    unsigned int index; -}; - - -/*****************************************************************************/ -/* hashtable_iterator - */ - -int -hashtable_iterator(struct hashtable_itr *, struct hashtable *h); - -/*****************************************************************************/ -/* hashtable_iterator_key - * - return the value of the (key,value) pair at the current position */ - -extern inline void * -hashtable_iterator_key(struct hashtable_itr *i) -{ -    return i->e->k; -} - -/*****************************************************************************/ -/* value - return the value of the (key,value) pair at the current position */ - -extern inline void * -hashtable_iterator_value(struct hashtable_itr *i) -{ -    return i->e->v; -} - -/*****************************************************************************/ -/* advance - advance the iterator to the next element - *           returns zero if advanced to end of table */ - -int -hashtable_iterator_advance(struct hashtable_itr *itr); - -/*****************************************************************************/ -/* remove - remove current element and advance the iterator to the next element - *          NB: if you need the value to free it, read it before - *          removing. ie: beware memory leaks! - *          returns zero if advanced to end of table */ - -int -hashtable_iterator_remove(struct hashtable_itr *itr); - -/*****************************************************************************/ -/* search - overwrite the supplied iterator, to point to the entry - *          matching the supplied key. - *          returns zero if not found. */ -int -hashtable_iterator_search(struct hashtable_itr *itr, void *k); - -#define DEFINE_HASHTABLE_ITERATOR_SEARCH(fnname, keytype) \ -int fnname (struct hashtable_itr *i, keytype *k) \ -{ \ -    return (hashtable_iterator_search(i,k)); \ -} - -/*****************************************************************************/ -/* search next - advance the iterator to point to the entry - *          matching the supplied key. - *          returns zero if not found. */ -int -hashtable_iterator_search_next(struct hashtable_itr *itr, void *k); - -#define DEFINE_HASHTABLE_ITERATOR_SEARCH_NEXT(fnname, keytype) \ -int fnname (struct hashtable_itr *i, keytype *k) \ -{ \ -    return (hashtable_iterator_search_next(i,k)); \ -} - -#endif /* __HASHTABLE_ITR_CWC22__*/ - -/* - * Copyright (c) 2002, 2004, Christopher Clark - * All rights reserved. - *  - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - *  - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - *  - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - *  - * * Neither the name of the original author; nor the names of any contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - *  - *  - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER - * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, - * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, - * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF - * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING - * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ diff --git a/code/ecp/htable/hashtable_private.h b/code/ecp/htable/hashtable_private.h deleted file mode 100755 index 2330b00..0000000 --- a/code/ecp/htable/hashtable_private.h +++ /dev/null @@ -1,84 +0,0 @@ -/* Copyright (C) 2002, 2004 Christopher Clark <firstname.lastname@cl.cam.ac.uk> */ - -#ifndef __HASHTABLE_PRIVATE_CWC22_H__ -#define __HASHTABLE_PRIVATE_CWC22_H__ - -#include "hashtable.h" - -/*****************************************************************************/ -struct entry -{ -    void *k, *v; -    unsigned int h; -    struct entry *next; -}; - -struct hashtable { -    unsigned int tablelength; -    struct entry **table; -    unsigned int entrycount; -    unsigned int loadlimit; -    unsigned int primeindex; -    unsigned int (*fn_hash) (void *k); -    int (*fn_eq) (void *k1, void *k2); -    void *(*fn_malloc) (size_t); -    void *(*fn_realloc) (void *,size_t); -    void (*fn_free) (void *); -    void (*fn_free_k) (void *); -    void (*fn_free_v) (void *); -}; - -/*****************************************************************************/ -unsigned int -hashtable_hash(struct hashtable *h, void *k); - -/*****************************************************************************/ -/* indexFor */ -static inline unsigned int -indexFor(unsigned int tablelength, unsigned int hashvalue) { -    return (hashvalue % tablelength); -}; - -/* Only works if tablelength == 2^N */ -/* -static inline unsigned int -indexFor(unsigned int tablelength, unsigned int hashvalue) -{ -    return (hashvalue & (tablelength - 1u)); -} -*/ - -#endif /* __HASHTABLE_PRIVATE_CWC22_H__*/ - -/* - * Copyright (c) 2002, Christopher Clark - * All rights reserved. - *  - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - *  - * * Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - *  - * * Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - *  - * * Neither the name of the original author; nor the names of any contributors - * may be used to endorse or promote products derived from this software - * without specific prior written permission. - *  - *  - * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS - * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT - * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR - * A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER - * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, - * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, - * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR - * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF - * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING - * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS - * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. -*/ diff --git a/code/ecp/htable/htable.c b/code/ecp/htable/htable.c deleted file mode 100644 index a46291b..0000000 --- a/code/ecp/htable/htable.c +++ /dev/null @@ -1,28 +0,0 @@ -#include <core.h> -#include <ht.h> -#include <cr.h> - -#include "hashtable.h" - -void *ecp_ht_create(ECPContext *ctx) { -    return create_hashtable(1000, (unsigned int (*)(void *))ecp_cr_dh_pub_hash_fn, (int (*)(void *, void *))ecp_cr_dh_pub_hash_eq, NULL, NULL, NULL); -} - -void ecp_ht_destroy(void *h) { -    hashtable_destroy(h); -} - -int ecp_ht_insert(void *h, unsigned char *k, ECPConnection *v) { -    int rv = hashtable_insert(h, k, v); -    if (!rv) return ECP_ERR; -    return ECP_OK; -} - -ECPConnection *ecp_ht_remove(void *h, unsigned char *k) { -    return hashtable_remove(h, k); -} - -ECPConnection *ecp_ht_search(void *h, unsigned char *k) { -    return hashtable_search(h, k); -} - | 
