X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fmemcached.cc;h=2eb91281e42176f3e72e096f3021df1f938a03e5;hb=50f05a9503f10bbc6df4eb3ea02c7cf5e36fd6c9;hp=1726b35fce634d7117bdd8244d6549200820fecb;hpb=81a0c9a7b94f27a20fab8fa60ec22e97b128ec94;p=m6w6%2Flibmemcached diff --git a/libmemcached/memcached.cc b/libmemcached/memcached.cc index 1726b35f..2eb91281 100644 --- a/libmemcached/memcached.cc +++ b/libmemcached/memcached.cc @@ -124,7 +124,7 @@ static inline bool _memcached_init(memcached_st *self) return true; } -static void _free(memcached_st *ptr, bool release_st) +static void __memcached_free(memcached_st *ptr, bool release_st) { /* If we have anything open, lets close it now */ send_quit(ptr); @@ -158,7 +158,9 @@ static void _free(memcached_st *ptr, bool release_st) ptr->configure.filename= NULL; } - if (memcached_is_allocated(ptr) && release_st) + hashkit_free(&ptr->hashkit); + + if (memcached_is_allocated(ptr) and release_st) { libmemcached_free(ptr, ptr); } @@ -172,7 +174,7 @@ memcached_st *memcached_create(memcached_st *ptr) } else { - ptr= (memcached_st *)malloc(sizeof(memcached_st)); + ptr= (memcached_st *)libmemcached_xmalloc(NULL, memcached_st); if (ptr == NULL) { @@ -242,7 +244,7 @@ memcached_return_t memcached_reset(memcached_st *ptr) bool stored_is_allocated= memcached_is_allocated(ptr); uint64_t query_id= ptr->query_id; - _free(ptr, false); + __memcached_free(ptr, false); memcached_create(ptr); memcached_set_allocated(ptr, stored_is_allocated); ptr->query_id= query_id; @@ -281,7 +283,7 @@ void memcached_free(memcached_st *ptr) { if (ptr) { - _free(ptr, true); + __memcached_free(ptr, true); } } @@ -354,6 +356,7 @@ memcached_st *memcached_clone(memcached_st *clone, const memcached_st *source) new_clone->_namespace= memcached_array_clone(new_clone, source->_namespace); new_clone->configure.filename= memcached_array_clone(new_clone, source->_namespace); + new_clone->configure.version= source->configure.version; if (LIBMEMCACHED_WITH_SASL_SUPPORT and source->sasl.callbacks) { @@ -381,11 +384,21 @@ memcached_st *memcached_clone(memcached_st *clone, const memcached_st *source) void *memcached_get_user_data(const memcached_st *ptr) { + if (ptr == NULL) + { + return NULL; + } + return ptr->user_data; } void *memcached_set_user_data(memcached_st *ptr, void *data) { + if (ptr == NULL) + { + return NULL; + } + void *ret= ptr->user_data; ptr->user_data= data; @@ -399,18 +412,30 @@ memcached_return_t memcached_push(memcached_st *destination, const memcached_st memcached_server_write_instance_st memcached_server_instance_fetch(memcached_st *ptr, uint32_t server_key) { + if (ptr == NULL) + { + return NULL; + } + return &ptr->servers[server_key]; } memcached_server_instance_st memcached_server_instance_by_position(const memcached_st *ptr, uint32_t server_key) { + if (ptr == NULL) + { + return NULL; + } + return &ptr->servers[server_key]; } uint64_t memcached_query_id(const memcached_st *self) { - if (not self) + if (self == NULL) + { return 0; + } return self->query_id; }