X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=include%2Fmemcached.h;h=da704b19091dddb68b510eafa6eedccf0d43acf4;hb=bbc4466149476f043a6eabf6757f97ab42c0f6cd;hp=a3ecf7e9c6fa109454aafe166dc98c5e01b1cc40;hpb=aef60cba06c79c42f79532923aa49675386c552f;p=m6w6%2Flibmemcached diff --git a/include/memcached.h b/include/memcached.h index a3ecf7e9..da704b19 100644 --- a/include/memcached.h +++ b/include/memcached.h @@ -10,8 +10,19 @@ #ifndef __MEMCACHED_H__ #define __MEMCACHED_H__ +#include #include +#include +#include +#include +#include +#include +#include +#include +#include +#include #include +#include #ifdef __cplusplus extern "C" { @@ -19,9 +30,13 @@ extern "C" { typedef struct memcached_st memcached_st; typedef struct memcached_stat_st memcached_stat_st; +typedef struct memcached_host_st memcached_host_st; #define MEMCACHED_DEFAULT_PORT 11211 #define MEMCACHED_DEFAULT_COMMAND_SIZE 350 +#define HUGE_STRING_LEN 8196 + +#define WATCHPOINT printf("WATCHPOINT %s:%d\n", __FILE__, __LINE__);fflush(stdout); typedef enum { MEMCACHED_SUCCESS, @@ -42,6 +57,7 @@ typedef enum { MEMCACHED_NOTFOUND, MEMCACHED_MEMORY_ALLOCATION_FAILURE, MEMCACHED_PARTIAL_READ, + MEMCACHED_SOME_ERRORS, } memcached_return; typedef enum { @@ -49,14 +65,24 @@ typedef enum { MEMCACHED_ALLOCATED= 1, } memcached_allocated; +struct memcached_host_st { + char *hostname; + unsigned int port; + int fd; +}; + struct memcached_stat_st { unsigned int pid; unsigned int uptime; + unsigned int threads; time_t time; - char *version; - unsigned rusage_user_seconds; + char version[8]; + unsigned int pointer_size; + unsigned int rusage_user; + unsigned int rusage_system; + unsigned int rusage_user_seconds; unsigned int rusage_user_microseconds; - unsigned rusage_system_seconds; + unsigned int rusage_system_seconds; unsigned int rusage_system_microseconds; unsigned int curr_items; unsigned int total_items; @@ -76,7 +102,8 @@ struct memcached_stat_st { struct memcached_st { memcached_allocated is_allocated; - int fd; + memcached_host_st *hosts; + unsigned int number_of_hosts; char connected; }; @@ -98,24 +125,34 @@ memcached_return memcached_replace(memcached_st *ptr, char *key, size_t key_leng uint16_t flags); memcached_return memcached_delete(memcached_st *ptr, char *key, size_t key_length, time_t expiration); -memcached_return memcached_increment(memcached_st *ptr, char *key, size_t key_length, - unsigned int count); -memcached_return memcached_decrement(memcached_st *ptr, char *key, size_t key_length, - unsigned int count); -memcached_return memcached_stat(memcached_st *ptr, memcached_stat_st *stat); +memcached_return memcached_increment(memcached_st *ptr, + char *key, size_t key_length, + unsigned int offset, + unsigned int *value); +memcached_return memcached_decrement(memcached_st *ptr, + char *key, size_t key_length, + unsigned int offset, + unsigned int *value); +memcached_stat_st *memcached_stat(memcached_st *ptr, char *args, memcached_return *error); +memcached_return memcached_stat_hostname(memcached_stat_st *stat, char *args, + char *hostname, unsigned int port); memcached_return memcached_flush(memcached_st *ptr, time_t expiration); -char *memcached_version(memcached_st *ptr, memcached_return *error); memcached_return memcached_verbosity(memcached_st *ptr, unsigned int verbosity); -memcached_return memcached_quit(memcached_st *ptr); +memcached_return memcached_quit(memcached_st *ptr, char *hostname, unsigned port); char *memcached_get(memcached_st *ptr, char *key, size_t key_length, size_t *value_length, uint16_t *flags, memcached_return *error); -void memcached_server_add(memcached_st *ptr, char *server_name, unsigned int port); -static memcached_return memcached_response(memcached_st *ptr, - char *buffer, size_t buffer_length); +memcached_return memcached_server_add(memcached_st *ptr, char *hostname, unsigned int port); char *memcached_strerror(memcached_st *ptr, memcached_return rc); +/* These are all private, do not use. */ +memcached_return memcached_connect(memcached_st *ptr); +memcached_return memcached_response(memcached_st *ptr, + char *buffer, size_t buffer_length, + unsigned int server_key); +unsigned int memcached_generate_hash(char *key, size_t key_length); + #ifdef __cplusplus } #endif