X-Git-Url: https://git.saurik.com/redis.git/blobdiff_plain/d866803818fb47a851e5730ccff634f993ce6f68..91c15ed1b51a0cd097e5c8b0d77edb07f460a866:/src/bitops.c diff --git a/src/bitops.c b/src/bitops.c index d309b7af..deec0971 100644 --- a/src/bitops.c +++ b/src/bitops.c @@ -114,14 +114,14 @@ void setbitCommand(redisClient *c) { o->ptr = sdsgrowzero(o->ptr,byte+1); /* Get current values */ - byteval = ((char*)o->ptr)[byte]; + byteval = ((uint8_t*)o->ptr)[byte]; bit = 7 - (bitoffset & 0x7); bitval = byteval & (1 << bit); /* Update byte with new bit value and return original value */ byteval &= ~(1 << bit); byteval |= ((on & 0x1) << bit); - ((char*)o->ptr)[byte] = byteval; + ((uint8_t*)o->ptr)[byte] = byteval; signalModifiedKey(c->db,c->argv[1]); server.dirty++; addReply(c, bitval ? shared.cone : shared.czero); @@ -148,7 +148,7 @@ void getbitCommand(redisClient *c) { bitval = llbuf[byte] & (1 << bit); } else { if (byte < sdslen(o->ptr)) - bitval = ((char*)o->ptr)[byte] & (1 << bit); + bitval = ((uint8_t*)o->ptr)[byte] & (1 << bit); } addReply(c, bitval ? shared.cone : shared.czero); @@ -197,6 +197,7 @@ void bitopCommand(redisClient *c) { objects[j] = NULL; src[j] = NULL; len[j] = 0; + minlen = 0; continue; } /* Return an error if one of the keys is not a string. */