X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;ds=sidebyside;f=libmemcached%2Fmemcached.hh;h=479693a71df2e63807a6d99a920a1e13fd434201;hb=d76b611a9173f8ea494b6287d768fdce39159958;hp=f7e349e7ee2fca05a4e28a8e8b5e78424f89610a;hpb=8fce86636639afaeac4ca0e869e8bcd833324a62;p=awesomized%2Flibmemcached diff --git a/libmemcached/memcached.hh b/libmemcached/memcached.hh index f7e349e7..479693a7 100644 --- a/libmemcached/memcached.hh +++ b/libmemcached/memcached.hh @@ -9,6 +9,7 @@ class Memcached { memcached_st memc; + memcached_result_st result; public: @@ -21,8 +22,15 @@ public: { memcached_clone(&memc, clone); } + char *fetch (char *key, size_t *key_length, size_t *value_length) + { + uint32_t flags; + memcached_return rc; - char *get(char *key, size_t *value_length) + return memcached_fetch(&memc, key, key_length, + value_length, &flags, &rc); + } + char *get(const char *key, size_t *value_length) { uint32_t flags; memcached_return rc; @@ -31,29 +39,33 @@ public: value_length, &flags, &rc); } - char *get_by_key(char *master_key, char *key, size_t *value_length) + char *get_by_key(const char *master_key, const char *key, + size_t *value_length) { uint32_t flags; memcached_return rc; - return memcached_get_by_key(&memc, master_key, strlen(master_key), key, strlen(key), + return memcached_get_by_key(&memc, master_key, strlen(master_key), + key, strlen(key), value_length, &flags, &rc); } - memcached_return mget(char **keys, size_t *key_length, unsigned int number_of_keys) + memcached_return mget(char **keys, size_t *key_length, + unsigned int number_of_keys) { return memcached_mget(&memc, keys, key_length, number_of_keys); } - memcached_return set(char *key, char *value, size_t value_length) + memcached_return set(const char *key, const char *value, size_t value_length) { return memcached_set(&memc, key, strlen(key), value, value_length, (time_t)0, (uint32_t)0); } - memcached_return set_by_key(char *master_key, char *key, char *value, size_t value_length) + memcached_return set_by_key(const char *master_key, const char *key, + const char *value, size_t value_length) { return memcached_set_by_key(&memc, master_key, strlen(master_key), key, strlen(key), @@ -61,40 +73,121 @@ public: (time_t)0, (uint32_t)0 ); } + memcached_return + increment(const char *key, unsigned int offset, uint64_t *value) + { + return memcached_increment(&memc, key, strlen(key), + offset, value); + } + memcached_return + decrement(const char *key, unsigned int offset, uint64_t *value) + { + return memcached_decrement(&memc, key, strlen(key), + offset, value); + } - memcached_return add(char *key, char *value, size_t value_length) + memcached_return add(const char *key, const char *value, size_t value_length) { return memcached_add(&memc, key, strlen(key), value, value_length, (time_t)0, (uint32_t)0); } + memcached_return add_by_key(const char *master_key, const char *key, + const char *value, size_t value_length) + { + return memcached_add_by_key(&memc, master_key, strlen(master_key), + key, strlen(key), + value, value_length, + (time_t)0, (uint32_t)0); + } - memcached_return replace(char *key, char *value, size_t value_length) + memcached_return replace(const char *key, const char *value, + size_t value_length) { return memcached_replace(&memc, key, strlen(key), value, value_length, (time_t)0, (uint32_t)0); } + memcached_return replace_by_key(const char *master_key, const char *key, + const char *value, size_t value_length) + { + return memcached_replace_by_key(&memc, master_key, strlen(master_key), + key, strlen(key), + value, value_length, + (time_t)0, (uint32_t)0); + } - memcached_return prepend(char *key, char *value, size_t value_length) + memcached_return prepend(const char *key, const char *value, + size_t value_length) { return memcached_prepend(&memc, key, strlen(key), value, value_length, (time_t)0, (uint32_t)0); } + memcached_return prepend_by_key(const char *master_key, const char *key, + const char *value, size_t value_length) + { + return memcached_prepend_by_key(&memc, master_key, strlen(master_key), + key, strlen(key), + value, value_length, + (time_t)0, + (uint32_t)0); + } - - memcached_return append(char *key, char *value, size_t value_length) + memcached_return append(const char *key, const char *value, + size_t value_length) { return memcached_append(&memc, key, strlen(key), value, value_length, (time_t)0, (uint32_t)0); } - ~Memcached() - { - memcached_free(&memc); - } + memcached_return append_by_key(const char *master_key, const char *key, + const char *value, size_t value_length) + { + return memcached_append_by_key(&memc, + master_key, strlen(master_key), + key, strlen(key), + value, value_length, + (time_t)0, + (uint32_t)0); + } + memcached_return cas(const char *key, const char *value, + size_t value_length, uint64_t cas) + { + return memcached_cas(&memc, key, strlen(key), + value, value_length, + (time_t)0, + (uint32_t)0, + cas); + } + memcached_return cas_by_key(const char *master_key, const char *key, + const char *value, size_t value_length, + uint64_t cas) + { + return memcached_cas_by_key(&memc, + master_key, strlen(master_key), + key, strlen(key), + value, value_length, + (time_t)0, + (uint32_t)0, + cas); + } + // using 'remove' vs. 'delete' since 'delete' is a keyword + memcached_return remove(const char *key) + { + return memcached_delete (&memc, key, strlen(key), (time_t)0); + + } + memcached_return delete_by_key(const char *master_key, const char *key) + { + return memcached_delete_by_key(&memc, master_key, strlen(master_key), + key, strlen(key), (time_t)0); + } + ~Memcached() + { + memcached_free(&memc); + } };