Coverage Report

Created: 2025-10-26 07:13

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/rocksdb/db/compaction/compaction_picker_universal.h
Line
Count
Source
1
//  Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
2
//  This source code is licensed under both the GPLv2 (found in the
3
//  COPYING file in the root directory) and Apache 2.0 License
4
//  (found in the LICENSE.Apache file in the root directory).
5
//
6
// Copyright (c) 2011 The LevelDB Authors. All rights reserved.
7
// Use of this source code is governed by a BSD-style license that can be
8
// found in the LICENSE file. See the AUTHORS file for names of contributors.
9
10
#pragma once
11
12
#include "db/compaction/compaction_picker.h"
13
#include "db/snapshot_checker.h"
14
15
namespace ROCKSDB_NAMESPACE {
16
class UniversalCompactionPicker : public CompactionPicker {
17
 public:
18
  UniversalCompactionPicker(const ImmutableOptions& ioptions,
19
                            const InternalKeyComparator* icmp)
20
0
      : CompactionPicker(ioptions, icmp) {}
21
22
  // If `require_max_output_level` is true, only pick compaction
23
  // with max output level or return nullptr if no such compaction exists.
24
  Compaction* PickCompaction(
25
      const std::string& cf_name, const MutableCFOptions& mutable_cf_options,
26
      const MutableDBOptions& mutable_db_options,
27
      const std::vector<SequenceNumber>& existing_snapshots,
28
      const SnapshotChecker* snapshot_checker, VersionStorageInfo* vstorage,
29
      LogBuffer* log_buffer, bool require_max_output_level = false) override;
30
0
  int MaxOutputLevel() const override { return NumberLevels() - 1; }
31
32
  bool NeedsCompaction(const VersionStorageInfo* vstorage) const override;
33
};
34
}  // namespace ROCKSDB_NAMESPACE