|
|
@ -110,9 +110,7 @@ struct StartKeyMinComparator { |
|
|
|
|
|
|
|
|
|
|
|
class ForwardRangeDelIterator { |
|
|
|
class ForwardRangeDelIterator { |
|
|
|
public: |
|
|
|
public: |
|
|
|
ForwardRangeDelIterator( |
|
|
|
explicit ForwardRangeDelIterator(const InternalKeyComparator* icmp); |
|
|
|
const InternalKeyComparator* icmp, |
|
|
|
|
|
|
|
const std::vector<std::unique_ptr<TruncatedRangeDelIterator>>* iters); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool ShouldDelete(const ParsedInternalKey& parsed); |
|
|
|
bool ShouldDelete(const ParsedInternalKey& parsed); |
|
|
|
void Invalidate(); |
|
|
|
void Invalidate(); |
|
|
@ -181,7 +179,6 @@ class ForwardRangeDelIterator { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const InternalKeyComparator* icmp_; |
|
|
|
const InternalKeyComparator* icmp_; |
|
|
|
const std::vector<std::unique_ptr<TruncatedRangeDelIterator>>* iters_; |
|
|
|
|
|
|
|
size_t unused_idx_; |
|
|
|
size_t unused_idx_; |
|
|
|
ActiveSeqSet active_seqnums_; |
|
|
|
ActiveSeqSet active_seqnums_; |
|
|
|
BinaryHeap<ActiveSeqSet::const_iterator, EndKeyMinComparator> active_iters_; |
|
|
|
BinaryHeap<ActiveSeqSet::const_iterator, EndKeyMinComparator> active_iters_; |
|
|
@ -190,9 +187,7 @@ class ForwardRangeDelIterator { |
|
|
|
|
|
|
|
|
|
|
|
class ReverseRangeDelIterator { |
|
|
|
class ReverseRangeDelIterator { |
|
|
|
public: |
|
|
|
public: |
|
|
|
ReverseRangeDelIterator( |
|
|
|
explicit ReverseRangeDelIterator(const InternalKeyComparator* icmp); |
|
|
|
const InternalKeyComparator* icmp, |
|
|
|
|
|
|
|
const std::vector<std::unique_ptr<TruncatedRangeDelIterator>>* iters); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool ShouldDelete(const ParsedInternalKey& parsed); |
|
|
|
bool ShouldDelete(const ParsedInternalKey& parsed); |
|
|
|
void Invalidate(); |
|
|
|
void Invalidate(); |
|
|
@ -268,7 +263,6 @@ class ReverseRangeDelIterator { |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
const InternalKeyComparator* icmp_; |
|
|
|
const InternalKeyComparator* icmp_; |
|
|
|
const std::vector<std::unique_ptr<TruncatedRangeDelIterator>>* iters_; |
|
|
|
|
|
|
|
size_t unused_idx_; |
|
|
|
size_t unused_idx_; |
|
|
|
ActiveSeqSet active_seqnums_; |
|
|
|
ActiveSeqSet active_seqnums_; |
|
|
|
BinaryHeap<ActiveSeqSet::const_iterator, StartKeyMaxComparator> active_iters_; |
|
|
|
BinaryHeap<ActiveSeqSet::const_iterator, StartKeyMaxComparator> active_iters_; |
|
|
@ -311,8 +305,8 @@ class RangeDelAggregator { |
|
|
|
StripeRep(const InternalKeyComparator* icmp, SequenceNumber upper_bound, |
|
|
|
StripeRep(const InternalKeyComparator* icmp, SequenceNumber upper_bound, |
|
|
|
SequenceNumber lower_bound) |
|
|
|
SequenceNumber lower_bound) |
|
|
|
: icmp_(icmp), |
|
|
|
: icmp_(icmp), |
|
|
|
forward_iter_(icmp, &iters_), |
|
|
|
forward_iter_(icmp), |
|
|
|
reverse_iter_(icmp, &iters_), |
|
|
|
reverse_iter_(icmp), |
|
|
|
upper_bound_(upper_bound), |
|
|
|
upper_bound_(upper_bound), |
|
|
|
lower_bound_(lower_bound) {} |
|
|
|
lower_bound_(lower_bound) {} |
|
|
|
|
|
|
|
|
|
|
|