X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=lib%2Fmemcached_delete.c;h=6a8495335e17a10e5f30aa167043efe6ba5e9431;hb=1bd637f6eccc1064a4e19e40b14a340818d1ccf3;hp=6fa2d4a8ff6833a3527f38ef57a31921439e1e7e;hpb=d3ef73cd144dfdbcaff41d3373e4458fb351f7af;p=m6w6%2Flibmemcached diff --git a/lib/memcached_delete.c b/lib/memcached_delete.c index 6fa2d4a8..6a849533 100644 --- a/lib/memcached_delete.c +++ b/lib/memcached_delete.c @@ -3,6 +3,7 @@ memcached_return memcached_delete(memcached_st *ptr, char *key, size_t key_length, time_t expiration) { + char to_write; size_t send_length, sent_length; memcached_return rc; char buffer[MEMCACHED_DEFAULT_COMMAND_SIZE]; @@ -10,12 +11,11 @@ memcached_return memcached_delete(memcached_st *ptr, char *key, size_t key_lengt LIBMEMCACHED_MEMCACHED_DELETE_START(); - rc= memcached_connect(ptr); + server_key= memcached_generate_hash(ptr, key, key_length); - if (rc != MEMCACHED_SUCCESS) + if ((rc= memcached_connect(ptr, server_key)) != MEMCACHED_SUCCESS) return rc; - server_key= memcached_generate_hash(ptr, key, key_length); if (expiration) send_length= snprintf(buffer, MEMCACHED_DEFAULT_COMMAND_SIZE, @@ -31,18 +31,29 @@ memcached_return memcached_delete(memcached_st *ptr, char *key, size_t key_lengt goto error; } - sent_length= memcached_io_write(ptr, server_key, buffer, send_length, 1); + if ((ptr->flags & MEM_NO_BLOCK)) + to_write= 0; + else + to_write= 1; - if (sent_length == -1 || sent_length != send_length) + if ((sent_length= memcached_io_write(ptr, server_key, buffer, send_length, to_write)) == -1) { + memcached_quit_server(ptr, server_key); rc= MEMCACHED_WRITE_FAILURE; 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; + 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; + } LIBMEMCACHED_MEMCACHED_DELETE_END();