Skip to content

Commit

Permalink
HPCC-30938 checkCount/getCount double counting seeks
Browse files Browse the repository at this point in the history
checkCount/getCount does not need to count/note seeks,
because the _lookup it calls that is passed the same
'stats' container already does so.

Signed-off-by: Jake Smith <[email protected]>
  • Loading branch information
jakesmith committed Nov 29, 2023
1 parent 92bba5b commit 135f5f0
Showing 1 changed file with 0 additions and 6 deletions.
6 changes: 0 additions & 6 deletions system/jhtree/jhtree.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2027,7 +2027,6 @@ unsigned __int64 CKeyCursor::getCount(KeyStatsCollector &stats)
{
reset();
unsigned __int64 result = 0;
unsigned lseeks = 0;
unsigned lastRealSeg = filter->lastRealSeg();
bool unfiltered = filter->isUnfiltered();
for (;;)
Expand All @@ -2037,23 +2036,20 @@ unsigned __int64 CKeyCursor::getCount(KeyStatsCollector &stats)
unsigned __int64 locount = getSequence();
endRange(lastRealSeg);
_ltEqual(stats);
lseeks++;
result += getSequence()-locount+1;
if (!incrementKey(lastRealSeg))
break;
}
else
break;
}
stats.noteSeeks(lseeks, 0, 0);
return result;
}

unsigned __int64 CKeyCursor::checkCount(unsigned __int64 max, KeyStatsCollector &stats)
{
reset();
unsigned __int64 result = 0;
unsigned lseeks = 0;
unsigned lastFullSeg = filter->lastFullSeg();
bool unfiltered = filter->isUnfiltered();
if (lastFullSeg == (unsigned) -1)
Expand All @@ -2071,7 +2067,6 @@ unsigned __int64 CKeyCursor::checkCount(unsigned __int64 max, KeyStatsCollector
unsigned __int64 locount = getSequence();
endRange(lastFullSeg);
_ltEqual(stats);
lseeks++;
result += getSequence()-locount+1;
if (max && (result > max))
break;
Expand All @@ -2081,7 +2076,6 @@ unsigned __int64 CKeyCursor::checkCount(unsigned __int64 max, KeyStatsCollector
else
break;
}
stats.noteSeeks(lseeks, 0, 0);
return result;
}

Expand Down

0 comments on commit 135f5f0

Please sign in to comment.