X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libhashkit%2Ftypes.h;h=255620b838ed529a4fcc1ddce12370c4183a6785;hb=81416ab2d4fe60d5c71ea11326a351993c539002;hp=fadb4d939322704d3955830c019951466afe056b;hpb=a81bddebd55105aefa57af7cc87adbda3d1a022e;p=m6w6%2Flibmemcached diff --git a/libhashkit/types.h b/libhashkit/types.h index fadb4d93..255620b8 100644 --- a/libhashkit/types.h +++ b/libhashkit/types.h @@ -11,6 +11,7 @@ #define HASHKIT_TYPES_H #ifdef __cplusplus + extern "C" { #endif @@ -18,6 +19,8 @@ typedef enum { HASHKIT_SUCCESS, HASHKIT_FAILURE, HASHKIT_MEMORY_ALLOCATION_FAILURE, + HASHKIT_INVALID_HASH, + HASHKIT_INVALID_ARGUMENT, HASHKIT_MAXIMUM_RETURN /* Always add new error code before */ } hashkit_return_t; @@ -32,6 +35,7 @@ typedef enum { HASHKIT_HASH_HSIEH, HASHKIT_HASH_MURMUR, HASHKIT_HASH_JENKINS, + HASHKIT_HASH_CUSTOM, HASHKIT_HASH_MAX } hashkit_hash_algorithm_t; @@ -48,7 +52,8 @@ typedef enum typedef struct hashkit_st hashkit_st; -typedef uint32_t (*hashkit_hash_fn)(const char *key, size_t key_length); + +typedef uint32_t (*hashkit_hash_fn)(const char *key, size_t key_length, void *context); #ifdef __cplusplus }