diff --git a/src/cursor.c b/src/cursor.c index 56a4487c..8f1bba85 100644 --- a/src/cursor.c +++ b/src/cursor.c @@ -638,7 +638,7 @@ static __always_inline int cursor_step(const bool inner, const bool forward, MDB inner_gone(mc); } else { if (mc->flags & z_hollow) { - cASSERT(mc, !inner_pointed(mc)); + cASSERT(mc, !inner_pointed(mc) || inner_hollow(mc)); return MDBX_ENODATA; } @@ -1818,8 +1818,9 @@ __hot csr_t cursor_seek(MDBX_cursor *mc, MDBX_val *key, MDBX_val *data, MDBX_cur * Поэтому переводим курсор в неустановленное состояние, но без сброса * top, что позволяет работать fastpath при последующем поиске по дереву * страниц. */ - mc->flags = z_hollow | (mc->flags & z_clear_mask); - inner_gone(mc); + mc->flags |= z_hollow; + if (inner_pointed(mc)) + mc->subcur->cursor.flags |= z_hollow; ret.err = MDBX_NOTFOUND; return ret; } diff --git a/src/cursor.h b/src/cursor.h index ece1866d..a55f1377 100644 --- a/src/cursor.h +++ b/src/cursor.h @@ -151,7 +151,7 @@ MDBX_MAYBE_UNUSED MDBX_NOTHROW_PURE_FUNCTION static inline bool is_hollow(const cASSERT(mc, mc->top >= 0); cASSERT(mc, (mc->flags & z_eof_hard) || mc->ki[mc->top] < page_numkeys(mc->pg[mc->top])); } else if (mc->subcur) - cASSERT(mc, is_poor(&mc->subcur->cursor)); + cASSERT(mc, is_poor(&mc->subcur->cursor) || (is_pointed(mc) && mc->subcur->cursor.flags < 0)); return r; }