X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fmemcached.h;h=c6b898dc9f38dc855f0bc4aa46171963e215fdbc;hb=02fa1c85c842e175225f74b0e213a5600d4c03cf;hp=d67a213706f28a11ca8b7c96482a4c7071de123f;hpb=f537d3eebdb3659ad3c3b3ad70df63ea964f1e83;p=m6w6%2Flibmemcached diff --git a/libmemcached/memcached.h b/libmemcached/memcached.h index d67a2137..c6b898dc 100644 --- a/libmemcached/memcached.h +++ b/libmemcached/memcached.h @@ -45,25 +45,13 @@ extern "C" { #endif struct memcached_st { + /** + @note these are static and should not change without a call to behavior. + */ struct { - bool is_allocated:1; - bool is_initialized:1; bool is_purging:1; - } options; - memcached_server_distribution_t distribution; - memcached_hash_t hash; - uint32_t continuum_points_counter; - memcached_server_st *hosts; - memcached_server_st *last_disconnected_server; - int32_t snd_timeout; - int32_t rcv_timeout; - uint32_t server_failure_limit; - uint32_t io_msg_watermark; - uint32_t io_bytes_watermark; - uint32_t io_key_prefetch; - uint32_t number_of_hosts; - int cached_errno; - struct { + bool is_processing_input:1; + // Everything below here is pretty static. bool auto_eject_hosts:1; bool binary_protocol:1; bool buffer_requests:1; @@ -79,20 +67,34 @@ struct memcached_st { bool use_sort_hosts:1; bool use_udp:1; bool verify_key:1; + bool cork:1; } flags; + memcached_server_distribution_t distribution; + memcached_hash_t hash; + uint32_t continuum_points_counter; // Ketama + memcached_server_st *servers; + memcached_server_st *last_disconnected_server; + int32_t snd_timeout; + int32_t rcv_timeout; + uint32_t server_failure_limit; + uint32_t io_msg_watermark; + uint32_t io_bytes_watermark; + uint32_t io_key_prefetch; + uint32_t number_of_hosts; + int cached_errno; int32_t poll_timeout; int32_t connect_timeout; int32_t retry_timeout; - uint32_t continuum_count; + uint32_t continuum_count; // Ketama int send_size; int recv_size; void *user_data; - time_t next_distribution_rebuild; + time_t next_distribution_rebuild; // Ketama size_t prefix_key_length; uint32_t number_of_replicas; memcached_hash_t distribution_hash; memcached_result_st result; - memcached_continuum_item_st *continuum; + memcached_continuum_item_st *continuum; // Ketama memcached_clone_fn on_clone; memcached_cleanup_fn on_cleanup; memcached_free_fn call_free; @@ -103,6 +105,9 @@ struct memcached_st { memcached_trigger_delete_key_fn delete_trigger; memcached_callback_st *callbacks; char prefix_key[MEMCACHED_PREFIX_KEY_MAX_SIZE]; + struct { + bool is_allocated:1; + } options; }; LIBMEMCACHED_API @@ -111,6 +116,12 @@ memcached_return_t memcached_version(memcached_st *ptr); LIBMEMCACHED_API void memcached_servers_reset(memcached_st *ptr); +// Local Only Inline +static inline memcached_server_st *memcached_server_instance_fetch(memcached_st *ptr, uint32_t server_key) +{ + return &ptr->servers[server_key]; +} + /* Public API */ LIBMEMCACHED_API @@ -239,8 +250,13 @@ void *memcached_set_user_data(memcached_st *ptr, void *data); LIBMEMCACHED_LOCAL memcached_return_t run_distribution(memcached_st *ptr); +// 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)) #ifdef __cplusplus }