mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:14:12 +08:00
mdbx: update DBXs with cursor-tracking.
This commit is contained in:
parent
7ce1a4c0cf
commit
cbafb3f471
20
src/bits.h
20
src/bits.h
@ -1300,3 +1300,23 @@ static __inline pgno_t pgno_align2os_pgno(const MDBX_env *env, pgno_t pgno) {
|
|||||||
|
|
||||||
/* Do not spill pages to disk if txn is getting full, may fail instead */
|
/* Do not spill pages to disk if txn is getting full, may fail instead */
|
||||||
#define MDBX_NOSPILL 0x8000
|
#define MDBX_NOSPILL 0x8000
|
||||||
|
|
||||||
|
/* Perform act while tracking temporary cursor mn */
|
||||||
|
#define WITH_CURSOR_TRACKING(mn, act) \
|
||||||
|
do { \
|
||||||
|
mdbx_cassert(&(mn), \
|
||||||
|
mn.mc_txn->mt_cursors != NULL /* must be not rdonly txt */); \
|
||||||
|
MDBX_cursor mc_dummy, *tracked, \
|
||||||
|
**tp = &(mn).mc_txn->mt_cursors[mn.mc_dbi]; \
|
||||||
|
if ((mn).mc_flags & C_SUB) { \
|
||||||
|
mc_dummy.mc_flags = C_INITIALIZED; \
|
||||||
|
mc_dummy.mc_xcursor = (MDBX_xcursor *)&(mn); \
|
||||||
|
tracked = &mc_dummy; \
|
||||||
|
} else { \
|
||||||
|
tracked = &(mn); \
|
||||||
|
} \
|
||||||
|
tracked->mc_next = *tp; \
|
||||||
|
*tp = tracked; \
|
||||||
|
{ act; } \
|
||||||
|
*tp = tracked->mc_next; \
|
||||||
|
} while (0)
|
||||||
|
24
src/mdbx.c
24
src/mdbx.c
@ -4535,7 +4535,9 @@ int mdbx_txn_commit(MDBX_txn *txn) {
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
data.iov_base = &txn->mt_dbs[i];
|
data.iov_base = &txn->mt_dbs[i];
|
||||||
rc = mdbx_cursor_put(&mc, &txn->mt_dbxs[i].md_name, &data, F_SUBDATA);
|
WITH_CURSOR_TRACKING(mc,
|
||||||
|
rc = mdbx_cursor_put(&mc, &txn->mt_dbxs[i].md_name,
|
||||||
|
&data, F_SUBDATA));
|
||||||
if (unlikely(rc != MDBX_SUCCESS))
|
if (unlikely(rc != MDBX_SUCCESS))
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
@ -9202,26 +9204,6 @@ static int mdbx_update_key(MDBX_cursor *mc, MDBX_val *key) {
|
|||||||
|
|
||||||
static void mdbx_cursor_copy(const MDBX_cursor *csrc, MDBX_cursor *cdst);
|
static void mdbx_cursor_copy(const MDBX_cursor *csrc, MDBX_cursor *cdst);
|
||||||
|
|
||||||
/* Perform act while tracking temporary cursor mn */
|
|
||||||
#define WITH_CURSOR_TRACKING(mn, act) \
|
|
||||||
do { \
|
|
||||||
mdbx_cassert(&(mn), \
|
|
||||||
mn.mc_txn->mt_cursors != NULL /* must be not rdonly txt */); \
|
|
||||||
MDBX_cursor mc_dummy, *tracked, \
|
|
||||||
**tp = &(mn).mc_txn->mt_cursors[mn.mc_dbi]; \
|
|
||||||
if ((mn).mc_flags & C_SUB) { \
|
|
||||||
mc_dummy.mc_flags = C_INITIALIZED; \
|
|
||||||
mc_dummy.mc_xcursor = (MDBX_xcursor *)&(mn); \
|
|
||||||
tracked = &mc_dummy; \
|
|
||||||
} else { \
|
|
||||||
tracked = &(mn); \
|
|
||||||
} \
|
|
||||||
tracked->mc_next = *tp; \
|
|
||||||
*tp = tracked; \
|
|
||||||
{ act; } \
|
|
||||||
*tp = tracked->mc_next; \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
/* Move a node from csrc to cdst. */
|
/* Move a node from csrc to cdst. */
|
||||||
static int mdbx_node_move(MDBX_cursor *csrc, MDBX_cursor *cdst, int fromleft) {
|
static int mdbx_node_move(MDBX_cursor *csrc, MDBX_cursor *cdst, int fromleft) {
|
||||||
MDBX_node *srcnode;
|
MDBX_node *srcnode;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user