X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fmemcached.c;h=4e0308a043df72b29bdc43800a475d04942c73d7;hb=d70dd7ca2db0a4f7d7c63367466567cc1efe9f68;hp=c0fee34d0e6520405e678bdaa9b2e44114e383db;hpb=9ea216e88d31ba62f89234361318a0accbbfe75a;p=m6w6%2Flibmemcached diff --git a/libmemcached/memcached.c b/libmemcached/memcached.c index c0fee34d..4e0308a0 100644 --- a/libmemcached/memcached.c +++ b/libmemcached/memcached.c @@ -132,35 +132,9 @@ memcached_st *memcached_create(memcached_st *ptr) return ptr; } -void server_list_free(memcached_st *ptr, memcached_server_st *servers) -{ - uint32_t x; - - if (servers == NULL) - return; - - for (x= 0; x < memcached_servers_count(servers); x++) - { - if (servers[x].address_info) - { - freeaddrinfo(servers[x].address_info); - servers[x].address_info= NULL; - } - } - - if (ptr) - { - libmemcached_free(ptr, servers); - } - else - { - free(servers); - } -} - void memcached_servers_reset(memcached_st *ptr) { - server_list_free(ptr, memcached_server_list(ptr)); + memcached_server_list_free(memcached_server_list(ptr)); memcached_server_list_set(ptr, NULL); ptr->number_of_hosts= 0; @@ -172,7 +146,7 @@ void memcached_free(memcached_st *ptr) { /* If we have anything open, lets close it now */ memcached_quit(ptr); - server_list_free(ptr, memcached_server_list(ptr)); + memcached_server_list_free(memcached_server_list(ptr)); memcached_result_free(&ptr->result); if (ptr->on_cleanup) @@ -252,8 +226,8 @@ memcached_st *memcached_clone(memcached_st *clone, const memcached_st *source) new_clone->io_key_prefetch= source->io_key_prefetch; new_clone->number_of_replicas= source->number_of_replicas; - if (memcached_server_list(source)) - rc= memcached_server_push(new_clone, memcached_server_list(source)); + if (memcached_server_count(source)) + rc= memcached_push(new_clone, source); if (rc != MEMCACHED_SUCCESS) { @@ -296,3 +270,18 @@ void *memcached_set_user_data(memcached_st *ptr, void *data) return ret; } + +memcached_return_t memcached_push(memcached_st *destination, const memcached_st *source) +{ + return memcached_server_push(destination, source->servers); +} + +inline memcached_server_write_instance_st memcached_server_instance_fetch(memcached_st *ptr, uint32_t server_key) +{ + return &ptr->servers[server_key]; +} + +inline memcached_server_instance_st memcached_server_instance_by_position(const memcached_st *ptr, uint32_t server_key) +{ + return &ptr->servers[server_key]; +}