2013-10-28 20:34:02 -07:00
|
|
|
// 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.
|
|
|
|
|
2014-04-15 13:39:26 -07:00
|
|
|
#ifndef ROCKSDB_LITE
|
2014-01-27 21:58:46 -08:00
|
|
|
#include "table/plain_table_factory.h"
|
2013-10-28 20:34:02 -07:00
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
#include <stdint.h>
|
2014-01-27 13:53:22 -08:00
|
|
|
#include "db/dbformat.h"
|
2013-10-28 20:34:02 -07:00
|
|
|
#include "table/plain_table_builder.h"
|
|
|
|
#include "table/plain_table_reader.h"
|
|
|
|
#include "port/port.h"
|
|
|
|
|
|
|
|
namespace rocksdb {
|
|
|
|
|
2014-09-04 16:18:36 -07:00
|
|
|
Status PlainTableFactory::NewTableReader(const ImmutableCFOptions& ioptions,
|
|
|
|
const EnvOptions& env_options,
|
2014-01-27 13:53:22 -08:00
|
|
|
const InternalKeyComparator& icomp,
|
2014-01-27 21:58:46 -08:00
|
|
|
unique_ptr<RandomAccessFile>&& file,
|
2013-10-28 20:34:02 -07:00
|
|
|
uint64_t file_size,
|
2014-01-27 21:58:46 -08:00
|
|
|
unique_ptr<TableReader>* table) const {
|
2014-09-04 16:18:36 -07:00
|
|
|
return PlainTableReader::Open(ioptions, env_options, icomp, std::move(file),
|
2014-01-27 13:53:22 -08:00
|
|
|
file_size, table, bloom_bits_per_key_,
|
2014-05-04 13:55:53 -07:00
|
|
|
hash_table_ratio_, index_sparseness_,
|
2014-06-18 16:36:48 -07:00
|
|
|
huge_page_tlb_size_, full_scan_mode_);
|
2013-10-28 20:34:02 -07:00
|
|
|
}
|
|
|
|
|
2014-01-27 21:58:46 -08:00
|
|
|
TableBuilder* PlainTableFactory::NewTableBuilder(
|
2014-09-04 16:18:36 -07:00
|
|
|
const ImmutableCFOptions& ioptions,
|
2015-02-17 08:03:45 -08:00
|
|
|
const InternalKeyComparator& internal_comparator, WritableFile* file,
|
|
|
|
const CompressionType, const CompressionOptions&,
|
|
|
|
const bool skip_filters) const {
|
|
|
|
|
|
|
|
// Ignore the skip_filters flag. PlainTable format is optimized for small
|
|
|
|
// in-memory dbs. The skip_filters optimization is not useful for plain
|
|
|
|
// tables
|
|
|
|
//
|
2014-09-04 16:18:36 -07:00
|
|
|
return new PlainTableBuilder(ioptions, file, user_key_len_, encoding_type_,
|
2014-07-18 16:58:13 -07:00
|
|
|
index_sparseness_, bloom_bits_per_key_, 6,
|
|
|
|
huge_page_tlb_size_, hash_table_ratio_,
|
|
|
|
store_index_in_file_);
|
2013-10-28 20:34:02 -07:00
|
|
|
}
|
2014-01-27 21:58:46 -08:00
|
|
|
|
2014-08-25 14:24:09 -07:00
|
|
|
std::string PlainTableFactory::GetPrintableTableOptions() const {
|
|
|
|
std::string ret;
|
|
|
|
ret.reserve(20000);
|
|
|
|
const int kBufferSize = 200;
|
|
|
|
char buffer[kBufferSize];
|
|
|
|
|
|
|
|
snprintf(buffer, kBufferSize, " user_key_len: %u\n",
|
|
|
|
user_key_len_);
|
|
|
|
ret.append(buffer);
|
|
|
|
snprintf(buffer, kBufferSize, " bloom_bits_per_key: %d\n",
|
|
|
|
bloom_bits_per_key_);
|
|
|
|
ret.append(buffer);
|
|
|
|
snprintf(buffer, kBufferSize, " hash_table_ratio: %lf\n",
|
|
|
|
hash_table_ratio_);
|
|
|
|
ret.append(buffer);
|
2014-09-29 23:23:09 +02:00
|
|
|
snprintf(buffer, kBufferSize, " index_sparseness: %zu\n",
|
2014-08-25 14:24:09 -07:00
|
|
|
index_sparseness_);
|
|
|
|
ret.append(buffer);
|
2014-09-29 23:23:09 +02:00
|
|
|
snprintf(buffer, kBufferSize, " huge_page_tlb_size: %zu\n",
|
2014-08-25 14:24:09 -07:00
|
|
|
huge_page_tlb_size_);
|
|
|
|
ret.append(buffer);
|
|
|
|
snprintf(buffer, kBufferSize, " encoding_type: %d\n",
|
|
|
|
encoding_type_);
|
|
|
|
ret.append(buffer);
|
|
|
|
snprintf(buffer, kBufferSize, " full_scan_mode: %d\n",
|
|
|
|
full_scan_mode_);
|
|
|
|
ret.append(buffer);
|
|
|
|
snprintf(buffer, kBufferSize, " store_index_in_file: %d\n",
|
|
|
|
store_index_in_file_);
|
|
|
|
ret.append(buffer);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2014-07-18 00:08:38 -07:00
|
|
|
extern TableFactory* NewPlainTableFactory(const PlainTableOptions& options) {
|
|
|
|
return new PlainTableFactory(options);
|
2014-01-27 21:58:46 -08:00
|
|
|
}
|
|
|
|
|
2014-06-18 16:36:48 -07:00
|
|
|
const std::string PlainTablePropertyNames::kPrefixExtractorName =
|
|
|
|
"rocksdb.prefix.extractor.name";
|
|
|
|
|
|
|
|
const std::string PlainTablePropertyNames::kEncodingType =
|
|
|
|
"rocksdb.plain.table.encoding.type";
|
|
|
|
|
2014-07-18 16:58:13 -07:00
|
|
|
const std::string PlainTablePropertyNames::kBloomVersion =
|
|
|
|
"rocksdb.plain.table.bloom.version";
|
|
|
|
|
|
|
|
const std::string PlainTablePropertyNames::kNumBloomBlocks =
|
|
|
|
"rocksdb.plain.table.bloom.numblocks";
|
|
|
|
|
2013-10-28 20:34:02 -07:00
|
|
|
} // namespace rocksdb
|
2014-04-15 13:39:26 -07:00
|
|
|
#endif // ROCKSDB_LITE
|