Remove FactoryFunc from LoadXXXObject (#11203)
Summary: The primary purpose of the FactoryFunc was to support LITE mode where the ObjectRegistry was not available. With the removal of LITE mode, the function was no longer required. Note that the MergeOperator had some private classes defined in header files. To gain access to their constructors (and name methods), the class definitions were moved into header files. Pull Request resolved: https://github.com/facebook/rocksdb/pull/11203 Reviewed By: cbi42 Differential Revision: D43160255 Pulled By: pdillinger fbshipit-source-id: f3a465fd5d1a7049b73ecf31e4b8c3762f6dae6coxigraph-8.1.1
parent
25e1365227
commit
b6640c3117
@ -0,0 +1,35 @@ |
||||
// 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).
|
||||
//
|
||||
// Merge operator that picks the maximum operand, Comparison is based on
|
||||
// Slice::compare
|
||||
|
||||
#pragma once |
||||
|
||||
#include "rocksdb/merge_operator.h" |
||||
|
||||
namespace ROCKSDB_NAMESPACE { |
||||
class Logger; |
||||
class Slice; |
||||
|
||||
class MaxOperator : public MergeOperator { |
||||
public: |
||||
static const char* kClassName() { return "MaxOperator"; } |
||||
static const char* kNickName() { return "max"; } |
||||
const char* Name() const override { return kClassName(); } |
||||
const char* NickName() const override { return kNickName(); } |
||||
|
||||
bool FullMergeV2(const MergeOperationInput& merge_in, |
||||
MergeOperationOutput* merge_out) const override; |
||||
bool PartialMerge(const Slice& /*key*/, const Slice& left_operand, |
||||
const Slice& right_operand, std::string* new_value, |
||||
Logger* /*logger*/) const override; |
||||
bool PartialMergeMulti(const Slice& /*key*/, |
||||
const std::deque<Slice>& operand_list, |
||||
std::string* new_value, |
||||
Logger* /*logger*/) const override; |
||||
}; |
||||
|
||||
} // namespace ROCKSDB_NAMESPACE
|
@ -0,0 +1,56 @@ |
||||
// 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).
|
||||
//
|
||||
// A merge operator that mimics Put semantics
|
||||
// Since this merge-operator will not be used in production,
|
||||
// it is implemented as a non-associative merge operator to illustrate the
|
||||
// new interface and for testing purposes. (That is, we inherit from
|
||||
// the MergeOperator class rather than the AssociativeMergeOperator
|
||||
// which would be simpler in this case).
|
||||
//
|
||||
// From the client-perspective, semantics are the same.
|
||||
|
||||
#pragma once |
||||
|
||||
#include "rocksdb/merge_operator.h" |
||||
|
||||
namespace ROCKSDB_NAMESPACE { |
||||
class Logger; |
||||
class Slice; |
||||
|
||||
class PutOperator : public MergeOperator { |
||||
public: |
||||
static const char* kClassName() { return "PutOperator"; } |
||||
static const char* kNickName() { return "put_v1"; } |
||||
const char* Name() const override { return kClassName(); } |
||||
const char* NickName() const override { return kNickName(); } |
||||
|
||||
bool FullMerge(const Slice& /*key*/, const Slice* /*existing_value*/, |
||||
const std::deque<std::string>& operand_sequence, |
||||
std::string* new_value, Logger* /*logger*/) const override; |
||||
bool PartialMerge(const Slice& /*key*/, const Slice& left_operand, |
||||
const Slice& right_operand, std::string* new_value, |
||||
Logger* /*logger*/) const override; |
||||
using MergeOperator::PartialMergeMulti; |
||||
bool PartialMergeMulti(const Slice& /*key*/, |
||||
const std::deque<Slice>& operand_list, |
||||
std::string* new_value, |
||||
Logger* /*logger*/) const override; |
||||
}; |
||||
|
||||
class PutOperatorV2 : public PutOperator { |
||||
public: |
||||
static const char* kNickName() { return "put"; } |
||||
const char* NickName() const override { return kNickName(); } |
||||
|
||||
bool FullMerge(const Slice& /*key*/, const Slice* /*existing_value*/, |
||||
const std::deque<std::string>& /*operand_sequence*/, |
||||
std::string* /*new_value*/, Logger* /*logger*/) const override; |
||||
|
||||
bool FullMergeV2(const MergeOperationInput& merge_in, |
||||
MergeOperationOutput* merge_out) const override; |
||||
}; |
||||
|
||||
} // namespace ROCKSDB_NAMESPACE
|
@ -0,0 +1,35 @@ |
||||
// 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).
|
||||
//
|
||||
// A 'model' merge operator with uint64 addition semantics
|
||||
// Implemented as an AssociativeMergeOperator for simplicity and example.
|
||||
|
||||
#pragma once |
||||
|
||||
#include "rocksdb/merge_operator.h" |
||||
#include "utilities/merge_operators.h" |
||||
|
||||
namespace ROCKSDB_NAMESPACE { |
||||
class Logger; |
||||
class Slice; |
||||
|
||||
class UInt64AddOperator : public AssociativeMergeOperator { |
||||
public: |
||||
static const char* kClassName() { return "UInt64AddOperator"; } |
||||
static const char* kNickName() { return "uint64add"; } |
||||
const char* Name() const override { return kClassName(); } |
||||
const char* NickName() const override { return kNickName(); } |
||||
|
||||
bool Merge(const Slice& /*key*/, const Slice* existing_value, |
||||
const Slice& value, std::string* new_value, |
||||
Logger* logger) const override; |
||||
|
||||
private: |
||||
// Takes the string and decodes it into a uint64_t
|
||||
// On error, prints a message and returns 0
|
||||
uint64_t DecodeInteger(const Slice& value, Logger* logger) const; |
||||
}; |
||||
|
||||
} // namespace ROCKSDB_NAMESPACE
|
Loading…
Reference in new issue