2019-03-27 18:24:16 +01:00
|
|
|
// 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
|
|
|
|
|
|
|
|
#include "monitoring/perf_context_imp.h"
|
|
|
|
#include "rocksdb/comparator.h"
|
|
|
|
|
2020-02-20 21:07:53 +01:00
|
|
|
namespace ROCKSDB_NAMESPACE {
|
2019-03-27 18:24:16 +01:00
|
|
|
|
|
|
|
// Wrapper of user comparator, with auto increment to
|
|
|
|
// perf_context.user_key_comparison_count.
|
|
|
|
class UserComparatorWrapper final : public Comparator {
|
|
|
|
public:
|
2020-07-08 02:25:08 +02:00
|
|
|
// `UserComparatorWrapper`s constructed with the default constructor are not
|
|
|
|
// usable and will segfault on any attempt to use them for comparisons.
|
|
|
|
UserComparatorWrapper() : user_comparator_(nullptr) {}
|
|
|
|
|
2019-03-27 18:24:16 +01:00
|
|
|
explicit UserComparatorWrapper(const Comparator* const user_cmp)
|
2020-03-07 01:21:03 +01:00
|
|
|
: Comparator(user_cmp->timestamp_size()), user_comparator_(user_cmp) {}
|
|
|
|
|
2019-03-27 18:24:16 +01:00
|
|
|
~UserComparatorWrapper() = default;
|
|
|
|
|
|
|
|
const Comparator* user_comparator() const { return user_comparator_; }
|
|
|
|
|
|
|
|
int Compare(const Slice& a, const Slice& b) const override {
|
|
|
|
PERF_COUNTER_ADD(user_key_comparison_count, 1);
|
|
|
|
return user_comparator_->Compare(a, b);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool Equal(const Slice& a, const Slice& b) const override {
|
|
|
|
PERF_COUNTER_ADD(user_key_comparison_count, 1);
|
|
|
|
return user_comparator_->Equal(a, b);
|
|
|
|
}
|
|
|
|
|
|
|
|
const char* Name() const override { return user_comparator_->Name(); }
|
|
|
|
|
|
|
|
void FindShortestSeparator(std::string* start,
|
|
|
|
const Slice& limit) const override {
|
|
|
|
return user_comparator_->FindShortestSeparator(start, limit);
|
|
|
|
}
|
|
|
|
|
|
|
|
void FindShortSuccessor(std::string* key) const override {
|
|
|
|
return user_comparator_->FindShortSuccessor(key);
|
|
|
|
}
|
|
|
|
|
|
|
|
const Comparator* GetRootComparator() const override {
|
|
|
|
return user_comparator_->GetRootComparator();
|
|
|
|
}
|
|
|
|
|
|
|
|
bool IsSameLengthImmediateSuccessor(const Slice& s,
|
|
|
|
const Slice& t) const override {
|
|
|
|
return user_comparator_->IsSameLengthImmediateSuccessor(s, t);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool CanKeysWithDifferentByteContentsBeEqual() const override {
|
|
|
|
return user_comparator_->CanKeysWithDifferentByteContentsBeEqual();
|
|
|
|
}
|
|
|
|
|
2020-03-07 01:21:03 +01:00
|
|
|
int CompareTimestamp(const Slice& ts1, const Slice& ts2) const override {
|
|
|
|
return user_comparator_->CompareTimestamp(ts1, ts2);
|
|
|
|
}
|
|
|
|
|
|
|
|
using Comparator::CompareWithoutTimestamp;
|
|
|
|
int CompareWithoutTimestamp(const Slice& a, bool a_has_ts, const Slice& b,
|
|
|
|
bool b_has_ts) const override {
|
|
|
|
PERF_COUNTER_ADD(user_key_comparison_count, 1);
|
|
|
|
return user_comparator_->CompareWithoutTimestamp(a, a_has_ts, b, b_has_ts);
|
|
|
|
}
|
|
|
|
|
2021-03-10 20:13:55 +01:00
|
|
|
bool EqualWithoutTimestamp(const Slice& a, const Slice& b) const override {
|
|
|
|
return user_comparator_->EqualWithoutTimestamp(a, b);
|
|
|
|
}
|
|
|
|
|
2019-03-27 18:24:16 +01:00
|
|
|
private:
|
|
|
|
const Comparator* user_comparator_;
|
|
|
|
};
|
|
|
|
|
2020-02-20 21:07:53 +01:00
|
|
|
} // namespace ROCKSDB_NAMESPACE
|