mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-23 01:38:22 +08:00
mdbx: fix add-node-args asserts.
This commit is contained in:
parent
6043181636
commit
1fca3d4c93
14
src/mdbx.c
14
src/mdbx.c
@ -8351,7 +8351,8 @@ new_sub:
|
|||||||
} else {
|
} else {
|
||||||
/* There is room already in this leaf page. */
|
/* There is room already in this leaf page. */
|
||||||
if (IS_LEAF2(mc->mc_pg[mc->mc_top])) {
|
if (IS_LEAF2(mc->mc_pg[mc->mc_top])) {
|
||||||
mdbx_cassert(mc, nflags == 0 && rdata->iov_len == 0);
|
mdbx_cassert(mc, (nflags & (F_BIGDATA | F_SUBDATA | F_DUPDATA)) == 0 &&
|
||||||
|
rdata->iov_len == 0);
|
||||||
rc = mdbx_node_add_leaf2(mc, mc->mc_ki[mc->mc_top], key);
|
rc = mdbx_node_add_leaf2(mc, mc->mc_ki[mc->mc_top], key);
|
||||||
} else
|
} else
|
||||||
rc = mdbx_node_add_leaf(mc, mc->mc_ki[mc->mc_top], key, rdata, nflags);
|
rc = mdbx_node_add_leaf(mc, mc->mc_ki[mc->mc_top], key, rdata, nflags);
|
||||||
@ -10797,16 +10798,17 @@ static int mdbx_page_split(MDBX_cursor *mc, const MDBX_val *newkey,
|
|||||||
mc->mc_ki[mc->mc_top] = 0;
|
mc->mc_ki[mc->mc_top] = 0;
|
||||||
switch (PAGETYPE(rp)) {
|
switch (PAGETYPE(rp)) {
|
||||||
case P_BRANCH: {
|
case P_BRANCH: {
|
||||||
mdbx_cassert(mc, nflags == 0);
|
mdbx_cassert(mc, (nflags & (F_BIGDATA | F_SUBDATA | F_DUPDATA)) == 0);
|
||||||
|
mdbx_cassert(mc, newpgno != 0 || newpgno != P_INVALID);
|
||||||
rc = mdbx_node_add_branch(mc, 0, newkey, newpgno);
|
rc = mdbx_node_add_branch(mc, 0, newkey, newpgno);
|
||||||
} break;
|
} break;
|
||||||
case P_LEAF: {
|
case P_LEAF: {
|
||||||
mdbx_cassert(mc, newpgno == 0);
|
mdbx_cassert(mc, newpgno == 0 || newpgno == P_INVALID);
|
||||||
rc = mdbx_node_add_leaf(mc, 0, newkey, newdata, nflags);
|
rc = mdbx_node_add_leaf(mc, 0, newkey, newdata, nflags);
|
||||||
} break;
|
} break;
|
||||||
case P_LEAF | P_LEAF2: {
|
case P_LEAF | P_LEAF2: {
|
||||||
mdbx_cassert(mc, nflags == 0);
|
mdbx_cassert(mc, (nflags & (F_BIGDATA | F_SUBDATA | F_DUPDATA)) == 0);
|
||||||
mdbx_cassert(mc, newpgno == 0);
|
mdbx_cassert(mc, newpgno == 0 || newpgno == P_INVALID);
|
||||||
rc = mdbx_node_add_leaf2(mc, 0, newkey);
|
rc = mdbx_node_add_leaf2(mc, 0, newkey);
|
||||||
} break;
|
} break;
|
||||||
default:
|
default:
|
||||||
@ -10860,7 +10862,7 @@ static int mdbx_page_split(MDBX_cursor *mc, const MDBX_val *newkey,
|
|||||||
rc = mdbx_node_add_leaf(mc, n, &rkey, rdata, flags);
|
rc = mdbx_node_add_leaf(mc, n, &rkey, rdata, flags);
|
||||||
} break;
|
} break;
|
||||||
/* case P_LEAF | P_LEAF2: {
|
/* case P_LEAF | P_LEAF2: {
|
||||||
mdbx_cassert(mc, 0 == (uint16_t)flags);
|
mdbx_cassert(mc, (nflags & (F_BIGDATA | F_SUBDATA | F_DUPDATA)) == 0);
|
||||||
mdbx_cassert(mc, gno == 0);
|
mdbx_cassert(mc, gno == 0);
|
||||||
rc = mdbx_node_add_leaf2(mc, n, &rkey);
|
rc = mdbx_node_add_leaf2(mc, n, &rkey);
|
||||||
} break; */
|
} break; */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user