Coverage Report

Created: 2023-01-03 07:00

/src/leveldb/table/iterator_wrapper.h
Line
Count
Source (jump to first uncovered line)
1
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
2
// Use of this source code is governed by a BSD-style license that can be
3
// found in the LICENSE file. See the AUTHORS file for names of contributors.
4
5
#ifndef STORAGE_LEVELDB_TABLE_ITERATOR_WRAPPER_H_
6
#define STORAGE_LEVELDB_TABLE_ITERATOR_WRAPPER_H_
7
8
#include "leveldb/iterator.h"
9
#include "leveldb/slice.h"
10
11
namespace leveldb {
12
13
// A internal wrapper class with an interface similar to Iterator that
14
// caches the valid() and key() results for an underlying iterator.
15
// This can help avoid virtual function calls and also gives better
16
// cache locality.
17
class IteratorWrapper {
18
 public:
19
526k
  IteratorWrapper() : iter_(nullptr), valid_(false) {}
20
1.53M
  explicit IteratorWrapper(Iterator* iter) : iter_(nullptr) { Set(iter); }
21
2.06M
  ~IteratorWrapper() { delete iter_; }
22
10.8M
  Iterator* iter() const { return iter_; }
23
24
  // Takes ownership of "iter" and will delete it when destroyed, or
25
  // when Set() is invoked again.
26
3.82M
  void Set(Iterator* iter) {
27
3.82M
    delete iter_;
28
3.82M
    iter_ = iter;
29
3.82M
    if (iter_ == nullptr) {
30
1.77M
      valid_ = false;
31
2.05M
    } else {
32
2.05M
      Update();
33
2.05M
    }
34
3.82M
  }
35
36
  // Iterator interface methods
37
32.9M
  bool Valid() const { return valid_; }
38
23.7M
  Slice key() const {
39
23.7M
    assert(Valid());
40
23.7M
    return key_;
41
23.7M
  }
42
8.81M
  Slice value() const {
43
8.81M
    assert(Valid());
44
8.81M
    return iter_->value();
45
8.81M
  }
46
  // Methods below require iter() != nullptr
47
1.28M
  Status status() const {
48
1.28M
    assert(iter_);
49
1.28M
    return iter_->status();
50
1.28M
  }
51
10.9M
  void Next() {
52
10.9M
    assert(iter_);
53
10.9M
    iter_->Next();
54
10.9M
    Update();
55
10.9M
  }
56
0
  void Prev() {
57
0
    assert(iter_);
58
0
    iter_->Prev();
59
0
    Update();
60
0
  }
61
0
  void Seek(const Slice& k) {
62
0
    assert(iter_);
63
0
    iter_->Seek(k);
64
0
    Update();
65
0
  }
66
1.52M
  void SeekToFirst() {
67
1.52M
    assert(iter_);
68
1.52M
    iter_->SeekToFirst();
69
1.52M
    Update();
70
1.52M
  }
71
0
  void SeekToLast() {
72
0
    assert(iter_);
73
0
    iter_->SeekToLast();
74
0
    Update();
75
0
  }
76
77
 private:
78
14.5M
  void Update() {
79
14.5M
    valid_ = iter_->Valid();
80
14.5M
    if (valid_) {
81
10.9M
      key_ = iter_->key();
82
10.9M
    }
83
14.5M
  }
84
85
  Iterator* iter_;
86
  bool valid_;
87
  Slice key_;
88
};
89
90
}  // namespace leveldb
91
92
#endif  // STORAGE_LEVELDB_TABLE_ITERATOR_WRAPPER_H_