mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-23 00:28:26 -05:00
Modules: dictionary API WIP #8: Iterator next/prev.
This commit is contained in:
parent
58ac1f8bbe
commit
fb1d5717de
42
src/module.c
42
src/module.c
@ -4502,6 +4502,48 @@ int RM_DictIteratorReseek(RedisModuleDictIter *di, const char *op, RedisModuleSt
|
|||||||
return RM_DictIteratorReseekC(di,op,key->ptr,sdslen(key->ptr));
|
return RM_DictIteratorReseekC(di,op,key->ptr,sdslen(key->ptr));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Return the current item of the dictionary iterator 'di' and steps to the
|
||||||
|
* next element. If the iterator already yield the last element and there
|
||||||
|
* are no other elements to return, NULL is returned, otherwise a pointer
|
||||||
|
* to a string representing the key is provided, and the '*keylen' length
|
||||||
|
* is set by reference (if keylen is not NULL). The '*dataptr', if not NULL
|
||||||
|
* is set to the value of the pointer stored at the returned key as auxiliary
|
||||||
|
* data (as set by the RedisModule_DictSet API).
|
||||||
|
*
|
||||||
|
* Usage example:
|
||||||
|
*
|
||||||
|
* ... create the iterator here ...
|
||||||
|
* char *key;
|
||||||
|
* void *data;
|
||||||
|
* while((key = RedisModule_DictNextC(iter,&keylen,&data)) != NULL) {
|
||||||
|
* printf("%.*s %p\n", (int)keylen, key, data);
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* The returned pointer is of type void because sometimes it makes sense
|
||||||
|
* to cast it to a char* sometimes to an unsigned char* depending on the
|
||||||
|
* fact it contains or not binary data, so this API ends being more
|
||||||
|
* comfortable to use.
|
||||||
|
*
|
||||||
|
* The validity of the returned pointer is until the next call to the
|
||||||
|
* next/prev iterator step. Also the pointer is no longer valid once the
|
||||||
|
* iterator is released. */
|
||||||
|
void *RM_DictNextC(RedisModuleDictIter *di, size_t *keylen, void **dataptr) {
|
||||||
|
if (!raxNext(&di->ri)) return NULL;
|
||||||
|
if (keylen) *keylen = di->ri.key_len;
|
||||||
|
if (dataptr) *dataptr = di->ri.data;
|
||||||
|
return di->ri.key;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* This function is exactly like RedisModule_DictNext() but after returning
|
||||||
|
* the currently selected element in the iterator, it selects the previous
|
||||||
|
* element (laxicographically smaller) instead of the next one. */
|
||||||
|
void *RM_DictPrevC(RedisModuleDictIter *di, size_t *keylen, void **dataptr) {
|
||||||
|
if (!raxPrev(&di->ri)) return NULL;
|
||||||
|
if (keylen) *keylen = di->ri.key_len;
|
||||||
|
if (dataptr) *dataptr = di->ri.data;
|
||||||
|
return di->ri.key;
|
||||||
|
}
|
||||||
|
|
||||||
/* TODO
|
/* TODO
|
||||||
RM_DictNextC();
|
RM_DictNextC();
|
||||||
RM_DictPrevC();
|
RM_DictPrevC();
|
||||||
|
Loading…
Reference in New Issue
Block a user