X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fcommon.h;h=18dc349a5b972bb76cf63dc91a838db50e248825;hb=8f36e509f6130022162abf7cde7e6c8acbbe224c;hp=42bafd94cf7b8358ca332ac1d0ab23f97df64db1;hpb=b62ff7f097d83abef0bf0d40d85e6c8734a8db94;p=awesomized%2Flibmemcached diff --git a/libmemcached/common.h b/libmemcached/common.h index 42bafd94..18dc349a 100644 --- a/libmemcached/common.h +++ b/libmemcached/common.h @@ -54,12 +54,15 @@ #include "libmemcached/memcached.h" #include "libmemcached/watchpoint.h" +typedef struct memcached_server_st memcached_server_instance_st; + /* These are private not to be installed headers */ #include "libmemcached/io.h" #include "libmemcached/internal.h" #include "libmemcached/libmemcached_probes.h" #include "libmemcached/memcached/protocol_binary.h" #include "libmemcached/byteorder.h" +#include "libmemcached/response.h" /* string value */ struct memcached_continuum_item_st @@ -68,6 +71,13 @@ struct memcached_continuum_item_st uint32_t value; }; +/* Yum, Fortran.... can you make the reference? */ +typedef enum { + MEM_NOT= -1, + MEM_FALSE= false, + MEM_TRUE= true, +} memcached_ternary_t; + #if !defined(__GNUC__) || (__GNUC__ == 2 && __GNUC_MINOR__ < 96) @@ -80,7 +90,6 @@ struct memcached_continuum_item_st #define unlikely(x) if(__builtin_expect((x) != 0, 0)) #endif - #define MEMCACHED_BLOCK_SIZE 1024 #define MEMCACHED_DEFAULT_COMMAND_SIZE 350 #define SMALL_STRING_LEN 1024 @@ -103,27 +112,37 @@ LIBMEMCACHED_LOCAL uint32_t jenkins_hash(const void *key, size_t length, uint32_t initval); LIBMEMCACHED_LOCAL -memcached_return_t memcached_connect(memcached_server_st *ptr); +memcached_return_t memcached_connect(memcached_server_instance_st *ptr); LIBMEMCACHED_LOCAL -memcached_return_t memcached_response(memcached_server_st *ptr, - char *buffer, size_t buffer_length, - memcached_result_st *result); +void memcached_quit_server(memcached_server_instance_st *ptr, uint8_t io_death); + LIBMEMCACHED_LOCAL -void memcached_quit_server(memcached_server_st *ptr, uint8_t io_death); +memcached_return_t run_distribution(memcached_st *ptr); #define memcached_server_response_increment(A) (A)->cursor_active++ #define memcached_server_response_decrement(A) (A)->cursor_active-- #define memcached_server_response_reset(A) (A)->cursor_active=0 +// These are private +#define memcached_is_allocated(__object) ((__object)->options.is_allocated) +#define memcached_is_initialized(__object) ((__object)->options.is_initialized) +#define memcached_is_purging(__object) ((__object)->flags.is_purging) +#define memcached_is_processing_input(__object) ((__object)->flags.is_processing_input) +#define memcached_set_purging(__object, __value) ((__object)->flags.is_purging= (__value)) +#define memcached_set_processing_input(__object, __value) ((__object)->flags.is_processing_input= (__value)) +#define memcached_set_initialized(__object, __value) ((__object)->options.is_initialized(= (__value)) +#define memcached_set_allocated(__object, __value) ((__object)->options.is_allocated(= (__value)) + + LIBMEMCACHED_LOCAL -memcached_return_t memcached_do(memcached_server_st *ptr, const void *commmand, +memcached_return_t memcached_do(memcached_server_instance_st *ptr, const void *commmand, size_t command_length, uint8_t with_flush); LIBMEMCACHED_LOCAL -memcached_return_t value_fetch(memcached_server_st *ptr, +memcached_return_t value_fetch(memcached_server_instance_st *ptr, char *buffer, memcached_result_st *result); LIBMEMCACHED_LOCAL -void server_list_free(memcached_st *ptr, memcached_server_st *servers); +void server_list_free(memcached_st *ptr, memcached_server_instance_st *servers); LIBMEMCACHED_LOCAL memcached_return_t memcached_key_test(const char * const *keys, @@ -135,7 +154,7 @@ LIBMEMCACHED_LOCAL uint32_t generate_hash(memcached_st *ptr, const char *key, size_t key_length); LIBMEMCACHED_LOCAL -memcached_return_t memcached_purge(memcached_server_st *ptr); +memcached_return_t memcached_purge(memcached_server_instance_st *ptr); static inline memcached_return_t memcached_validate_key_length(size_t key_length, bool binary) { @@ -156,4 +175,42 @@ static inline memcached_return_t memcached_validate_key_length(size_t key_length return MEMCACHED_SUCCESS; } +#ifdef TCP_CORK + #define CORK TCP_CORK +#elif defined TCP_NOPUSH + #define CORK TCP_NOPUSH +#endif + +/* + test_cork() tries to enable TCP_CORK. IF TCP_CORK is not an option + on the system it returns false but sets errno to 0. Otherwise on + failure errno is set. +*/ +static inline memcached_ternary_t test_cork(memcached_server_st *ptr, int enable) +{ +#ifdef CORK + if (ptr->type != MEMCACHED_CONNECTION_TCP) + return MEM_FALSE; + + int err= setsockopt(ptr->fd, IPPROTO_TCP, CORK, + &enable, (socklen_t)sizeof(int)); + if (! err) + { + return MEM_TRUE; + } + + perror(strerror(errno)); + ptr->cached_errno= errno; + + return MEM_FALSE; +#else + (void)ptr; + (void)enable; + + ptr->cached_errno= 0; + + return MEM_NOT; +#endif +} + #endif /* LIBMEMCACHED_COMMON_H */