mirror of
https://github.com/fluencelabs/redis
synced 2025-05-12 10:47:12 +00:00
Merge branch 'unstable' of github.com:/antirez/redis into unstable
This commit is contained in:
commit
aa3f13761f
24
src/module.c
24
src/module.c
@ -7310,22 +7310,30 @@ int RM_GetLFU(RedisModuleKey *key, long long *lfu_freq) {
|
|||||||
* Unlike RM_ModuleTypeSetValue() which will free the old value, this function
|
* Unlike RM_ModuleTypeSetValue() which will free the old value, this function
|
||||||
* simply swaps the old value with the new value.
|
* simply swaps the old value with the new value.
|
||||||
*
|
*
|
||||||
* The function returns the old value, or NULL if any of the above conditions is
|
* The function returns REDISMODULE_OK on success, REDISMODULE_ERR on errors
|
||||||
* not met.
|
* such as:
|
||||||
|
*
|
||||||
|
* 1. Key is not opened for writing.
|
||||||
|
* 2. Key is not a module data type key.
|
||||||
|
* 3. Key is a module datatype other than 'mt'.
|
||||||
|
*
|
||||||
|
* If old_value is non-NULL, the old value is returned by reference.
|
||||||
*/
|
*/
|
||||||
void *RM_ModuleTypeReplaceValue(RedisModuleKey *key, moduleType *mt, void *new_value) {
|
int RM_ModuleTypeReplaceValue(RedisModuleKey *key, moduleType *mt, void *new_value, void **old_value) {
|
||||||
if (!(key->mode & REDISMODULE_WRITE) || key->iter)
|
if (!(key->mode & REDISMODULE_WRITE) || key->iter)
|
||||||
return NULL;
|
return REDISMODULE_ERR;
|
||||||
if (!key->value || key->value->type != OBJ_MODULE)
|
if (!key->value || key->value->type != OBJ_MODULE)
|
||||||
return NULL;
|
return REDISMODULE_ERR;
|
||||||
|
|
||||||
moduleValue *mv = key->value->ptr;
|
moduleValue *mv = key->value->ptr;
|
||||||
if (mv->type != mt)
|
if (mv->type != mt)
|
||||||
return NULL;
|
return REDISMODULE_ERR;
|
||||||
|
|
||||||
void *old_val = mv->value;
|
if (old_value)
|
||||||
|
*old_value = mv->value;
|
||||||
mv->value = new_value;
|
mv->value = new_value;
|
||||||
return old_val;
|
|
||||||
|
return REDISMODULE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Register all the APIs we export. Keep this function at the end of the
|
/* Register all the APIs we export. Keep this function at the end of the
|
||||||
|
@ -525,7 +525,7 @@ int REDISMODULE_API_FUNC(RedisModule_GetContextFlags)(RedisModuleCtx *ctx);
|
|||||||
void *REDISMODULE_API_FUNC(RedisModule_PoolAlloc)(RedisModuleCtx *ctx, size_t bytes);
|
void *REDISMODULE_API_FUNC(RedisModule_PoolAlloc)(RedisModuleCtx *ctx, size_t bytes);
|
||||||
RedisModuleType *REDISMODULE_API_FUNC(RedisModule_CreateDataType)(RedisModuleCtx *ctx, const char *name, int encver, RedisModuleTypeMethods *typemethods);
|
RedisModuleType *REDISMODULE_API_FUNC(RedisModule_CreateDataType)(RedisModuleCtx *ctx, const char *name, int encver, RedisModuleTypeMethods *typemethods);
|
||||||
int REDISMODULE_API_FUNC(RedisModule_ModuleTypeSetValue)(RedisModuleKey *key, RedisModuleType *mt, void *value);
|
int REDISMODULE_API_FUNC(RedisModule_ModuleTypeSetValue)(RedisModuleKey *key, RedisModuleType *mt, void *value);
|
||||||
void *REDISMODULE_API_FUNC(RedisModule_ModuleTypeReplaceValue)(RedisModuleKey *key, RedisModuleType *mt, void *new_value);
|
int REDISMODULE_API_FUNC(RedisModule_ModuleTypeReplaceValue)(RedisModuleKey *key, RedisModuleType *mt, void *new_value, void **old_value);
|
||||||
RedisModuleType *REDISMODULE_API_FUNC(RedisModule_ModuleTypeGetType)(RedisModuleKey *key);
|
RedisModuleType *REDISMODULE_API_FUNC(RedisModule_ModuleTypeGetType)(RedisModuleKey *key);
|
||||||
void *REDISMODULE_API_FUNC(RedisModule_ModuleTypeGetValue)(RedisModuleKey *key);
|
void *REDISMODULE_API_FUNC(RedisModule_ModuleTypeGetValue)(RedisModuleKey *key);
|
||||||
int REDISMODULE_API_FUNC(RedisModule_IsIOError)(RedisModuleIO *io);
|
int REDISMODULE_API_FUNC(RedisModule_IsIOError)(RedisModuleIO *io);
|
||||||
|
@ -999,7 +999,7 @@ struct redisCommand redisCommandTable[] = {
|
|||||||
0,NULL,0,0,0,0,0,0},
|
0,NULL,0,0,0,0,0,0},
|
||||||
|
|
||||||
{"acl",aclCommand,-2,
|
{"acl",aclCommand,-2,
|
||||||
"admin no-script ok-loading ok-stale",
|
"admin no-script no-slowlog ok-loading ok-stale",
|
||||||
0,NULL,0,0,0,0,0,0}
|
0,NULL,0,0,0,0,0,0}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -2266,6 +2266,7 @@ void createSharedObjects(void) {
|
|||||||
void initServerConfig(void) {
|
void initServerConfig(void) {
|
||||||
int j;
|
int j;
|
||||||
|
|
||||||
|
server.hz = CONFIG_DEFAULT_HZ;
|
||||||
updateCachedTime(1);
|
updateCachedTime(1);
|
||||||
getRandomHexChars(server.runid,CONFIG_RUN_ID_SIZE);
|
getRandomHexChars(server.runid,CONFIG_RUN_ID_SIZE);
|
||||||
server.runid[CONFIG_RUN_ID_SIZE] = '\0';
|
server.runid[CONFIG_RUN_ID_SIZE] = '\0';
|
||||||
|
@ -124,6 +124,28 @@ static int datatype_dump(RedisModuleCtx *ctx, RedisModuleString **argv, int argc
|
|||||||
return REDISMODULE_OK;
|
return REDISMODULE_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int datatype_swap(RedisModuleCtx *ctx, RedisModuleString **argv, int argc) {
|
||||||
|
if (argc != 3) {
|
||||||
|
RedisModule_WrongArity(ctx);
|
||||||
|
return REDISMODULE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
RedisModuleKey *a = RedisModule_OpenKey(ctx, argv[1], REDISMODULE_WRITE);
|
||||||
|
RedisModuleKey *b = RedisModule_OpenKey(ctx, argv[2], REDISMODULE_WRITE);
|
||||||
|
void *val = RedisModule_ModuleTypeGetValue(a);
|
||||||
|
|
||||||
|
int error = (RedisModule_ModuleTypeReplaceValue(b, datatype, val, &val) == REDISMODULE_ERR ||
|
||||||
|
RedisModule_ModuleTypeReplaceValue(a, datatype, val, NULL) == REDISMODULE_ERR);
|
||||||
|
if (!error)
|
||||||
|
RedisModule_ReplyWithSimpleString(ctx, "OK");
|
||||||
|
else
|
||||||
|
RedisModule_ReplyWithError(ctx, "ERR failed");
|
||||||
|
|
||||||
|
RedisModule_CloseKey(a);
|
||||||
|
RedisModule_CloseKey(b);
|
||||||
|
|
||||||
|
return REDISMODULE_OK;
|
||||||
|
}
|
||||||
|
|
||||||
int RedisModule_OnLoad(RedisModuleCtx *ctx, RedisModuleString **argv, int argc) {
|
int RedisModule_OnLoad(RedisModuleCtx *ctx, RedisModuleString **argv, int argc) {
|
||||||
REDISMODULE_NOT_USED(argv);
|
REDISMODULE_NOT_USED(argv);
|
||||||
@ -157,5 +179,8 @@ int RedisModule_OnLoad(RedisModuleCtx *ctx, RedisModuleString **argv, int argc)
|
|||||||
if (RedisModule_CreateCommand(ctx,"datatype.dump", datatype_dump,"",1,1,1) == REDISMODULE_ERR)
|
if (RedisModule_CreateCommand(ctx,"datatype.dump", datatype_dump,"",1,1,1) == REDISMODULE_ERR)
|
||||||
return REDISMODULE_ERR;
|
return REDISMODULE_ERR;
|
||||||
|
|
||||||
|
if (RedisModule_CreateCommand(ctx,"datatype.swap", datatype_swap,"",1,1,1) == REDISMODULE_ERR)
|
||||||
|
return REDISMODULE_ERR;
|
||||||
|
|
||||||
return REDISMODULE_OK;
|
return REDISMODULE_OK;
|
||||||
}
|
}
|
||||||
|
@ -24,4 +24,21 @@ start_server {tags {"modules"}} {
|
|||||||
catch {r datatype.restore dtkeycopy $truncated} e
|
catch {r datatype.restore dtkeycopy $truncated} e
|
||||||
set e
|
set e
|
||||||
} {*Invalid*}
|
} {*Invalid*}
|
||||||
|
|
||||||
|
test {DataType: ModuleTypeReplaceValue() happy path works} {
|
||||||
|
r datatype.set key-a 1 AAA
|
||||||
|
r datatype.set key-b 2 BBB
|
||||||
|
|
||||||
|
assert {[r datatype.swap key-a key-b] eq {OK}}
|
||||||
|
assert {[r datatype.get key-a] eq {2 BBB}}
|
||||||
|
assert {[r datatype.get key-b] eq {1 AAA}}
|
||||||
|
}
|
||||||
|
|
||||||
|
test {DataType: ModuleTypeReplaceValue() fails on non-module keys} {
|
||||||
|
r datatype.set key-a 1 AAA
|
||||||
|
r set key-b RedisString
|
||||||
|
|
||||||
|
catch {r datatype.swap key-a key-b} e
|
||||||
|
set e
|
||||||
|
} {*ERR*}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user