| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 | //  Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.//  This source code is licensed under both the GPLv2 (found in the//  COPYING file in the root directory) and Apache 2.0 License//  (found in the LICENSE.Apache file in the root directory).//// Copyright (c) 2011 The LevelDB Authors. All rights reserved.// Use of this source code is governed by a BSD-style license that can be// found in the LICENSE file. See the AUTHORS file for names of contributors.#pragma once#ifndef ROCKSDB_LITE#include "db/compaction/compaction_picker.h"namespace ROCKSDB_NAMESPACE {class FIFOCompactionPicker : public CompactionPicker { public:  FIFOCompactionPicker(const ImmutableCFOptions& ioptions,                       const InternalKeyComparator* icmp)      : CompactionPicker(ioptions, icmp) {}  virtual Compaction* PickCompaction(      const std::string& cf_name, const MutableCFOptions& mutable_cf_options,      VersionStorageInfo* version, LogBuffer* log_buffer,      SequenceNumber earliest_memtable_seqno = kMaxSequenceNumber) override;  virtual Compaction* CompactRange(      const std::string& cf_name, const MutableCFOptions& mutable_cf_options,      VersionStorageInfo* vstorage, int input_level, int output_level,      const CompactRangeOptions& compact_range_options,      const InternalKey* begin, const InternalKey* end,      InternalKey** compaction_end, bool* manual_conflict,      uint64_t max_file_num_to_ignore) override;  // The maximum allowed output level.  Always returns 0.  virtual int MaxOutputLevel() const override { return 0; }  virtual bool NeedsCompaction(      const VersionStorageInfo* vstorage) const override; private:  Compaction* PickTTLCompaction(const std::string& cf_name,                                const MutableCFOptions& mutable_cf_options,                                VersionStorageInfo* version,                                LogBuffer* log_buffer);  Compaction* PickSizeCompaction(const std::string& cf_name,                                 const MutableCFOptions& mutable_cf_options,                                 VersionStorageInfo* version,                                 LogBuffer* log_buffer);};}  // namespace ROCKSDB_NAMESPACE#endif  // !ROCKSDB_LITE
 |