See changes in changelog, but...
[m6w6/libmemcached] / lib / memcached_quit.c
index 89a55ecf43c96f0739152c1c851917d48bfd8c03..64bfe27e25f60cb810acec811255876b4fb91301 100644 (file)
@@ -4,6 +4,9 @@
   This closes all connections (forces flush of input as well).
   
   Maybe add a host specific, or key specific version? 
+  
+  The reason we send "quit" is that in case we have buffered IO, this 
+  will force data to be completed.
 */
 void memcached_quit(memcached_st *ptr)
 {
@@ -15,6 +18,10 @@ void memcached_quit(memcached_st *ptr)
     {
       if (ptr->hosts[x].fd != -1)
       {
+        char buffer[MEMCACHED_DEFAULT_COMMAND_SIZE];
+
+        if (ptr->flags & MEM_NO_BLOCK)
+          memcached_io_write(ptr, x, "quit\r\n", 6, 1);
         close(ptr->hosts[x].fd);
         ptr->hosts[x].fd= -1;
       }