Use strchr in a loop rather than strstr
This commit is contained in:
parent
2e5e9a49fd
commit
9c4ee606d6
15
hiredis.c
15
hiredis.c
@ -162,11 +162,20 @@ static char *readBytes(redisReader *r, unsigned int bytes) {
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static char *seekNewline(char *s) {
|
||||||
|
/* Find pointer to \r\n without strstr */
|
||||||
|
while(s != NULL && s[0] != '\r' && s[1] != '\n')
|
||||||
|
s = strchr(s,'\r');
|
||||||
|
return s;
|
||||||
|
}
|
||||||
|
|
||||||
static char *readLine(redisReader *r, int *_len) {
|
static char *readLine(redisReader *r, int *_len) {
|
||||||
char *p, *s = strstr(r->buf+r->pos,"\r\n");
|
char *p, *s;
|
||||||
int len;
|
int len;
|
||||||
if (s != NULL) {
|
|
||||||
p = r->buf+r->pos;
|
p = r->buf+r->pos;
|
||||||
|
s = seekNewline(p);
|
||||||
|
if (s != NULL) {
|
||||||
len = s-(r->buf+r->pos);
|
len = s-(r->buf+r->pos);
|
||||||
r->pos += len+2; /* skip \r\n */
|
r->pos += len+2; /* skip \r\n */
|
||||||
if (_len) *_len = len;
|
if (_len) *_len = len;
|
||||||
@ -234,7 +243,7 @@ static int processBulkItem(redisReader *r) {
|
|||||||
unsigned long bytelen;
|
unsigned long bytelen;
|
||||||
|
|
||||||
p = r->buf+r->pos;
|
p = r->buf+r->pos;
|
||||||
s = strstr(p,"\r\n");
|
s = seekNewline(p);
|
||||||
if (s != NULL) {
|
if (s != NULL) {
|
||||||
p = r->buf+r->pos;
|
p = r->buf+r->pos;
|
||||||
bytelen = s-(r->buf+r->pos)+2; /* include \r\n */
|
bytelen = s-(r->buf+r->pos)+2; /* include \r\n */
|
||||||
|
Loading…
Reference in New Issue
Block a user