X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=lib%2Fmemcached_delete.c;h=7c026cbcd9835005833220fd008f4e07c7856801;hb=3bd95102380ff8d9f2599f0965c09776344d0691;hp=ecd7d8dc1b203cad509f1616939981b1b0a1a48a;hpb=cf34e0d38a58e81ec3993af0db6c221585d712e5;p=m6w6%2Flibmemcached diff --git a/lib/memcached_delete.c b/lib/memcached_delete.c index ecd7d8dc..7c026cbc 100644 --- a/lib/memcached_delete.c +++ b/lib/memcached_delete.c @@ -3,19 +3,30 @@ memcached_return memcached_delete(memcached_st *ptr, char *key, size_t key_length, time_t expiration) { - size_t send_length, sent_length; + return memcached_delete_by_key(ptr, key, key_length, + key, key_length, expiration); +} + +memcached_return memcached_delete_by_key(memcached_st *ptr, + char *master_key, size_t master_key_length, + char *key, size_t key_length, + time_t expiration) +{ + char to_write; + size_t send_length; memcached_return rc; char buffer[MEMCACHED_DEFAULT_COMMAND_SIZE]; unsigned int server_key; LIBMEMCACHED_MEMCACHED_DELETE_START(); - rc= memcached_connect(ptr); + if (key_length == 0) + return MEMCACHED_NO_KEY_PROVIDED; - if (rc != MEMCACHED_SUCCESS) - return rc; + if (ptr->hosts == NULL || ptr->number_of_hosts == 0) + return MEMCACHED_NO_SERVERS; - server_key= memcached_generate_hash(key, key_length) % ptr->number_of_hosts; + server_key= memcached_generate_hash(ptr, master_key, master_key_length); if (expiration) send_length= snprintf(buffer, MEMCACHED_DEFAULT_COMMAND_SIZE, @@ -31,21 +42,28 @@ memcached_return memcached_delete(memcached_st *ptr, char *key, size_t key_lengt goto error; } - sent_length= send(ptr->hosts[server_key].fd, buffer, send_length, 0); + if ((ptr->flags & MEM_NO_BLOCK)) + to_write= 0; + else + to_write= 1; - if (sent_length == -1 || sent_length != send_length) - { - rc= MEMCACHED_WRITE_FAILURE; + rc= memcached_do(ptr, server_key, buffer, send_length, to_write); + if (rc != MEMCACHED_SUCCESS) goto error; - } - rc= memcached_response(ptr, buffer, MEMCACHED_DEFAULT_COMMAND_SIZE, server_key); - - if (rc == MEMCACHED_DELETED) + if ((ptr->flags & MEM_NO_BLOCK)) + { rc= MEMCACHED_SUCCESS; - - LIBMEMCACHED_MEMCACHED_DELETE_END(); + memcached_server_response_increment(ptr, server_key); + } + else + { + rc= memcached_response(ptr, buffer, MEMCACHED_DEFAULT_COMMAND_SIZE, server_key); + if (rc == MEMCACHED_DELETED) + rc= MEMCACHED_SUCCESS; + } error: + LIBMEMCACHED_MEMCACHED_DELETE_END(); return rc; }