Stop tracking searchPathLen
This commit is contained in:
@@ -2494,7 +2494,6 @@ namespace {
|
|||||||
bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
||||||
InternalVersionT readVersion, ReadContext *tls) {
|
InternalVersionT readVersion, ReadContext *tls) {
|
||||||
auto remaining = key;
|
auto remaining = key;
|
||||||
int searchPathLen = 0;
|
|
||||||
|
|
||||||
assert(remaining.size() > 0);
|
assert(remaining.size() > 0);
|
||||||
|
|
||||||
@@ -2508,7 +2507,7 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (;;) {
|
for (bool first = true;; first = 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]);
|
||||||
@@ -2516,28 +2515,31 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
n = c;
|
n = c;
|
||||||
goto downLeftSpine;
|
goto downLeftSpine;
|
||||||
} else {
|
} else {
|
||||||
|
if (!first && maxVersion(n) > readVersion) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
goto backtrack;
|
goto backtrack;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
n = child;
|
n = child;
|
||||||
remaining = remaining.subspan(1, remaining.size() - 1);
|
remaining = remaining.subspan(1, remaining.size() - 1);
|
||||||
++searchPathLen;
|
|
||||||
|
|
||||||
if (n->partialKeyLen > 0) {
|
if (n->partialKeyLen > 0) {
|
||||||
int commonLen = std::min<int>(n->partialKeyLen, remaining.size());
|
int commonLen = std::min<int>(n->partialKeyLen, remaining.size());
|
||||||
int i = longestCommonPrefix(n->partialKey(), remaining.data(), commonLen);
|
int i = longestCommonPrefix(n->partialKey(), remaining.data(), commonLen);
|
||||||
searchPathLen += i;
|
|
||||||
if (i < commonLen) {
|
if (i < commonLen) {
|
||||||
++searchPathLen;
|
|
||||||
auto c = n->partialKey()[i] <=> remaining[i];
|
auto c = n->partialKey()[i] <=> remaining[i];
|
||||||
if (c > 0) {
|
if (c > 0) {
|
||||||
goto downLeftSpine;
|
goto downLeftSpine;
|
||||||
} else {
|
} else {
|
||||||
if (searchPathLen > prefixLen && n->entryPresent &&
|
if ((!first || i + 1 >= prefixLen) && n->entryPresent &&
|
||||||
n->entry.rangeVersion > readVersion) {
|
n->entry.rangeVersion > readVersion) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
if ((!first || i + 1 >= prefixLen) && maxVersion(n) > readVersion) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
goto backtrack;
|
goto backtrack;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2551,13 +2553,10 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
|
|
||||||
++tls->range_read_iterations_accum;
|
++tls->range_read_iterations_accum;
|
||||||
|
|
||||||
assert(searchPathLen <= int(key.size()));
|
|
||||||
|
|
||||||
if (remaining.size() == 0) {
|
if (remaining.size() == 0) {
|
||||||
goto downLeftSpine;
|
goto downLeftSpine;
|
||||||
}
|
}
|
||||||
|
|
||||||
assert(searchPathLen >= prefixLen);
|
|
||||||
if (n->entryPresent && (n->entry.pointVersion > readVersion ||
|
if (n->entryPresent && (n->entry.pointVersion > readVersion ||
|
||||||
n->entry.rangeVersion > readVersion)) {
|
n->entry.rangeVersion > readVersion)) {
|
||||||
return false;
|
return false;
|
||||||
@@ -2569,21 +2568,14 @@ bool checkRangeRightSide(Node *n, std::span<const uint8_t> key, int prefixLen,
|
|||||||
}
|
}
|
||||||
backtrack:
|
backtrack:
|
||||||
for (;;) {
|
for (;;) {
|
||||||
// searchPathLen > prefixLen implies n is not the root
|
|
||||||
if (searchPathLen > prefixLen && maxVersion(n) > readVersion) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (n->parent == nullptr) {
|
if (n->parent == nullptr) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
auto next = getChildGeq(n->parent, n->parentsIndex + 1);
|
auto next = getChildGeq(n->parent, n->parentsIndex + 1);
|
||||||
if (next == nullptr) {
|
if (next == nullptr) {
|
||||||
searchPathLen -= 1 + n->partialKeyLen;
|
|
||||||
n = n->parent;
|
n = n->parent;
|
||||||
} else {
|
} else {
|
||||||
searchPathLen -= n->partialKeyLen;
|
|
||||||
n = next;
|
n = next;
|
||||||
searchPathLen += n->partialKeyLen;
|
|
||||||
goto downLeftSpine;
|
goto downLeftSpine;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user