From 8ce0b3228dc4742b045cb471b145551d1afac337 Mon Sep 17 00:00:00 2001 From: Pieter Noordhuis Date: Thu, 4 Nov 2010 23:52:47 +0100 Subject: Finding \r\n without strstr is a little harder --- hiredis.c | 11 ++++++++++- test.c | 11 +++++++++++ 2 files changed, 21 insertions(+), 1 deletion(-) diff --git a/hiredis.c b/hiredis.c index ffdf027..f0d78a0 100644 --- a/hiredis.c +++ b/hiredis.c @@ -164,8 +164,17 @@ static char *readBytes(redisReader *r, unsigned int bytes) { static char *seekNewline(char *s) { /* Find pointer to \r\n without strstr */ - while(s != NULL && s[0] != '\r' && s[1] != '\n') + while (s != NULL) { s = strchr(s,'\r'); + if (s != NULL) { + if (s[1] == '\n') + break; + else + s++; + } else { + break; + } + } return s; } diff --git a/test.c b/test.c index 995456e..c82ea51 100644 --- a/test.c +++ b/test.c @@ -219,6 +219,17 @@ static void test_reply_reader() { ret = redisReplyReaderGetReply(reader,&reply); test_cond(ret == REDIS_OK && reply == (void*)REDIS_REPLY_STATUS); redisReplyReaderFree(reader); + + test("Works when a single newline (\\r\\n) covers two calls to feed: "); + reader = redisReplyReaderCreate(); + redisReplyReaderSetReplyObjectFunctions(reader,NULL); + redisReplyReaderFeed(reader,(char*)"+OK\r",4); + ret = redisReplyReaderGetReply(reader,&reply); + assert(ret == REDIS_OK && reply == NULL); + redisReplyReaderFeed(reader,(char*)"\n",1); + ret = redisReplyReaderGetReply(reader,&reply); + test_cond(ret == REDIS_OK && reply == (void*)REDIS_REPLY_STATUS); + redisReplyReaderFree(reader); } static void test_throughput() { -- cgit v1.2.3