2013-10-16 21:59:46 +00:00
|
|
|
// Copyright (c) 2013, Facebook, Inc. All rights reserved.
|
|
|
|
// This source code is licensed under the BSD-style license found in the
|
|
|
|
// LICENSE file in the root directory of this source tree. An additional grant
|
|
|
|
// of patent rights can be found in the PATENTS file in the same directory.
|
|
|
|
//
|
2013-08-13 21:04:56 +00:00
|
|
|
// Copyright (c) 2012 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.
|
|
|
|
|
2015-07-01 23:13:49 +00:00
|
|
|
#include <algorithm>
|
2013-08-23 15:38:13 +00:00
|
|
|
#include "rocksdb/slice_transform.h"
|
|
|
|
#include "rocksdb/slice.h"
|
2014-11-25 04:44:49 +00:00
|
|
|
#include "util/string_util.h"
|
2015-07-07 23:58:20 +00:00
|
|
|
#include <stdio.h>
|
2013-08-13 21:04:56 +00:00
|
|
|
|
2013-10-04 04:49:15 +00:00
|
|
|
namespace rocksdb {
|
2013-08-13 21:04:56 +00:00
|
|
|
|
|
|
|
namespace {
|
|
|
|
|
|
|
|
class FixedPrefixTransform : public SliceTransform {
|
|
|
|
private:
|
|
|
|
size_t prefix_len_;
|
2014-05-13 21:42:31 +00:00
|
|
|
std::string name_;
|
2013-08-13 21:04:56 +00:00
|
|
|
|
|
|
|
public:
|
2014-05-13 21:42:31 +00:00
|
|
|
explicit FixedPrefixTransform(size_t prefix_len)
|
|
|
|
: prefix_len_(prefix_len),
|
2014-11-25 04:44:49 +00:00
|
|
|
name_("rocksdb.FixedPrefix." + ToString(prefix_len_)) {}
|
2013-08-13 21:04:56 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual const char* Name() const override { return name_.c_str(); }
|
2013-08-13 21:04:56 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual Slice Transform(const Slice& src) const override {
|
2013-08-13 21:04:56 +00:00
|
|
|
assert(InDomain(src));
|
|
|
|
return Slice(src.data(), prefix_len_);
|
|
|
|
}
|
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool InDomain(const Slice& src) const override {
|
2013-08-13 21:04:56 +00:00
|
|
|
return (src.size() >= prefix_len_);
|
|
|
|
}
|
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool InRange(const Slice& dst) const override {
|
2013-08-13 21:04:56 +00:00
|
|
|
return (dst.size() == prefix_len_);
|
|
|
|
}
|
2015-01-21 19:09:56 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool SameResultWhenAppended(const Slice& prefix) const override {
|
2015-01-21 19:09:56 +00:00
|
|
|
return InDomain(prefix);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class CappedPrefixTransform : public SliceTransform {
|
|
|
|
private:
|
|
|
|
size_t cap_len_;
|
|
|
|
std::string name_;
|
|
|
|
|
|
|
|
public:
|
|
|
|
explicit CappedPrefixTransform(size_t cap_len)
|
|
|
|
: cap_len_(cap_len),
|
|
|
|
name_("rocksdb.CappedPrefix." + ToString(cap_len_)) {}
|
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual const char* Name() const override { return name_.c_str(); }
|
2015-01-21 19:09:56 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual Slice Transform(const Slice& src) const override {
|
2015-01-21 19:09:56 +00:00
|
|
|
assert(InDomain(src));
|
|
|
|
return Slice(src.data(), std::min(cap_len_, src.size()));
|
|
|
|
}
|
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool InDomain(const Slice& src) const override { return true; }
|
2015-01-21 19:09:56 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool InRange(const Slice& dst) const override {
|
2015-01-21 19:09:56 +00:00
|
|
|
return (dst.size() <= cap_len_);
|
|
|
|
}
|
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool SameResultWhenAppended(const Slice& prefix) const override {
|
2015-01-21 19:09:56 +00:00
|
|
|
return prefix.size() >= cap_len_;
|
|
|
|
}
|
2013-08-13 21:04:56 +00:00
|
|
|
};
|
2013-08-23 06:10:02 +00:00
|
|
|
|
|
|
|
class NoopTransform : public SliceTransform {
|
|
|
|
public:
|
|
|
|
explicit NoopTransform() { }
|
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual const char* Name() const override { return "rocksdb.Noop"; }
|
2013-08-23 06:10:02 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual Slice Transform(const Slice& src) const override { return src; }
|
2013-08-23 06:10:02 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool InDomain(const Slice& src) const override { return true; }
|
2013-08-23 06:10:02 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool InRange(const Slice& dst) const override { return true; }
|
2015-01-21 19:09:56 +00:00
|
|
|
|
2015-02-26 19:28:41 +00:00
|
|
|
virtual bool SameResultWhenAppended(const Slice& prefix) const override {
|
2015-01-21 19:09:56 +00:00
|
|
|
return false;
|
|
|
|
}
|
2013-08-23 06:10:02 +00:00
|
|
|
};
|
|
|
|
|
2013-08-13 21:04:56 +00:00
|
|
|
}
|
|
|
|
|
2015-07-07 23:58:20 +00:00
|
|
|
// Do not want to include the whole /port/port.h here for one define
|
|
|
|
#ifdef OS_WIN
|
2015-07-13 19:11:05 +00:00
|
|
|
#define snprintf _snprintf
|
2015-07-07 23:58:20 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
// Return a string that contains the copy of the referenced data.
|
|
|
|
std::string Slice::ToString(bool hex) const {
|
2015-07-13 19:11:05 +00:00
|
|
|
std::string result; // RVO/NRVO/move
|
2015-07-07 23:58:20 +00:00
|
|
|
if (hex) {
|
|
|
|
char buf[10];
|
|
|
|
for (size_t i = 0; i < size_; i++) {
|
|
|
|
snprintf(buf, 10, "%02X", (unsigned char)data_[i]);
|
|
|
|
result += buf;
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
} else {
|
|
|
|
result.assign(data_, size_);
|
|
|
|
return result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-13 21:04:56 +00:00
|
|
|
const SliceTransform* NewFixedPrefixTransform(size_t prefix_len) {
|
|
|
|
return new FixedPrefixTransform(prefix_len);
|
|
|
|
}
|
|
|
|
|
2015-01-21 19:09:56 +00:00
|
|
|
const SliceTransform* NewCappedPrefixTransform(size_t cap_len) {
|
|
|
|
return new CappedPrefixTransform(cap_len);
|
|
|
|
}
|
|
|
|
|
2013-08-23 06:10:02 +00:00
|
|
|
const SliceTransform* NewNoopTransform() {
|
|
|
|
return new NoopTransform;
|
|
|
|
}
|
|
|
|
|
2013-10-04 04:49:15 +00:00
|
|
|
} // namespace rocksdb
|