2020-04-28 18:02:11 -07: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.
|
|
|
|
|
|
|
|
#include "rocksdb/cache.h"
|
|
|
|
|
|
|
|
#include "cache/lru_cache.h"
|
|
|
|
#include "options/options_helper.h"
|
|
|
|
#include "util/string_util.h"
|
|
|
|
|
|
|
|
namespace ROCKSDB_NAMESPACE {
|
2020-05-21 10:56:40 -07:00
|
|
|
#ifndef ROCKSDB_LITE
|
|
|
|
static std::unordered_map<std::string, OptionTypeInfo>
|
|
|
|
lru_cache_options_type_info = {
|
|
|
|
{"capacity",
|
|
|
|
{offsetof(struct LRUCacheOptions, capacity), OptionType::kSizeT,
|
|
|
|
OptionVerificationType::kNormal, OptionTypeFlags::kMutable,
|
|
|
|
offsetof(struct LRUCacheOptions, capacity)}},
|
|
|
|
{"num_shard_bits",
|
|
|
|
{offsetof(struct LRUCacheOptions, num_shard_bits), OptionType::kInt,
|
|
|
|
OptionVerificationType::kNormal, OptionTypeFlags::kMutable,
|
|
|
|
offsetof(struct LRUCacheOptions, num_shard_bits)}},
|
|
|
|
{"strict_capacity_limit",
|
|
|
|
{offsetof(struct LRUCacheOptions, strict_capacity_limit),
|
|
|
|
OptionType::kBoolean, OptionVerificationType::kNormal,
|
|
|
|
OptionTypeFlags::kMutable,
|
|
|
|
offsetof(struct LRUCacheOptions, strict_capacity_limit)}},
|
|
|
|
{"high_pri_pool_ratio",
|
|
|
|
{offsetof(struct LRUCacheOptions, high_pri_pool_ratio),
|
|
|
|
OptionType::kDouble, OptionVerificationType::kNormal,
|
|
|
|
OptionTypeFlags::kMutable,
|
|
|
|
offsetof(struct LRUCacheOptions, high_pri_pool_ratio)}}};
|
|
|
|
#endif // ROCKSDB_LITE
|
|
|
|
|
|
|
|
Status Cache::CreateFromString(const ConfigOptions& config_options,
|
2020-04-28 18:02:11 -07:00
|
|
|
const std::string& value,
|
|
|
|
std::shared_ptr<Cache>* result) {
|
|
|
|
Status status;
|
|
|
|
std::shared_ptr<Cache> cache;
|
|
|
|
if (value.find('=') == std::string::npos) {
|
|
|
|
cache = NewLRUCache(ParseSizeT(value));
|
|
|
|
} else {
|
|
|
|
#ifndef ROCKSDB_LITE
|
|
|
|
LRUCacheOptions cache_opts;
|
2020-05-21 10:56:40 -07:00
|
|
|
status = OptionTypeInfo::ParseStruct(
|
|
|
|
config_options, "", &lru_cache_options_type_info, "", value,
|
|
|
|
reinterpret_cast<char*>(&cache_opts));
|
|
|
|
if (status.ok()) {
|
|
|
|
cache = NewLRUCache(cache_opts);
|
2020-04-28 18:02:11 -07:00
|
|
|
}
|
|
|
|
#else
|
2020-05-21 10:56:40 -07:00
|
|
|
(void)config_options;
|
2020-04-28 18:02:11 -07:00
|
|
|
status = Status::NotSupported("Cannot load cache in LITE mode ", value);
|
|
|
|
#endif //! ROCKSDB_LITE
|
|
|
|
}
|
|
|
|
if (status.ok()) {
|
|
|
|
result->swap(cache);
|
|
|
|
}
|
|
|
|
return status;
|
|
|
|
}
|
|
|
|
} // namespace ROCKSDB_NAMESPACE
|