X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fmemcached.h;h=225b20990d1f2d6a4bec4de5cb1e8781b3fc8908;hb=24353992d6086a53123cc6a42fd41b982acb0952;hp=370643150d1fa44308ac0654411ae214e348e348;hpb=cb617c6de5535ddbdb21779e02726f395b6a9d8d;p=awesomized%2Flibmemcached diff --git a/libmemcached/memcached.h b/libmemcached/memcached.h index 37064315..225b2099 100644 --- a/libmemcached/memcached.h +++ b/libmemcached/memcached.h @@ -18,31 +18,22 @@ #include #include -#ifdef MEMCACHED_INTERNAL -#include -#endif +#include +#include #include #include -#include #include #include #include #include +#include #ifdef __cplusplus extern "C" { #endif -/* These are Private and should not be used by applications */ #define MEMCACHED_VERSION_STRING_LENGTH 24 - -/* string value */ -struct memcached_continuum_item_st { - uint32_t index; - uint32_t value; -}; - -#define LIBMEMCACHED_VERSION_STRING "0.29" +#define LIBMEMCACHED_VERSION_STRING "0.34" struct memcached_analysis_st { uint32_t average_item_size; @@ -85,7 +76,11 @@ struct memcached_stat_st { struct memcached_st { uint8_t purging; bool is_allocated; + uint8_t distribution; + uint8_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; @@ -100,45 +95,56 @@ struct memcached_st { int32_t connect_timeout; int32_t retry_timeout; uint32_t continuum_count; - memcached_hash hash; int send_size; int recv_size; - memcached_server_st *hosts; void *user_data; time_t next_distribution_rebuild; size_t prefix_key_length; + memcached_hash hash_continuum; memcached_result_st result; - memcached_server_distribution distribution; memcached_continuum_item_st *continuum; memcached_clone_func on_clone; memcached_cleanup_func on_cleanup; memcached_free_function call_free; memcached_malloc_function call_malloc; memcached_realloc_function call_realloc; + memcached_calloc_function call_calloc; memcached_trigger_key get_key_failure; memcached_trigger_delete_key delete_trigger; char prefix_key[MEMCACHED_PREFIX_KEY_MAX_SIZE]; - memcached_hash hash_continuum; + uint32_t number_of_replicas; + memcached_callback_st *callbacks; }; +LIBMEMCACHED_API +memcached_return memcached_version(memcached_st *ptr); /* Public API */ + +LIBMEMCACHED_API const char * memcached_lib_version(void); +LIBMEMCACHED_API memcached_st *memcached_create(memcached_st *ptr); +LIBMEMCACHED_API void memcached_free(memcached_st *ptr); +LIBMEMCACHED_API memcached_st *memcached_clone(memcached_st *clone, memcached_st *ptr); +LIBMEMCACHED_API memcached_return memcached_delete(memcached_st *ptr, const char *key, size_t key_length, time_t expiration); -memcached_return memcached_increment(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_increment(memcached_st *ptr, const char *key, size_t key_length, uint32_t offset, uint64_t *value); -memcached_return memcached_decrement(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_decrement(memcached_st *ptr, const char *key, size_t key_length, uint32_t offset, uint64_t *value); +LIBMEMCACHED_API memcached_return memcached_increment_with_initial(memcached_st *ptr, const char *key, size_t key_length, @@ -146,6 +152,7 @@ memcached_return memcached_increment_with_initial(memcached_st *ptr, uint64_t initial, time_t expiration, uint64_t *value); +LIBMEMCACHED_API memcached_return memcached_decrement_with_initial(memcached_st *ptr, const char *key, size_t key_length, @@ -153,83 +160,138 @@ memcached_return memcached_decrement_with_initial(memcached_st *ptr, uint64_t initial, time_t expiration, uint64_t *value); +LIBMEMCACHED_API void memcached_stat_free(memcached_st *, memcached_stat_st *); +LIBMEMCACHED_API memcached_stat_st *memcached_stat(memcached_st *ptr, char *args, memcached_return *error); -memcached_return memcached_stat_servername(memcached_stat_st *stat, char *args, +LIBMEMCACHED_API +memcached_return memcached_stat_servername(memcached_stat_st *memc_stat, char *args, char *hostname, unsigned int port); +LIBMEMCACHED_API memcached_return memcached_flush(memcached_st *ptr, time_t expiration); +LIBMEMCACHED_API memcached_return memcached_verbosity(memcached_st *ptr, unsigned int verbosity); +LIBMEMCACHED_API void memcached_quit(memcached_st *ptr); -char *memcached_strerror(memcached_st *ptr, memcached_return rc); +LIBMEMCACHED_API +const char *memcached_strerror(memcached_st *ptr, memcached_return rc); +LIBMEMCACHED_API memcached_return memcached_behavior_set(memcached_st *ptr, memcached_behavior flag, uint64_t data); +LIBMEMCACHED_API uint64_t memcached_behavior_get(memcached_st *ptr, memcached_behavior flag); + +/* The two public hash bits */ +LIBMEMCACHED_API uint32_t memcached_generate_hash_value(const char *key, size_t key_length, memcached_hash hash_algorithm); +LIBMEMCACHED_API +uint32_t memcached_generate_hash(memcached_st *ptr, const char *key, size_t key_length); + +LIBMEMCACHED_API memcached_return memcached_flush_buffers(memcached_st *mem); /* Server Public functions */ -memcached_return memcached_server_add_udp(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_server_add_udp(memcached_st *ptr, const char *hostname, unsigned int port); -memcached_return memcached_server_add_unix_socket(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_server_add_unix_socket(memcached_st *ptr, const char *filename); -memcached_return memcached_server_add(memcached_st *ptr, const char *hostname, +LIBMEMCACHED_API +memcached_return memcached_server_add(memcached_st *ptr, const char *hostname, unsigned int port); -memcached_return memcached_server_add_udp_with_weight(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_server_add_udp_with_weight(memcached_st *ptr, const char *hostname, unsigned int port, uint32_t weight); -memcached_return memcached_server_add_unix_socket_with_weight(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_server_add_unix_socket_with_weight(memcached_st *ptr, const char *filename, uint32_t weight); -memcached_return memcached_server_add_with_weight(memcached_st *ptr, const char *hostname, +LIBMEMCACHED_API +memcached_return memcached_server_add_with_weight(memcached_st *ptr, const char *hostname, unsigned int port, uint32_t weight); +LIBMEMCACHED_API void memcached_server_list_free(memcached_server_st *ptr); +LIBMEMCACHED_API memcached_return memcached_server_push(memcached_st *ptr, memcached_server_st *list); -memcached_server_st *memcached_server_list_append(memcached_server_st *ptr, - const char *hostname, - unsigned int port, +LIBMEMCACHED_API +memcached_server_st *memcached_server_list_append(memcached_server_st *ptr, + const char *hostname, + unsigned int port, memcached_return *error); -memcached_server_st *memcached_server_list_append_with_weight(memcached_server_st *ptr, - const char *hostname, - unsigned int port, +LIBMEMCACHED_API +memcached_server_st *memcached_server_list_append_with_weight(memcached_server_st *ptr, + const char *hostname, + unsigned int port, uint32_t weight, memcached_return *error); +LIBMEMCACHED_API unsigned int memcached_server_list_count(memcached_server_st *ptr); +LIBMEMCACHED_API memcached_server_st *memcached_servers_parse(const char *server_strings); -char *memcached_stat_get_value(memcached_st *ptr, memcached_stat_st *stat, +LIBMEMCACHED_API +char *memcached_stat_get_value(memcached_st *ptr, memcached_stat_st *memc_stat, const char *key, memcached_return *error); -char ** memcached_stat_get_keys(memcached_st *ptr, memcached_stat_st *stat, +LIBMEMCACHED_API +char ** memcached_stat_get_keys(memcached_st *ptr, memcached_stat_st *memc_stat, memcached_return *error); -memcached_return memcached_delete_by_key(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_delete_by_key(memcached_st *ptr, const char *master_key, size_t master_key_length, const char *key, size_t key_length, time_t expiration); -memcached_return memcached_fetch_execute(memcached_st *ptr, +LIBMEMCACHED_API +memcached_return memcached_fetch_execute(memcached_st *ptr, memcached_execute_function *callback, void *context, unsigned int number_of_callbacks); -memcached_return memcached_callback_set(memcached_st *ptr, - memcached_callback flag, +LIBMEMCACHED_API +memcached_return memcached_callback_set(memcached_st *ptr, + memcached_callback flag, void *data); -void *memcached_callback_get(memcached_st *ptr, +LIBMEMCACHED_API +void *memcached_callback_get(memcached_st *ptr, memcached_callback flag, memcached_return *error); +LIBMEMCACHED_API memcached_return memcached_dump(memcached_st *ptr, memcached_dump_func *function, void *context, uint32_t number_of_callbacks); +LIBMEMCACHED_API +memcached_return memcached_set_memory_allocators(memcached_st *ptr, + memcached_malloc_function mem_malloc, + memcached_free_function mem_free, + memcached_realloc_function mem_realloc, + memcached_calloc_function mem_calloc); + +LIBMEMCACHED_API +void memcached_get_memory_allocators(memcached_st *ptr, + memcached_malloc_function *mem_malloc, + memcached_free_function *mem_free, + memcached_realloc_function *mem_realloc, + memcached_calloc_function *mem_calloc); + +LIBMEMCACHED_API +void *memcached_get_user_data(memcached_st *ptr); +LIBMEMCACHED_API +void *memcached_set_user_data(memcached_st *ptr, void *data); + +LIBMEMCACHED_API +memcached_return run_distribution(memcached_st *ptr); #ifdef __cplusplus } #endif -#include #endif /* __MEMCACHED_H__ */