X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fcommon.h;h=b64af72331fc94ff3fb636dbd27cb8fa12214774;hb=8386963414b7c9d9fa5328ab1d4dd768d742ad54;hp=ad6ccd7de6f5821b3a80e263125d4a250652ef56;hpb=571fad579922f2b10873193500dfd0652f4fdc37;p=m6w6%2Flibmemcached diff --git a/libmemcached/common.h b/libmemcached/common.h index ad6ccd7d..b64af723 100644 --- a/libmemcached/common.h +++ b/libmemcached/common.h @@ -8,6 +8,7 @@ #include #include #include +#include #include #include #include @@ -21,11 +22,11 @@ #include #include -#if TIME_WITH_SYS_TIME +#ifdef TIME_WITH_SYS_TIME # include # include #else -# if HAVE_SYS_TIME_H +# ifdef HAVE_SYS_TIME_H # include # else # include @@ -37,6 +38,7 @@ #include #include "memcached_io.h" +#include "memcached/protocol_binary.h" #include #if !defined(__GNUC__) || (__GNUC__ == 2 && __GNUC_MINOR__ < 96) @@ -77,6 +79,9 @@ typedef enum { MEM_BUFFER_REQUESTS= (1 << 8), MEM_USE_SORT_HOSTS= (1 << 9), MEM_VERIFY_KEY= (1 << 10), + /* 11 used for weighted ketama */ + MEM_KETAMA_WEIGHTED= (1 << 11), + MEM_BINARY_PROTOCOL= (1 << 12) } memcached_flags; /* Hashing algo */ @@ -85,6 +90,7 @@ uint32_t hash_crc32(const char *data, size_t data_len); uint32_t hsieh_hash(const char *key, size_t key_length); uint32_t murmur_hash(const char *key, size_t key_length); +uint32_t jenkins_hash(const void *key, size_t length, uint32_t initval); memcached_return memcached_connect(memcached_server_st *ptr); memcached_return memcached_response(memcached_server_st *ptr, @@ -97,7 +103,7 @@ void memcached_quit_server(memcached_server_st *ptr, uint8_t io_death); #define memcached_server_response_decrement(A) (A)->cursor_active-- #define memcached_server_response_reset(A) (A)->cursor_active=0 -memcached_return memcached_do(memcached_server_st *ptr, const char *commmand, +memcached_return memcached_do(memcached_server_st *ptr, const void *commmand, size_t command_length, uint8_t with_flush); memcached_return memcached_version(memcached_st *ptr); memcached_return value_fetch(memcached_server_st *ptr, @@ -110,5 +116,16 @@ memcached_return memcachd_key_test(char **keys, size_t *key_length, memcached_return run_distribution(memcached_st *ptr); +uint32_t generate_hash_value(const char *key, size_t key_length, memcached_hash hash_algorithm); + uint32_t generate_hash(memcached_st *ptr, const char *key, size_t key_length); +memcached_return memcached_server_remove(memcached_server_st *st_ptr); + +extern uint64_t ntohll(uint64_t); +extern uint64_t htonll(uint64_t); + +void host_reset(memcached_st *ptr, memcached_server_st *host, + const char *hostname, unsigned int port, + memcached_connection type); + #endif /* __COMMON_H__ */