projects
/
m6w6
/
libmemcached
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
|
github
raw
|
inline
| side by side
Fixed test case output
[m6w6/libmemcached]
/
lib
/
memcached_response.c
diff --git
a/lib/memcached_response.c
b/lib/memcached_response.c
index 1276351332d829d851eab826fe4ce61f540465ed..d649922b0da164354d91bd276e16fadf8f44838b 100644
(file)
--- a/
lib/memcached_response.c
+++ b/
lib/memcached_response.c
@@
-6,31
+6,39
@@
*/
#include "common.h"
*/
#include "common.h"
+#include "memcached_io.h"
memcached_return memcached_response(memcached_st *ptr,
char *buffer, size_t buffer_length,
unsigned int server_key)
{
memcached_return memcached_response(memcached_st *ptr,
char *buffer, size_t buffer_length,
unsigned int server_key)
{
+ unsigned int x;
size_t send_length;
char *buffer_ptr;
memset(buffer, 0, buffer_length);
send_length= 0;
size_t send_length;
char *buffer_ptr;
memset(buffer, 0, buffer_length);
send_length= 0;
- buffer_ptr= buffer;
- while (1)
+ for (x= 0; x <= ptr->stack_responses; x++)
{
{
- unsigned int read_length;
- read_length= recv(ptr->hosts[server_key].fd, buffer_ptr, 1, 0);
+ buffer_ptr= buffer;
+ while (1)
+ {
+ unsigned int read_length;
+
+ read_length= memcached_io_read(ptr, server_key,
+ buffer_ptr, 1);
- if (read_length != 1)
- return MEMCACHED_UNKNOWN_READ_FAILURE;
+
if (read_length != 1)
+
return MEMCACHED_UNKNOWN_READ_FAILURE;
- if (*buffer_ptr == '\n')
- break;
- else
- buffer_ptr++;
+ if (*buffer_ptr == '\n')
+ break;
+ else
+ buffer_ptr++;
+ }
}
}
+ ptr->stack_responses= 0;
switch(buffer[0])
{
switch(buffer[0])
{
@@
-40,15
+48,17
@@
memcached_return memcached_response(memcached_st *ptr,
return MEMCACHED_SUCCESS;
case 'S': /* STORED STATS SERVER_ERROR */
{
return MEMCACHED_SUCCESS;
case 'S': /* STORED STATS SERVER_ERROR */
{
- if (buffer[
1] == 'T
') /* STORED STATS */
+ if (buffer[
2] == 'A
') /* STORED STATS */
return MEMCACHED_SUCCESS;
else if (buffer[1] == 'E')
return MEMCACHED_SERVER_ERROR;
return MEMCACHED_SUCCESS;
else if (buffer[1] == 'E')
return MEMCACHED_SERVER_ERROR;
+ else if (buffer[1] == 'T')
+ return MEMCACHED_STORED;
else
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
case 'D': /* DELETED */
else
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
case 'D': /* DELETED */
- return MEMCACHED_
SUCCESS
;
+ return MEMCACHED_
DELETED
;
case 'N': /* NOT_FOUND */
{
if (buffer[4] == 'F')
case 'N': /* NOT_FOUND */
{
if (buffer[4] == 'F')
@@
-61,7
+71,7
@@
memcached_return memcached_response(memcached_st *ptr,
case 'E': /* PROTOCOL ERROR or END */
{
if (buffer[1] == 'N')
case 'E': /* PROTOCOL ERROR or END */
{
if (buffer[1] == 'N')
- return MEMCACHED_
NOTFOU
ND;
+ return MEMCACHED_
E
ND;
else if (buffer[1] == 'R')
return MEMCACHED_PROTOCOL_ERROR;
else
else if (buffer[1] == 'R')
return MEMCACHED_PROTOCOL_ERROR;
else