mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-21 18:58:21 +08:00
mdbx: more checks inside mdbx_cursor_close()
.
Related to https://github.com/erthink/libmdbx/issues/146 Change-Id: I7b90a0e515aa6320b0e89ec52fe01bc0be126071
This commit is contained in:
parent
3e7459b428
commit
3758e7697e
@ -14273,16 +14273,18 @@ again:
|
|||||||
}
|
}
|
||||||
|
|
||||||
void mdbx_cursor_close(MDBX_cursor *mc) {
|
void mdbx_cursor_close(MDBX_cursor *mc) {
|
||||||
if (mc) {
|
if (likely(mc)) {
|
||||||
mdbx_ensure(NULL, mc->mc_signature == MDBX_MC_LIVE ||
|
mdbx_ensure(NULL, mc->mc_signature == MDBX_MC_LIVE ||
|
||||||
mc->mc_signature == MDBX_MC_READY4CLOSE);
|
mc->mc_signature == MDBX_MC_READY4CLOSE);
|
||||||
|
MDBX_txn *const txn = mc->mc_txn;
|
||||||
if (!mc->mc_backup) {
|
if (!mc->mc_backup) {
|
||||||
|
mc->mc_txn = NULL;
|
||||||
/* Remove from txn, if tracked.
|
/* Remove from txn, if tracked.
|
||||||
* A read-only txn (!C_UNTRACK) may have been freed already,
|
* A read-only txn (!C_UNTRACK) may have been freed already,
|
||||||
* so do not peek inside it. Only write txns track cursors. */
|
* so do not peek inside it. Only write txns track cursors. */
|
||||||
if (mc->mc_flags & C_UNTRACK) {
|
if (mc->mc_flags & C_UNTRACK) {
|
||||||
mdbx_cassert(mc, !(mc->mc_txn->mt_flags & MDBX_TXN_RDONLY));
|
mdbx_ensure(txn->mt_env, check_txn_rw(txn, 0) == MDBX_SUCCESS);
|
||||||
MDBX_cursor **prev = &mc->mc_txn->tw.cursors[mc->mc_dbi];
|
MDBX_cursor **prev = &txn->tw.cursors[mc->mc_dbi];
|
||||||
while (*prev && *prev != mc)
|
while (*prev && *prev != mc)
|
||||||
prev = &(*prev)->mc_next;
|
prev = &(*prev)->mc_next;
|
||||||
mdbx_cassert(mc, *prev == mc);
|
mdbx_cassert(mc, *prev == mc);
|
||||||
@ -14294,6 +14296,7 @@ void mdbx_cursor_close(MDBX_cursor *mc) {
|
|||||||
} else {
|
} else {
|
||||||
/* Cursor closed before nested txn ends */
|
/* Cursor closed before nested txn ends */
|
||||||
mdbx_cassert(mc, mc->mc_signature == MDBX_MC_LIVE);
|
mdbx_cassert(mc, mc->mc_signature == MDBX_MC_LIVE);
|
||||||
|
mdbx_ensure(txn->mt_env, check_txn_rw(txn, 0) == MDBX_SUCCESS);
|
||||||
mc->mc_signature = MDBX_MC_WAIT4EOT;
|
mc->mc_signature = MDBX_MC_WAIT4EOT;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user