summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorantirez <antirez@gmail.com>2010-03-23 12:29:35 +0100
committerantirez <antirez@gmail.com>2010-03-23 12:29:35 +0100
commitd36c4e97e5018d98b4b346db7841090d9b6f4cfc (patch)
treee91b0533d90013b968a13ba038263a97a334f112
parent3ea27d37d1e6884a9fd0640f25b937fb9fe06aed (diff)
downloadredis-d36c4e97e5018d98b4b346db7841090d9b6f4cfc.tar.gz
key deletion on empty value fix + some refactoring
-rw-r--r--redis.c25
1 files changed, 9 insertions, 16 deletions
diff --git a/redis.c b/redis.c
index 6f38b6101..3fb351825 100644
--- a/redis.c
+++ b/redis.c
@@ -4790,17 +4790,14 @@ static void sinterGenericCommand(redisClient *c, robj **setskeys, unsigned long
if (dictSize((dict*)dstset->ptr) > 0) {
dictAdd(c->db->dict,dstkey,dstset);
incrRefCount(dstkey);
+ addReplyLong(c,dictSize((dict*)dstset->ptr));
} else {
decrRefCount(dstset);
+ addReply(c,shared.czero);
}
- }
-
- if (!dstkey) {
- lenobj->ptr = sdscatprintf(sdsempty(),"*%lu\r\n",cardinality);
- } else {
- addReplySds(c,sdscatprintf(sdsempty(),":%lu\r\n",
- dictSize((dict*)dstset->ptr)));
server.dirty++;
+ } else {
+ lenobj->ptr = sdscatprintf(sdsempty(),"*%lu\r\n",cardinality);
}
zfree(dv);
}
@@ -4873,7 +4870,8 @@ static void sunionDiffGenericCommand(redisClient *c, robj **setskeys, int setsnu
}
dictReleaseIterator(di);
- if (op == REDIS_OP_DIFF && cardinality == 0) break; /* result set is empty */
+ /* result set is empty? Exit asap. */
+ if (op == REDIS_OP_DIFF && cardinality == 0) break;
}
/* Output the content of the resulting set, if not in STORE mode */
@@ -4887,6 +4885,7 @@ static void sunionDiffGenericCommand(redisClient *c, robj **setskeys, int setsnu
addReplyBulk(c,ele);
}
dictReleaseIterator(di);
+ decrRefCount(dstset);
} else {
/* If we have a target key where to store the resulting set
* create this key with the result set inside */
@@ -4894,17 +4893,11 @@ static void sunionDiffGenericCommand(redisClient *c, robj **setskeys, int setsnu
if (dictSize((dict*)dstset->ptr) > 0) {
dictAdd(c->db->dict,dstkey,dstset);
incrRefCount(dstkey);
+ addReplyLong(c,dictSize((dict*)dstset->ptr));
} else {
decrRefCount(dstset);
+ addReply(c,shared.czero);
}
- }
-
- /* Cleanup */
- if (!dstkey) {
- decrRefCount(dstset);
- } else {
- addReplySds(c,sdscatprintf(sdsempty(),":%lu\r\n",
- dictSize((dict*)dstset->ptr)));
server.dirty++;
}
zfree(dv);