|
|
@ -76,17 +76,16 @@ void MemTableListVersion::AddIterators(const ReadOptions& options, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// caller is responsible for referencing m
|
|
|
|
void MemTableListVersion::Add(MemTable* m) { |
|
|
|
void MemTableListVersion::Add(MemTable* m) { |
|
|
|
assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable
|
|
|
|
assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable
|
|
|
|
m->Ref(); |
|
|
|
|
|
|
|
memlist_.push_front(m); |
|
|
|
memlist_.push_front(m); |
|
|
|
++size_; |
|
|
|
++size_; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// caller is responsible for unreferencing m
|
|
|
|
void MemTableListVersion::Remove(MemTable* m) { |
|
|
|
void MemTableListVersion::Remove(MemTable* m) { |
|
|
|
assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable
|
|
|
|
assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable
|
|
|
|
MemTable* x __attribute__((unused)) = m->Unref(); |
|
|
|
|
|
|
|
assert(x == nullptr); // it still needs to be alive!
|
|
|
|
|
|
|
|
memlist_.remove(m); |
|
|
|
memlist_.remove(m); |
|
|
|
--size_; |
|
|
|
--size_; |
|
|
|
} |
|
|
|
} |
|
|
@ -232,6 +231,11 @@ Status MemTableList::InstallMemtableFlushResults( |
|
|
|
void MemTableList::Add(MemTable* m) { |
|
|
|
void MemTableList::Add(MemTable* m) { |
|
|
|
assert(current_->size_ >= num_flush_not_started_); |
|
|
|
assert(current_->size_ >= num_flush_not_started_); |
|
|
|
InstallNewVersion(); |
|
|
|
InstallNewVersion(); |
|
|
|
|
|
|
|
// this method is used to move mutable memtable into an immutable list.
|
|
|
|
|
|
|
|
// since mutable memtable is already refcounted by the DBImpl,
|
|
|
|
|
|
|
|
// and when moving to the imutable list we don't unref it,
|
|
|
|
|
|
|
|
// we don't have to ref the memtable here. we just take over the
|
|
|
|
|
|
|
|
// reference from the DBImpl.
|
|
|
|
current_->Add(m); |
|
|
|
current_->Add(m); |
|
|
|
m->MarkImmutable(); |
|
|
|
m->MarkImmutable(); |
|
|
|
num_flush_not_started_++; |
|
|
|
num_flush_not_started_++; |
|
|
|