X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=include%2Fmemcached.h;h=3e8cea8857d1489001ab0d8859ae812915da3945;hb=3e08799c9d80873a66e7e0b08c6524b0d5c47c28;hp=a798fef0b755f39e244877e2c3b0585f82d9aa16;hpb=1f34771f7ba527e3afb675f1a448d6c5ab66596b;p=awesomized%2Flibmemcached diff --git a/include/memcached.h b/include/memcached.h index a798fef0..3e8cea88 100644 --- a/include/memcached.h +++ b/include/memcached.h @@ -22,6 +22,7 @@ #include #include #include +#include #ifdef __cplusplus extern "C" { @@ -29,10 +30,16 @@ extern "C" { typedef struct memcached_st memcached_st; typedef struct memcached_stat_st memcached_stat_st; +typedef struct memcached_string_st memcached_string_st; +typedef struct memcached_host_st memcached_host_st; #define MEMCACHED_DEFAULT_PORT 11211 #define MEMCACHED_DEFAULT_COMMAND_SIZE 350 +#define SMALL_STRING_LEN 1024 #define HUGE_STRING_LEN 8196 +#define MEMCACHED_MAX_KEY 251 /* We add one to have it null terminated */ + +#define WATCHPOINT printf("WATCHPOINT %s:%d\n", __FILE__, __LINE__);fflush(stdout); typedef enum { MEMCACHED_SUCCESS, @@ -53,6 +60,7 @@ typedef enum { MEMCACHED_NOTFOUND, MEMCACHED_MEMORY_ALLOCATION_FAILURE, MEMCACHED_PARTIAL_READ, + MEMCACHED_SOME_ERRORS, } memcached_return; typedef enum { @@ -60,6 +68,12 @@ 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; @@ -89,9 +103,18 @@ struct memcached_stat_st { unsigned int limit_maxbytes; }; +struct memcached_string_st { + char *string; + char *end; + size_t current_size; + size_t block_size; +}; + struct memcached_st { memcached_allocated is_allocated; - int fd; + memcached_host_st *hosts; + unsigned int number_of_hosts; + unsigned int cursor_server; char connected; }; @@ -113,29 +136,58 @@ 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_stat_st **memcached_stat(memcached_st *ptr, memcached_return *error); +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); +void memcached_quit(memcached_st *ptr); 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); +memcached_return memcached_mget(memcached_st *ptr, + char **keys, size_t *key_length, + unsigned int number_of_keys); +char *memcached_fetch(memcached_st *ptr, char *key, size_t *key_length, + size_t *value_length, uint16_t *flags, + memcached_return *error); +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); + char *buffer, size_t buffer_length, + unsigned int server_key); +unsigned int memcached_generate_hash(char *key, size_t key_length); +memcached_return memcached_stat_get_value(memcached_stat_st *stat, char *key, + char *value, size_t value_length); +char ** memcached_stat_get_keys(memcached_stat_st *stat, memcached_return *error); + +/* String Struct */ +#define memcached_string_length(A, B) (size_t)(B->end - B->string) +#define memcached_string_size(A, B) B->current_size +#define memcached_string_value(A, B) B->string + +memcached_string_st *memcached_string_init(memcached_st *ptr, size_t initial_size); +memcached_return memcached_string_append_character(memcached_st *ptr, + memcached_string_st *string, + char character); +memcached_return memcached_string_append(memcached_st *ptr, memcached_string_st *string, + char *value, size_t length); +size_t memcached_string_backspace(memcached_st *ptr, memcached_string_st *string, size_t remove); +memcached_return memcached_string_reset(memcached_st *ptr, memcached_string_st *string); +void memcached_string_free(memcached_st *ptr, memcached_string_st *string); #ifdef __cplusplus }