X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libmemcached%2Fhosts.cc;h=db6398914a699472d6163c3d4327b9f882e93055;hb=7abcaebdc4c3dd11b779eaef58a7371fb82ae888;hp=32bf8ce37d9301bd6139feb77aecb041e1e3a07b;hpb=28adf7b936c6f5c25b7526ff56ec1256da1246d4;p=m6w6%2Flibmemcached diff --git a/libmemcached/hosts.cc b/libmemcached/hosts.cc index 32bf8ce3..db639891 100644 --- a/libmemcached/hosts.cc +++ b/libmemcached/hosts.cc @@ -344,7 +344,9 @@ static memcached_return_t update_continuum(memcached_st *ptr) memcached_return_t memcached_server_push(memcached_st *ptr, const memcached_server_list_st list) { if (not list) + { return MEMCACHED_SUCCESS; + } uint32_t count= memcached_server_list_count(list); @@ -362,21 +364,19 @@ memcached_return_t memcached_server_push(memcached_st *ptr, const memcached_serv memcached_server_write_instance_st instance; if ((ptr->flags.use_udp && list[x].type != MEMCACHED_CONNECTION_UDP) - || ((list[x].type == MEMCACHED_CONNECTION_UDP) - && ! (ptr->flags.use_udp)) ) + or ((list[x].type == MEMCACHED_CONNECTION_UDP) and not (ptr->flags.use_udp)) ) { return MEMCACHED_INVALID_HOST_PROTOCOL; } WATCHPOINT_ASSERT(list[x].hostname[0] != 0); + // We have extended the array, and now we will find it, and use it. instance= memcached_server_instance_fetch(ptr, memcached_server_count(ptr)); WATCHPOINT_ASSERT(instance); - /* TODO check return type */ - instance= memcached_server_create_with(ptr, instance, list[x].hostname, - list[x].port, list[x].weight, list[x].type); - if (not instance) + if (not __server_create_with(ptr, instance, list[x].hostname, + list[x].port, list[x].weight, list[x].type)) { return memcached_set_error(*ptr, MEMCACHED_MEMORY_ALLOCATION_FAILURE, MEMCACHED_AT); } @@ -454,7 +454,7 @@ memcached_return_t memcached_server_add_with_weight(memcached_st *ptr, if (not hostname) hostname= "localhost"; - return server_add(ptr, hostname, port, weight, MEMCACHED_CONNECTION_TCP); + return server_add(ptr, hostname, port, weight, hostname[0] == '/' ? MEMCACHED_CONNECTION_UNIX_SOCKET : MEMCACHED_CONNECTION_TCP); } static memcached_return_t server_add(memcached_st *ptr, const char *hostname, @@ -480,7 +480,10 @@ static memcached_return_t server_add(memcached_st *ptr, const char *hostname, /* TODO: Check return type */ memcached_server_write_instance_st instance= memcached_server_instance_fetch(ptr, memcached_server_count(ptr)); - (void)memcached_server_create_with(ptr, instance, hostname, port, weight, type); + if (not __server_create_with(ptr, instance, hostname, port, weight, type)) + { + return memcached_set_error(*ptr, MEMCACHED_MEMORY_ALLOCATION_FAILURE, MEMCACHED_AT); + } if (weight > 1) { @@ -489,6 +492,7 @@ static memcached_return_t server_add(memcached_st *ptr, const char *hostname, ptr->number_of_hosts++; + // @note we place the count in the bottom of the server list instance= memcached_server_instance_fetch(ptr, 0); memcached_servers_set_count(instance, memcached_server_count(ptr));