mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-22 16:18:28 -05:00
Use specialized function to add multi bulk reply length
This commit is contained in:
parent
57b0738011
commit
0537e7bf80
@ -107,7 +107,7 @@ void execCommand(redisClient *c) {
|
|||||||
unwatchAllKeys(c); /* Unwatch ASAP otherwise we'll waste CPU cycles */
|
unwatchAllKeys(c); /* Unwatch ASAP otherwise we'll waste CPU cycles */
|
||||||
orig_argv = c->argv;
|
orig_argv = c->argv;
|
||||||
orig_argc = c->argc;
|
orig_argc = c->argc;
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",c->mstate.count));
|
addReplyMultiBulkLen(c,c->mstate.count);
|
||||||
for (j = 0; j < c->mstate.count; j++) {
|
for (j = 0; j < c->mstate.count; j++) {
|
||||||
c->argc = c->mstate.commands[j].argc;
|
c->argc = c->mstate.commands[j].argc;
|
||||||
c->argv = c->mstate.commands[j].argv;
|
c->argv = c->mstate.commands[j].argv;
|
||||||
|
@ -200,6 +200,10 @@ void addReplyUlong(redisClient *c, unsigned long ul) {
|
|||||||
_addReplyLongLong(c,(long long)ul,':');
|
_addReplyLongLong(c,(long long)ul,':');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void addReplyMultiBulkLen(redisClient *c, long length) {
|
||||||
|
_addReplyLongLong(c,length,'*');
|
||||||
|
}
|
||||||
|
|
||||||
void addReplyBulkLen(redisClient *c, robj *obj) {
|
void addReplyBulkLen(redisClient *c, robj *obj) {
|
||||||
size_t len;
|
size_t len;
|
||||||
|
|
||||||
|
@ -617,6 +617,7 @@ void addReplySds(redisClient *c, sds s);
|
|||||||
void addReplyDouble(redisClient *c, double d);
|
void addReplyDouble(redisClient *c, double d);
|
||||||
void addReplyLongLong(redisClient *c, long long ll);
|
void addReplyLongLong(redisClient *c, long long ll);
|
||||||
void addReplyUlong(redisClient *c, unsigned long ul);
|
void addReplyUlong(redisClient *c, unsigned long ul);
|
||||||
|
void addReplyMultiBulkLen(redisClient *c, long length);
|
||||||
void *dupClientReplyValue(void *o);
|
void *dupClientReplyValue(void *o);
|
||||||
|
|
||||||
/* List data type */
|
/* List data type */
|
||||||
|
@ -307,7 +307,7 @@ void sortCommand(redisClient *c) {
|
|||||||
outputlen = getop ? getop*(end-start+1) : end-start+1;
|
outputlen = getop ? getop*(end-start+1) : end-start+1;
|
||||||
if (storekey == NULL) {
|
if (storekey == NULL) {
|
||||||
/* STORE option not specified, sent the sorting result to client */
|
/* STORE option not specified, sent the sorting result to client */
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",outputlen));
|
addReplyMultiBulkLen(c,outputlen);
|
||||||
for (j = start; j <= end; j++) {
|
for (j = start; j <= end; j++) {
|
||||||
listNode *ln;
|
listNode *ln;
|
||||||
listIter li;
|
listIter li;
|
||||||
|
@ -315,7 +315,7 @@ void hmgetCommand(redisClient *c) {
|
|||||||
/* Note the check for o != NULL happens inside the loop. This is
|
/* Note the check for o != NULL happens inside the loop. This is
|
||||||
* done because objects that cannot be found are considered to be
|
* done because objects that cannot be found are considered to be
|
||||||
* an empty hash. The reply should then be a series of NULLs. */
|
* an empty hash. The reply should then be a series of NULLs. */
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",c->argc-2));
|
addReplyMultiBulkLen(c,c->argc-2);
|
||||||
for (i = 2; i < c->argc; i++) {
|
for (i = 2; i < c->argc; i++) {
|
||||||
if (o != NULL && (value = hashTypeGet(o,c->argv[i])) != NULL) {
|
if (o != NULL && (value = hashTypeGet(o,c->argv[i])) != NULL) {
|
||||||
addReplyBulk(c,value);
|
addReplyBulk(c,value);
|
||||||
|
@ -494,7 +494,7 @@ void lrangeCommand(redisClient *c) {
|
|||||||
rangelen = (end-start)+1;
|
rangelen = (end-start)+1;
|
||||||
|
|
||||||
/* Return the result in form of a multi-bulk reply */
|
/* Return the result in form of a multi-bulk reply */
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",rangelen));
|
addReplyMultiBulkLen(c,rangelen);
|
||||||
listTypeIterator *li = listTypeInitIterator(o,start,REDIS_TAIL);
|
listTypeIterator *li = listTypeInitIterator(o,start,REDIS_TAIL);
|
||||||
for (j = 0; j < rangelen; j++) {
|
for (j = 0; j < rangelen; j++) {
|
||||||
redisAssert(listTypeNext(li,&entry));
|
redisAssert(listTypeNext(li,&entry));
|
||||||
@ -772,7 +772,7 @@ int handleClientsWaitingListPush(redisClient *c, robj *key, robj *ele) {
|
|||||||
redisAssert(ln != NULL);
|
redisAssert(ln != NULL);
|
||||||
receiver = ln->value;
|
receiver = ln->value;
|
||||||
|
|
||||||
addReplySds(receiver,sdsnew("*2\r\n"));
|
addReplyMultiBulkLen(receiver,2);
|
||||||
addReplyBulk(receiver,key);
|
addReplyBulk(receiver,key);
|
||||||
addReplyBulk(receiver,ele);
|
addReplyBulk(receiver,ele);
|
||||||
unblockClientWaitingData(receiver);
|
unblockClientWaitingData(receiver);
|
||||||
@ -811,7 +811,7 @@ void blockingPopGenericCommand(redisClient *c, int where) {
|
|||||||
* "real" command will add the last element (the value)
|
* "real" command will add the last element (the value)
|
||||||
* for us. If this souds like an hack to you it's just
|
* for us. If this souds like an hack to you it's just
|
||||||
* because it is... */
|
* because it is... */
|
||||||
addReplySds(c,sdsnew("*2\r\n"));
|
addReplyMultiBulkLen(c,2);
|
||||||
addReplyBulk(c,argv[1]);
|
addReplyBulk(c,argv[1]);
|
||||||
popGenericCommand(c,where);
|
popGenericCommand(c,where);
|
||||||
|
|
||||||
|
@ -469,7 +469,7 @@ void sunionDiffGenericCommand(redisClient *c, robj **setkeys, int setnum, robj *
|
|||||||
|
|
||||||
/* Output the content of the resulting set, if not in STORE mode */
|
/* Output the content of the resulting set, if not in STORE mode */
|
||||||
if (!dstkey) {
|
if (!dstkey) {
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",cardinality));
|
addReplyMultiBulkLen(c,cardinality);
|
||||||
si = setTypeInitIterator(dstset);
|
si = setTypeInitIterator(dstset);
|
||||||
while((ele = setTypeNext(si)) != NULL) {
|
while((ele = setTypeNext(si)) != NULL) {
|
||||||
addReplyBulk(c,ele);
|
addReplyBulk(c,ele);
|
||||||
|
@ -79,7 +79,7 @@ void getsetCommand(redisClient *c) {
|
|||||||
void mgetCommand(redisClient *c) {
|
void mgetCommand(redisClient *c) {
|
||||||
int j;
|
int j;
|
||||||
|
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",c->argc-1));
|
addReplyMultiBulkLen(c,c->argc-1);
|
||||||
for (j = 1; j < c->argc; j++) {
|
for (j = 1; j < c->argc; j++) {
|
||||||
robj *o = lookupKeyRead(c->db,c->argv[j]);
|
robj *o = lookupKeyRead(c->db,c->argv[j]);
|
||||||
if (o == NULL) {
|
if (o == NULL) {
|
||||||
|
@ -782,8 +782,7 @@ void zrangeGenericCommand(redisClient *c, int reverse) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* Return the result in form of a multi-bulk reply */
|
/* Return the result in form of a multi-bulk reply */
|
||||||
addReplySds(c,sdscatprintf(sdsempty(),"*%d\r\n",
|
addReplyMultiBulkLen(c,withscores ? (rangelen*2) : rangelen);
|
||||||
withscores ? (rangelen*2) : rangelen));
|
|
||||||
for (j = 0; j < rangelen; j++) {
|
for (j = 0; j < rangelen; j++) {
|
||||||
ele = ln->obj;
|
ele = ln->obj;
|
||||||
addReplyBulk(c,ele);
|
addReplyBulk(c,ele);
|
||||||
|
Loading…
Reference in New Issue
Block a user