mirror of
https://github.com/isar/libmdbx.git
synced 2025-01-08 05:24:12 +08:00
mdbx: fix MDBX_NODUPDATA handling for key-value data.
More for https://github.com/erthink/libmdbx/issues/99 in continue to 9428efd2ae9f7fe984422b5eb1fc47f732236b51 Change-Id: I56050ddf5e56807a11d8613780c3ba76cc16d324
This commit is contained in:
parent
8c8c86038a
commit
e28d223d42
@ -12023,10 +12023,12 @@ int mdbx_cursor_put(MDBX_cursor *mc, const MDBX_val *key, MDBX_val *data,
|
|||||||
if (exact) {
|
if (exact) {
|
||||||
if (mc->mc_flags & C_SUB) {
|
if (mc->mc_flags & C_SUB) {
|
||||||
mdbx_assert(env, data->iov_len == 0 && olddata.iov_len == 0);
|
mdbx_assert(env, data->iov_len == 0 && olddata.iov_len == 0);
|
||||||
return rc;
|
return (flags & MDBX_NODUPDATA) ? MDBX_KEYEXIST : MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
if (!(flags & MDBX_RESERVE) && mc->mc_dbx->md_dcmp(data, &olddata) == 0)
|
if (!(flags & MDBX_RESERVE) &&
|
||||||
return rc;
|
unlikely(mc->mc_dbx->md_dcmp(data, &olddata) == 0))
|
||||||
|
return ((flags & MDBX_NODUPDATA) && mc->mc_xcursor) ? MDBX_KEYEXIST
|
||||||
|
: MDBX_SUCCESS;
|
||||||
}
|
}
|
||||||
} else if (unlikely(rc != MDBX_NOTFOUND))
|
} else if (unlikely(rc != MDBX_NOTFOUND))
|
||||||
return rc;
|
return rc;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user