mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 00:28:26 -05:00
Fixed a bug in HSET, a memory leak, and a theoretical bug in dict.c
This commit is contained in:
parent
b1d9c91ca8
commit
2069d06a0b
10
dict.c
10
dict.c
@ -232,7 +232,7 @@ int dictAdd(dict *ht, void *key, void *val)
|
|||||||
* operation. */
|
* operation. */
|
||||||
int dictReplace(dict *ht, void *key, void *val)
|
int dictReplace(dict *ht, void *key, void *val)
|
||||||
{
|
{
|
||||||
dictEntry *entry;
|
dictEntry *entry, auxentry;
|
||||||
|
|
||||||
/* Try to add the element. If the key
|
/* Try to add the element. If the key
|
||||||
* does not exists dictAdd will suceed. */
|
* does not exists dictAdd will suceed. */
|
||||||
@ -241,8 +241,14 @@ int dictReplace(dict *ht, void *key, void *val)
|
|||||||
/* It already exists, get the entry */
|
/* It already exists, get the entry */
|
||||||
entry = dictFind(ht, key);
|
entry = dictFind(ht, key);
|
||||||
/* Free the old value and set the new one */
|
/* Free the old value and set the new one */
|
||||||
dictFreeEntryVal(ht, entry);
|
/* Set the new value and free the old one. Note that it is important
|
||||||
|
* to do that in this order, as the value may just be exactly the same
|
||||||
|
* as the previous one. In this context, think to reference counting,
|
||||||
|
* you want to increment (set), and then decrement (free), and not the
|
||||||
|
* reverse. */
|
||||||
|
auxentry = *entry;
|
||||||
dictSetHashVal(ht, entry, val);
|
dictSetHashVal(ht, entry, val);
|
||||||
|
dictFreeEntryVal(ht, &auxentry);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
redis.c
2
redis.c
@ -5849,7 +5849,7 @@ static void hsetCommand(redisClient *c) {
|
|||||||
tryObjectEncoding(c->argv[2]);
|
tryObjectEncoding(c->argv[2]);
|
||||||
/* note that c->argv[3] is already encoded, as the latest arg
|
/* note that c->argv[3] is already encoded, as the latest arg
|
||||||
* of a bulk command is always integer encoded if possible. */
|
* of a bulk command is always integer encoded if possible. */
|
||||||
if (dictAdd(o->ptr,c->argv[2],c->argv[3]) == DICT_OK) {
|
if (dictReplace(o->ptr,c->argv[2],c->argv[3])) {
|
||||||
incrRefCount(c->argv[2]);
|
incrRefCount(c->argv[2]);
|
||||||
} else {
|
} else {
|
||||||
update = 1;
|
update = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user