Skip to content

Commit

Permalink
SRANDMEMBER <count> leak fixed.
Browse files Browse the repository at this point in the history
For "CASE 4" (see code) we need to free the element if it's already in
the result dictionary and adding it failed.
  • Loading branch information
antirez committed Sep 21, 2012
1 parent be90c80 commit 578c945
Showing 1 changed file with 10 additions and 8 deletions.
18 changes: 10 additions & 8 deletions src/t_set.c
Original file line number Diff line number Diff line change
Expand Up @@ -476,19 +476,21 @@ void srandmemberWithCountCommand(redisClient *c) {
unsigned long added = 0;

while(added < count) {
int retval;

encoding = setTypeRandomElement(set,&ele,&llele);
if (encoding == REDIS_ENCODING_INTSET) {
retval = dictAdd(d,createStringObjectFromLongLong(llele),NULL);
ele = createStringObjectFromLongLong(llele);
} else if (ele->encoding == REDIS_ENCODING_RAW) {
retval = dictAdd(d,dupStringObject(ele),NULL);
ele = dupStringObject(ele);
} else if (ele->encoding == REDIS_ENCODING_INT) {
retval = dictAdd(d,
createStringObjectFromLongLong((long)ele->ptr),NULL);
ele = createStringObjectFromLongLong((long)ele->ptr);
}

if (retval == DICT_OK) added++;
/* Try to add the object to the dictionary. If it already exists
* free it, otherwise increment the number of objects we have
* in the result dictionary. */
if (dictAdd(d,ele,NULL) == DICT_OK)
added++;
else
decrRefCount(ele);
}
}

Expand Down

0 comments on commit 578c945

Please sign in to comment.