Convert RDB ziplist loading to sdsnative()

This saves us an unnecessary zmalloc, memcpy, and two frees.
This commit is contained in:
Matt Stancliff 2014-12-10 15:46:24 -05:00
parent e1619772db
commit 127c15e2b2

View File

@ -981,13 +981,9 @@ robj *rdbLoadObject(int rdbtype, rio *rdb) {
rdbtype == REDIS_RDB_TYPE_ZSET_ZIPLIST ||
rdbtype == REDIS_RDB_TYPE_HASH_ZIPLIST)
{
robj *aux = rdbLoadStringObject(rdb);
if (aux == NULL) return NULL;
o = createObject(REDIS_STRING,NULL); /* string is just placeholder */
o->ptr = zmalloc(sdslen(aux->ptr));
memcpy(o->ptr,aux->ptr,sdslen(aux->ptr));
decrRefCount(aux);
o = rdbLoadStringObject(rdb);
if (o == NULL) return NULL;
o->ptr = sdsnative(o->ptr);
/* Fix the object encoding, and make sure to convert the encoded
* data type into the base type if accordingly to the current