Make the options in table_builder/block_builder less misleading
Summary: By original design, the regular `block options` and index `block options` in table_builder is mutable. We can use ChangeOptions to change the options directly. However, with my last change, `BlockBuilder` no longer hold the reference to the index_block_options -- as a result, any changes made after the creation of index block builder will be of no effect. But still the code is very error-prone and developers can easily fall into the trap without aware of it. To avoid this problem from happening in the future, I deleted the `ChangeOptions` and the `index_block_options`, as well as many other changes to make it less misleading. Test Plan: make make check make release Reviewers: dhruba, haobo Reviewed By: haobo CC: leveldb Differential Revision: https://reviews.facebook.net/D13707
This commit is contained in:
parent
f7a2b972a8
commit
7604e2f70c
@ -77,7 +77,6 @@ void LogStatsCollectionError(
|
|||||||
|
|
||||||
struct BlockBasedTableBuilder::Rep {
|
struct BlockBasedTableBuilder::Rep {
|
||||||
Options options;
|
Options options;
|
||||||
Options index_block_options;
|
|
||||||
WritableFile* file;
|
WritableFile* file;
|
||||||
uint64_t offset = 0;
|
uint64_t offset = 0;
|
||||||
Status status;
|
Status status;
|
||||||
@ -105,10 +104,11 @@ struct BlockBasedTableBuilder::Rep {
|
|||||||
|
|
||||||
Rep(const Options& opt, WritableFile* f, CompressionType compression_type)
|
Rep(const Options& opt, WritableFile* f, CompressionType compression_type)
|
||||||
: options(opt),
|
: options(opt),
|
||||||
index_block_options(opt),
|
|
||||||
file(f),
|
file(f),
|
||||||
data_block(&options),
|
data_block(options),
|
||||||
index_block(1, index_block_options.comparator),
|
// To avoid linear scan, we make the block_restart_interval to be `1`
|
||||||
|
// in index block builder
|
||||||
|
index_block(1 /* block_restart_interval */, options.comparator),
|
||||||
compression_type(compression_type),
|
compression_type(compression_type),
|
||||||
filter_block(opt.filter_policy == nullptr ? nullptr
|
filter_block(opt.filter_policy == nullptr ? nullptr
|
||||||
: new FilterBlockBuilder(opt)) {
|
: new FilterBlockBuilder(opt)) {
|
||||||
|
@ -51,8 +51,8 @@ BlockBuilder::BlockBuilder(int block_restart_interval,
|
|||||||
restarts_.push_back(0); // First restart point is at offset 0
|
restarts_.push_back(0); // First restart point is at offset 0
|
||||||
}
|
}
|
||||||
|
|
||||||
BlockBuilder::BlockBuilder(const Options* options)
|
BlockBuilder::BlockBuilder(const Options& options)
|
||||||
: BlockBuilder(options->block_restart_interval, options->comparator) {
|
: BlockBuilder(options.block_restart_interval, options.comparator) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void BlockBuilder::Reset() {
|
void BlockBuilder::Reset() {
|
||||||
|
@ -20,8 +20,8 @@ class Comparator;
|
|||||||
|
|
||||||
class BlockBuilder {
|
class BlockBuilder {
|
||||||
public:
|
public:
|
||||||
BlockBuilder(int block_restart_interval, const Comparator* comparator);
|
BlockBuilder(int block_builder, const Comparator* comparator);
|
||||||
explicit BlockBuilder(const Options* options);
|
explicit BlockBuilder(const Options& options);
|
||||||
|
|
||||||
// Reset the contents as if the BlockBuilder was just constructed.
|
// Reset the contents as if the BlockBuilder was just constructed.
|
||||||
void Reset();
|
void Reset();
|
||||||
|
@ -34,7 +34,7 @@ TEST(BlockTest, SimpleTest) {
|
|||||||
Options options = Options();
|
Options options = Options();
|
||||||
std::vector<std::string> keys;
|
std::vector<std::string> keys;
|
||||||
std::vector<std::string> values;
|
std::vector<std::string> values;
|
||||||
BlockBuilder builder(&options);
|
BlockBuilder builder(options);
|
||||||
int num_records = 100000;
|
int num_records = 100000;
|
||||||
char buf[10];
|
char buf[10];
|
||||||
char* p = &buf[0];
|
char* p = &buf[0];
|
||||||
|
@ -217,7 +217,7 @@ class BlockConstructor: public Constructor {
|
|||||||
virtual Status FinishImpl(const Options& options, const KVMap& data) {
|
virtual Status FinishImpl(const Options& options, const KVMap& data) {
|
||||||
delete block_;
|
delete block_;
|
||||||
block_ = nullptr;
|
block_ = nullptr;
|
||||||
BlockBuilder builder(&options);
|
BlockBuilder builder(options);
|
||||||
|
|
||||||
for (KVMap::const_iterator it = data.begin();
|
for (KVMap::const_iterator it = data.begin();
|
||||||
it != data.end();
|
it != data.end();
|
||||||
@ -832,7 +832,7 @@ TEST(TableTest, BasicTableStats) {
|
|||||||
ASSERT_EQ("", stats.filter_policy_name); // no filter policy is used
|
ASSERT_EQ("", stats.filter_policy_name); // no filter policy is used
|
||||||
|
|
||||||
// Verify data size.
|
// Verify data size.
|
||||||
BlockBuilder block_builder(&options);
|
BlockBuilder block_builder(options);
|
||||||
for (const auto& item : kvmap) {
|
for (const auto& item : kvmap) {
|
||||||
block_builder.Add(item.first, item.second);
|
block_builder.Add(item.first, item.second);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user