mdbx: minor refine/fix MDBX_ENODATA for compatibility.

Related to https://github.com/erthink/libmdbx/issues/243
This commit is contained in:
Леонид Юрьев (Leonid Yuriev) 2021-12-02 17:25:27 +03:00
parent c2cab7a6a8
commit d96bc98244
2 changed files with 6 additions and 2 deletions

View File

@ -13750,7 +13750,7 @@ static int mdbx_cursor_next(MDBX_cursor *mc, MDBX_val *key, MDBX_val *data,
mp = mc->mc_pg[mc->mc_top]; mp = mc->mc_pg[mc->mc_top];
if (mc->mc_flags & C_EOF) { if (mc->mc_flags & C_EOF) {
if (mc->mc_ki[mc->mc_top] + 1u >= page_numkeys(mp)) if (mc->mc_ki[mc->mc_top] + 1u >= page_numkeys(mp))
return MDBX_ENODATA; return (mc->mc_flags & C_SUB) ? MDBX_NOTFOUND : MDBX_ENODATA;
mc->mc_flags ^= C_EOF; mc->mc_flags ^= C_EOF;
} }
@ -14337,12 +14337,14 @@ int mdbx_cursor_get(MDBX_cursor *mc, MDBX_val *key, MDBX_val *data,
int (*mfunc)(MDBX_cursor * mc, MDBX_val * key, MDBX_val * data); int (*mfunc)(MDBX_cursor * mc, MDBX_val * key, MDBX_val * data);
switch (op) { switch (op) {
case MDBX_GET_CURRENT: { case MDBX_GET_CURRENT: {
if (unlikely((mc->mc_flags & (C_INITIALIZED | C_EOF)) != C_INITIALIZED)) if (unlikely(!(mc->mc_flags & C_INITIALIZED)))
return MDBX_ENODATA; return MDBX_ENODATA;
MDBX_page *mp = mc->mc_pg[mc->mc_top]; MDBX_page *mp = mc->mc_pg[mc->mc_top];
const unsigned nkeys = page_numkeys(mp); const unsigned nkeys = page_numkeys(mp);
if (mc->mc_ki[mc->mc_top] >= nkeys) { if (mc->mc_ki[mc->mc_top] >= nkeys) {
mdbx_cassert(mc, nkeys <= UINT16_MAX); mdbx_cassert(mc, nkeys <= UINT16_MAX);
if (mc->mc_flags & C_EOF)
return MDBX_ENODATA;
mc->mc_ki[mc->mc_top] = (uint16_t)nkeys; mc->mc_ki[mc->mc_top] = (uint16_t)nkeys;
mc->mc_flags |= C_EOF; mc->mc_flags |= C_EOF;
return MDBX_NOTFOUND; return MDBX_NOTFOUND;

View File

@ -1174,6 +1174,8 @@ bool testcase::speculum_verify() {
rc = false; rc = false;
} }
err = mdbx_cursor_get(cursor, &akey, &avalue, MDBX_GET_CURRENT); err = mdbx_cursor_get(cursor, &akey, &avalue, MDBX_GET_CURRENT);
if (err == MDBX_SUCCESS)
err = mdbx_cursor_get(cursor, &akey, &avalue, MDBX_NEXT);
if (err != MDBX_ENODATA) { if (err != MDBX_ENODATA) {
log_error("unexpected %d for MDBX_GET_CURRENT at EOF", err); log_error("unexpected %d for MDBX_GET_CURRENT at EOF", err);
rc = false; rc = false;