diff options
author | John Mark Bell <jmb@netsurf-browser.org> | 2008-11-30 16:35:19 +0000 |
---|---|---|
committer | John Mark Bell <jmb@netsurf-browser.org> | 2008-11-30 16:35:19 +0000 |
commit | aa0aa44aaab4b0693400dc4307822ac493014224 (patch) | |
tree | 0fbce8307517d84a2f1eb1a295778e8dd6fff6d4 /test/hash.c | |
parent | 7712c61effc3ef39d0b9eaf060049d11441884bf (diff) | |
download | libparserutils-aa0aa44aaab4b0693400dc4307822ac493014224.tar.gz libparserutils-aa0aa44aaab4b0693400dc4307822ac493014224.tar.bz2 |
New datastructures:
+ Chunked array
+ Hash table (open addressing)
Constify parameter to parserutils_stack_push
svn path=/trunk/libparserutils/; revision=5850
Diffstat (limited to 'test/hash.c')
-rw-r--r-- | test/hash.c | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/test/hash.c b/test/hash.c new file mode 100644 index 0000000..3eceeae --- /dev/null +++ b/test/hash.c @@ -0,0 +1,56 @@ +#include <stdio.h> +#include <stdlib.h> +#include <string.h> + +#include <parserutils/utils/hash.h> + +#include "testutils.h" + +extern void parserutils_hash_dump(parserutils_hash *hash); + +static void *myrealloc(void *ptr, size_t len, void *pw) +{ + UNUSED(pw); + + return realloc(ptr, len); +} + +int main(int argc, char **argv) +{ + parserutils_hash *hash; + uint8_t buf[256]; + + UNUSED(argc); + UNUSED(argv); + + /* Seed buffer with printable ascii */ + for (int i = 0; i < (int) sizeof(buf); i++) { + buf[i] = 97 + (int) (26.0 * (rand() / (RAND_MAX + 1.0))); + } + buf[sizeof(buf) - 1] = '\0'; + + assert(parserutils_hash_create(myrealloc, NULL, &hash) == + PARSERUTILS_OK); + + for (int i = 0; i < (int) sizeof(buf); i++) { + uint8_t *s = buf; + + while (s - buf <= i) { + const parserutils_hash_entry *e; + + parserutils_hash_insert(hash, + s, (size_t) (sizeof(buf) - i), &e); + + s++; + } + } + +// parserutils_hash_dump(hash); + + parserutils_hash_destroy(hash); + + printf("PASS\n"); + + return 0; +} + |