Prepare for interleaving checkRangeRightSide
This commit is contained in:
@@ -2496,13 +2496,9 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
auto remaining = key;
|
auto remaining = key;
|
||||||
int searchPathLen = 0;
|
int searchPathLen = 0;
|
||||||
|
|
||||||
for (;; ++tls->range_read_iterations_accum) {
|
assert(remaining.size() > 0);
|
||||||
assert(searchPathLen <= int(key.size()));
|
|
||||||
if (remaining.size() == 0) {
|
|
||||||
goto downLeftSpine;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (searchPathLen >= prefixLen) {
|
if (prefixLen == 0) {
|
||||||
if (n->entryPresent && n->entry.pointVersion > readVersion) {
|
if (n->entryPresent && n->entry.pointVersion > readVersion) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@@ -2512,11 +2508,7 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (searchPathLen > prefixLen && n->entryPresent &&
|
for (;;) {
|
||||||
n->entry.rangeVersion > readVersion) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
Node *child = getChild(n, remaining[0]);
|
Node *child = getChild(n, remaining[0]);
|
||||||
if (child == nullptr) {
|
if (child == nullptr) {
|
||||||
auto c = getChildGeq(n, remaining[0]);
|
auto c = getChildGeq(n, remaining[0]);
|
||||||
@@ -2556,6 +2548,24 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
goto downLeftSpine;
|
goto downLeftSpine;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
++tls->range_read_iterations_accum;
|
||||||
|
|
||||||
|
assert(searchPathLen <= int(key.size()));
|
||||||
|
|
||||||
|
if (remaining.size() == 0) {
|
||||||
|
goto downLeftSpine;
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(searchPathLen >= prefixLen);
|
||||||
|
if (n->entryPresent && (n->entry.pointVersion > readVersion ||
|
||||||
|
n->entry.rangeVersion > readVersion)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!checkMaxBetweenExclusive(n, -1, remaining[0], readVersion, tls)) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
backtrack:
|
backtrack:
|
||||||
for (;;) {
|
for (;;) {
|
||||||
|
Reference in New Issue
Block a user