aboutsummaryrefslogtreecommitdiff
path: root/extmod/modbtree.c
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2016-06-18 00:47:26 +0300
committerPaul Sokolovsky <pfalcon@users.sourceforge.net>2016-06-18 00:47:26 +0300
commite6e7e0e9c5622ca1f09012a28024e443216a9e5c (patch)
tree1acc9c882fd8b2183719d2c04ada67d7cb0af37f /extmod/modbtree.c
parent7c8d76fad34cbb75b9f7faec156e88632631f127 (diff)
extmod/modbtree: items(): Implement DESC flag.
Diffstat (limited to 'extmod/modbtree.c')
-rw-r--r--extmod/modbtree.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/extmod/modbtree.c b/extmod/modbtree.c
index 4e607bee5..eff2cd1f5 100644
--- a/extmod/modbtree.c
+++ b/extmod/modbtree.c
@@ -43,7 +43,8 @@ typedef struct _mp_obj_btree_t {
mp_obj_t start_key;
mp_obj_t end_key;
#define FLAG_END_KEY_INCL 1
- bool flags;
+ #define FLAG_DESC 2
+ byte flags;
} mp_obj_btree_t;
STATIC const mp_obj_type_t btree_type;
@@ -141,16 +142,19 @@ STATIC mp_obj_t btree_iternext(mp_obj_t self_in) {
mp_obj_btree_t *self = MP_OBJ_TO_PTR(self_in);
DBT key, val;
int res;
+ bool desc = self->flags & FLAG_DESC;
if (self->start_key != MP_OBJ_NULL) {
int flags = R_FIRST;
if (self->start_key != mp_const_none) {
key.data = (void*)mp_obj_str_get_data(self->start_key, &key.size);
flags = R_CURSOR;
+ } else if (desc) {
+ flags = R_LAST;
}
res = __bt_seq(self->db, &key, &val, flags);
self->start_key = MP_OBJ_NULL;
} else {
- res = __bt_seq(self->db, &key, &val, R_NEXT);
+ res = __bt_seq(self->db, &key, &val, desc ? R_PREV : R_NEXT);
}
if (res == RET_SPECIAL) {
@@ -163,6 +167,9 @@ STATIC mp_obj_t btree_iternext(mp_obj_t self_in) {
end_key.data = (void*)mp_obj_str_get_data(self->end_key, &end_key.size);
BTREE *t = self->db->internal;
int cmp = t->bt_cmp(&key, &end_key);
+ if (desc) {
+ cmp = -cmp;
+ }
if (self->flags & FLAG_END_KEY_INCL) {
cmp--;
}
@@ -254,6 +261,7 @@ STATIC const mp_rom_map_elem_t mp_module_btree_globals_table[] = {
{ MP_ROM_QSTR(MP_QSTR___name__), MP_ROM_QSTR(MP_QSTR_btree) },
{ MP_ROM_QSTR(MP_QSTR_open), MP_ROM_PTR(&mod_btree_open_obj) },
{ MP_ROM_QSTR(MP_QSTR_INCL), MP_OBJ_NEW_SMALL_INT(FLAG_END_KEY_INCL) },
+ { MP_ROM_QSTR(MP_QSTR_DESC), MP_OBJ_NEW_SMALL_INT(FLAG_DESC) },
};
STATIC MP_DEFINE_CONST_DICT(mp_module_btree_globals, mp_module_btree_globals_table);