Commit 8298740dd9a56859459b0e191b675c43fb95ea81
1 parent
063189e6
move sdbm implementation in one file.
Showing
8 changed files
with
49 additions
and
62 deletions
| 1 | +2012-02-20 18:08:23 +0100 Georg Hopp | ||
| 2 | + | ||
| 3 | + * move sdbm implementation in one file. (HEAD, master) | ||
| 4 | + | ||
| 1 | 2012-02-20 17:16:44 +0100 Georg Hopp | 5 | 2012-02-20 17:16:44 +0100 Georg Hopp |
| 2 | 6 | ||
| 3 | - * changed /**/ single line comments to // (HEAD, master) | 7 | + * changed /**/ single line comments to // (origin/master, origin/HEAD) |
| 4 | 8 | ||
| 5 | 2012-02-20 14:55:46 +0100 Georg Hopp | 9 | 2012-02-20 14:55:46 +0100 Georg Hopp |
| 6 | 10 | ||
| 7 | - * start documenting this whole stuff...well at least add a copyright information in each file (origin/master, origin/HEAD) | 11 | + * start documenting this whole stuff...well at least add a copyright information in each file |
| 8 | 12 | ||
| 9 | 2012-02-20 10:10:29 +0100 Georg Hopp | 13 | 2012-02-20 10:10:29 +0100 Georg Hopp |
| 10 | 14 |
include/hash.h
0 → 100644
| @@ -40,6 +40,6 @@ bin_PROGRAMS = testserver | @@ -40,6 +40,6 @@ bin_PROGRAMS = testserver | ||
| 40 | testserver_SOURCES = testserver.c \ | 40 | testserver_SOURCES = testserver.c \ |
| 41 | $(IFACE) $(CLASS) $(SOCKET) $(SERVER) $(LOGGER) $(MSG) $(REQ) \ | 41 | $(IFACE) $(CLASS) $(SOCKET) $(SERVER) $(LOGGER) $(MSG) $(REQ) \ |
| 42 | $(WRITER) $(RESP) $(HEADER) $(PARSER) $(WORKER) $(CB) \ | 42 | $(WRITER) $(RESP) $(HEADER) $(PARSER) $(WORKER) $(CB) \ |
| 43 | - signalHandling.c daemonize.c | 43 | + signalHandling.c daemonize.c hash.c |
| 44 | testserver_CFLAGS = -Wall -I ../include/ | 44 | testserver_CFLAGS = -Wall -I ../include/ |
| 45 | testserver_LDFLAGS = -lrt | 45 | testserver_LDFLAGS = -lrt |
src/hash.c
0 → 100644
| 1 | +#include <ctype.h> | ||
| 2 | + | ||
| 3 | +#include "hash.h" | ||
| 4 | + | ||
| 5 | +/** | ||
| 6 | + * SDBM hashing algorithm: | ||
| 7 | + * | ||
| 8 | + * this algorithm was created for sdbm (a public-domain reimplementation of | ||
| 9 | + * ndbm) database library. it was found to do well in scrambling bits, | ||
| 10 | + * causing better distribution of the keys and fewer splits. it also happens | ||
| 11 | + * to be a good general hashing function with good distribution. the actual | ||
| 12 | + * function is hash(i) = hash(i - 1) * 65599 + str[i]; what is included below | ||
| 13 | + * is the faster version used in gawk. [there is even a faster, duff-device | ||
| 14 | + * version] the magic constant 65599 was picked out of thin air while | ||
| 15 | + * experimenting with different constants, and turns out to be a prime. this | ||
| 16 | + * is one of the algorithms used in berkeley db (see sleepycat) and elsewhere. | ||
| 17 | + */ | ||
| 18 | +unsigned long | ||
| 19 | +sdbm(const unsigned char * str) | ||
| 20 | +{ | ||
| 21 | + unsigned long hash = 0; | ||
| 22 | + int c; | ||
| 23 | + | ||
| 24 | + while ((c = tolower(*str++))) | ||
| 25 | + hash = c + (hash << 6) + (hash << 16) - hash; | ||
| 26 | + | ||
| 27 | + return hash; | ||
| 28 | +} | ||
| 29 | + | ||
| 30 | +// vim: set ts=4 sw=4: |
| @@ -23,40 +23,13 @@ | @@ -23,40 +23,13 @@ | ||
| 23 | 23 | ||
| 24 | #include <stdlib.h> | 24 | #include <stdlib.h> |
| 25 | #include <string.h> | 25 | #include <string.h> |
| 26 | -#include <ctype.h> | ||
| 27 | 26 | ||
| 27 | +#include "hash.h" | ||
| 28 | #include "class.h" | 28 | #include "class.h" |
| 29 | #include "interface/class.h" | 29 | #include "interface/class.h" |
| 30 | 30 | ||
| 31 | #include "http/header.h" | 31 | #include "http/header.h" |
| 32 | 32 | ||
| 33 | -/** | ||
| 34 | - * SDBM hashing algorithm: | ||
| 35 | - * | ||
| 36 | - * this algorithm was created for sdbm (a public-domain reimplementation of | ||
| 37 | - * ndbm) database library. it was found to do well in scrambling bits, | ||
| 38 | - * causing better distribution of the keys and fewer splits. it also happens | ||
| 39 | - * to be a good general hashing function with good distribution. the actual | ||
| 40 | - * function is hash(i) = hash(i - 1) * 65599 + str[i]; what is included below | ||
| 41 | - * is the faster version used in gawk. [there is even a faster, duff-device | ||
| 42 | - * version] the magic constant 65599 was picked out of thin air while | ||
| 43 | - * experimenting with different constants, and turns out to be a prime. this | ||
| 44 | - * is one of the algorithms used in berkeley db (see sleepycat) and elsewhere. | ||
| 45 | - */ | ||
| 46 | -static | ||
| 47 | -inline | ||
| 48 | -unsigned long | ||
| 49 | -sdbm(unsigned char * str) | ||
| 50 | -{ | ||
| 51 | - unsigned long hash = 0; | ||
| 52 | - int c; | ||
| 53 | - | ||
| 54 | - while ((c = tolower(*str++))) | ||
| 55 | - hash = c + (hash << 6) + (hash << 16) - hash; | ||
| 56 | - | ||
| 57 | - return hash; | ||
| 58 | -} | ||
| 59 | - | ||
| 60 | static | 33 | static |
| 61 | void | 34 | void |
| 62 | ctor(void * _this, va_list * params) { | 35 | ctor(void * _this, va_list * params) { |
| @@ -22,29 +22,15 @@ | @@ -22,29 +22,15 @@ | ||
| 22 | 22 | ||
| 23 | #include <search.h> | 23 | #include <search.h> |
| 24 | #include <stdlib.h> | 24 | #include <stdlib.h> |
| 25 | -#include <ctype.h> | ||
| 26 | #include <stdio.h> | 25 | #include <stdio.h> |
| 27 | 26 | ||
| 27 | +#include "hash.h" | ||
| 28 | #include "class.h" | 28 | #include "class.h" |
| 29 | #include "interface/class.h" | 29 | #include "interface/class.h" |
| 30 | #include "http/header.h" | 30 | #include "http/header.h" |
| 31 | 31 | ||
| 32 | static | 32 | static |
| 33 | inline | 33 | inline |
| 34 | -unsigned long | ||
| 35 | -sdbm(const unsigned char * str) | ||
| 36 | -{ | ||
| 37 | - unsigned long hash = 0; | ||
| 38 | - int c; | ||
| 39 | - | ||
| 40 | - while ((c = tolower(*str++))) | ||
| 41 | - hash = c + (hash << 6) + (hash << 16) - hash; | ||
| 42 | - | ||
| 43 | - return hash; | ||
| 44 | -} | ||
| 45 | - | ||
| 46 | -static | ||
| 47 | -inline | ||
| 48 | int | 34 | int |
| 49 | comp(const void * _a, const void * _b) | 35 | comp(const void * _a, const void * _b) |
| 50 | { | 36 | { |
| @@ -24,26 +24,12 @@ | @@ -24,26 +24,12 @@ | ||
| 24 | 24 | ||
| 25 | #include <search.h> | 25 | #include <search.h> |
| 26 | #include <stdlib.h> | 26 | #include <stdlib.h> |
| 27 | -#include <ctype.h> | ||
| 28 | 27 | ||
| 28 | +#include "hash.h" | ||
| 29 | #include "http/header.h" | 29 | #include "http/header.h" |
| 30 | 30 | ||
| 31 | static | 31 | static |
| 32 | inline | 32 | inline |
| 33 | -unsigned long | ||
| 34 | -sdbm(const unsigned char * str) | ||
| 35 | -{ | ||
| 36 | - unsigned long hash = 0; | ||
| 37 | - int c; | ||
| 38 | - | ||
| 39 | - while ((c = tolower(*str++))) | ||
| 40 | - hash = c + (hash << 6) + (hash << 16) - hash; | ||
| 41 | - | ||
| 42 | - return hash; | ||
| 43 | -} | ||
| 44 | - | ||
| 45 | -static | ||
| 46 | -inline | ||
| 47 | int | 33 | int |
| 48 | comp(const void * _a, const void * _b) | 34 | comp(const void * _a, const void * _b) |
| 49 | { | 35 | { |
| @@ -65,7 +65,7 @@ httpWorkerProcess(HttpWorker this, int fd) | @@ -65,7 +65,7 @@ httpWorkerProcess(HttpWorker this, int fd) | ||
| 65 | if (NULL != httpHeaderGet( | 65 | if (NULL != httpHeaderGet( |
| 66 | &(((HttpMessage)request)->header), | 66 | &(((HttpMessage)request)->header), |
| 67 | "If-None-Match")) { | 67 | "If-None-Match")) { |
| 68 | - response = httpResponse304(handle, "image/jpeg"); | 68 | + response = (HttpMessage)httpResponse304(handle, "image/jpeg"); |
| 69 | } | 69 | } |
| 70 | else { | 70 | else { |
| 71 | response = (HttpMessage)httpResponseImage(handle); | 71 | response = (HttpMessage)httpResponseImage(handle); |
Please
register
or
login
to post a comment