3 static memcached_return
memcached_auto(memcached_st
*ptr
,
5 char *key
, size_t key_length
,
9 size_t send_length
, sent_length
;
11 char buffer
[MEMCACHED_DEFAULT_COMMAND_SIZE
];
12 unsigned int server_key
;
14 rc
= memcached_connect(ptr
);
16 if (rc
!= MEMCACHED_SUCCESS
)
19 server_key
= memcached_generate_hash(key
, key_length
) % ptr
->number_of_hosts
;
21 send_length
= snprintf(buffer
, MEMCACHED_DEFAULT_COMMAND_SIZE
,
22 "%s %.*s %u\r\n", verb
,
25 if (send_length
>= MEMCACHED_DEFAULT_COMMAND_SIZE
)
26 return MEMCACHED_WRITE_FAILURE
;
27 sent_length
= memcached_io_write(ptr
, server_key
, buffer
, send_length
, 1);
29 if (sent_length
== -1 || sent_length
!= send_length
)
30 return MEMCACHED_WRITE_FAILURE
;
32 memset(buffer
, 0, MEMCACHED_DEFAULT_COMMAND_SIZE
);
34 rc
= memcached_response(ptr
, buffer
, MEMCACHED_DEFAULT_COMMAND_SIZE
, server_key
);
37 So why recheck responce? Because the protocol is brain dead :)
38 The number returned might end up equaling one of the string
39 values. Less chance of a mistake with memcmp() so we will
40 use it. We still called memcached_response() though since it
41 worked its magic for non-blocking IO.
43 if (!memcmp(buffer
, "ERROR\r\n", MEMCACHED_DEFAULT_COMMAND_SIZE
))
46 rc
= MEMCACHED_PROTOCOL_ERROR
;
48 else if (!memcmp(buffer
, "NOT_FOUND\r\n", MEMCACHED_DEFAULT_COMMAND_SIZE
))
51 rc
= MEMCACHED_NOTFOUND
;
55 *value
= strtol(buffer
, (char **)NULL
, 10);
56 rc
= MEMCACHED_SUCCESS
;
62 memcached_return
memcached_increment(memcached_st
*ptr
,
63 char *key
, size_t key_length
,
69 LIBMEMCACHED_MEMCACHED_INCREMENT_START();
70 rc
= memcached_auto(ptr
, "incr", key
, key_length
, offset
, value
);
71 LIBMEMCACHED_MEMCACHED_INCREMENT_END();
76 memcached_return
memcached_decrement(memcached_st
*ptr
,
77 char *key
, size_t key_length
,
83 LIBMEMCACHED_MEMCACHED_DECREMENT_START();
84 rc
= memcached_auto(ptr
, "decr", key
, key_length
, offset
, value
);
85 LIBMEMCACHED_MEMCACHED_DECREMENT_END();