This is a rewrite of some of the IO code to handle larger loads of set data
[awesomized/libmemcached] / lib / memcached_quit.c
1 #include "common.h"
2
3 /*
4 This closes all connections (forces flush of input as well).
5
6 Maybe add a host specific, or key specific version?
7
8 The reason we send "quit" is that in case we have buffered IO, this
9 will force data to be completed.
10 */
11
12 void memcached_quit_server(memcached_st *ptr, unsigned int server_key)
13 {
14 if (ptr->hosts[server_key].fd != -1)
15 {
16 if (ptr->flags & MEM_NO_BLOCK)
17 memcached_io_write(ptr, server_key, "quit\r\n", 6, 1);
18 close(ptr->hosts[server_key].fd);
19 ptr->hosts[server_key].fd= -1;
20 ptr->hosts[server_key].stack_responses= 0;
21 }
22
23 ptr->connected--;
24 }
25
26 void memcached_quit(memcached_st *ptr)
27 {
28 unsigned int x;
29
30 if (ptr->hosts)
31 {
32 for (x= 0; x < ptr->number_of_hosts; x++)
33 memcached_quit_server(ptr, x);
34 }
35
36 ptr->connected= 0;
37 }