projects
/
m6w6
/
libmemcached
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
|
github
raw
|
inline
| side by side
Added behavior method around testing of keys.
[m6w6/libmemcached]
/
lib
/
memcached_response.c
diff --git
a/lib/memcached_response.c
b/lib/memcached_response.c
index 31b5911737f2820a39d4d1f36c0ab55c9e23e344..33dc0b1e5bfd41d9c28bb41d061028ab313fa619 100644
(file)
--- a/
lib/memcached_response.c
+++ b/
lib/memcached_response.c
@@
-49,7
+49,10
@@
memcached_return memcached_response(memcached_server_st *ptr,
WATCHPOINT_ASSERT(isgraph(*buffer_ptr) || isspace(*buffer_ptr));
if (read_length != 1)
WATCHPOINT_ASSERT(isgraph(*buffer_ptr) || isspace(*buffer_ptr));
if (read_length != 1)
+ {
+ memcached_io_reset(ptr);
return MEMCACHED_UNKNOWN_READ_FAILURE;
return MEMCACHED_UNKNOWN_READ_FAILURE;
+ }
if (*buffer_ptr == '\n')
break;
if (*buffer_ptr == '\n')
break;
@@
-60,7
+63,10
@@
memcached_return memcached_response(memcached_server_st *ptr,
WATCHPOINT_ASSERT(total_length <= buffer_length);
if (total_length >= buffer_length)
WATCHPOINT_ASSERT(total_length <= buffer_length);
if (total_length >= buffer_length)
+ {
+ memcached_io_reset(ptr);
return MEMCACHED_PROTOCOL_ERROR;
return MEMCACHED_PROTOCOL_ERROR;
+ }
}
buffer_ptr++;
*buffer_ptr= 0;
}
buffer_ptr++;
*buffer_ptr= 0;
@@
-92,6
+98,7
@@
memcached_return memcached_response(memcached_server_st *ptr,
{
WATCHPOINT_STRING(buffer);
WATCHPOINT_ASSERT(0);
{
WATCHPOINT_STRING(buffer);
WATCHPOINT_ASSERT(0);
+ memcached_io_reset(ptr);
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
case 'O': /* OK */
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
case 'O': /* OK */
@@
-111,6
+118,7
@@
memcached_return memcached_response(memcached_server_st *ptr,
{
WATCHPOINT_STRING(buffer);
WATCHPOINT_ASSERT(0);
{
WATCHPOINT_STRING(buffer);
WATCHPOINT_ASSERT(0);
+ memcached_io_reset(ptr);
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
}
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
}
@@
-123,20
+131,31
@@
memcached_return memcached_response(memcached_server_st *ptr,
else if (buffer[4] == 'S')
return MEMCACHED_NOTSTORED;
else
else if (buffer[4] == 'S')
return MEMCACHED_NOTSTORED;
else
+ {
+ memcached_io_reset(ptr);
return MEMCACHED_UNKNOWN_READ_FAILURE;
return MEMCACHED_UNKNOWN_READ_FAILURE;
+ }
}
case 'E': /* PROTOCOL ERROR or END */
{
if (buffer[1] == 'N')
return MEMCACHED_END;
else if (buffer[1] == 'R')
}
case 'E': /* PROTOCOL ERROR or END */
{
if (buffer[1] == 'N')
return MEMCACHED_END;
else if (buffer[1] == 'R')
+ {
+ memcached_io_reset(ptr);
return MEMCACHED_PROTOCOL_ERROR;
return MEMCACHED_PROTOCOL_ERROR;
+ }
else
else
+ {
+ memcached_io_reset(ptr);
return MEMCACHED_UNKNOWN_READ_FAILURE;
return MEMCACHED_UNKNOWN_READ_FAILURE;
+ }
}
case 'C': /* CLIENT ERROR */
}
case 'C': /* CLIENT ERROR */
+ memcached_io_reset(ptr);
return MEMCACHED_CLIENT_ERROR;
default:
return MEMCACHED_CLIENT_ERROR;
default:
+ memcached_io_reset(ptr);
return MEMCACHED_UNKNOWN_READ_FAILURE;
}
return MEMCACHED_UNKNOWN_READ_FAILURE;
}