Skip to content

Commit

Permalink
Fix MergeContext::copied_operands_ strings moving
Browse files Browse the repository at this point in the history
Summary:
MergeContext::copied_operands contain strings that MergeContext::operand_list_ Slices point to
It's possible that when MergeContext::copied_operands grow, these strings are moved and there place in memory is changed, this will cause MergeContext::operand_list_ to point to invalid memory.
fix this problem by using unique_ptr<string> instead of string

Test Plan: run tests under mac/clang

Reviewers: sdong, yiwu

Reviewed By: yiwu

Subscribers: andrewkr, dhruba

Differential Revision: https://reviews.facebook.net/D61023
  • Loading branch information
IslamAbdelRahman committed Jul 25, 2016
1 parent a4955b3 commit 16e225f
Showing 1 changed file with 8 additions and 8 deletions.
16 changes: 8 additions & 8 deletions db/merge_context.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,9 @@ class MergeContext {
operand_list_->push_back(operand_slice);
} else {
// We need to have our own copy of the operand since it's not pinned
copied_operands_->emplace_back(operand_slice.data(),
operand_slice.size());
operand_list_->push_back(copied_operands_->back());
copied_operands_->emplace_back(
new std::string(operand_slice.data(), operand_slice.size()));
operand_list_->push_back(*copied_operands_->back());
}
}

Expand All @@ -52,9 +52,9 @@ class MergeContext {
operand_list_->push_back(operand_slice);
} else {
// We need to have our own copy of the operand since it's not pinned
copied_operands_->emplace_back(operand_slice.data(),
operand_slice.size());
operand_list_->push_back(copied_operands_->back());
copied_operands_->emplace_back(
new std::string(operand_slice.data(), operand_slice.size()));
operand_list_->push_back(*copied_operands_->back());
}
}

Expand Down Expand Up @@ -88,7 +88,7 @@ class MergeContext {
void Initialize() {
if (!operand_list_) {
operand_list_.reset(new std::vector<Slice>());
copied_operands_.reset(new std::vector<std::string>());
copied_operands_.reset(new std::vector<std::unique_ptr<std::string>>());
}
}

Expand All @@ -109,7 +109,7 @@ class MergeContext {
// List of operands
std::unique_ptr<std::vector<Slice>> operand_list_;
// Copy of operands that are not pinned.
std::unique_ptr<std::vector<std::string>> copied_operands_;
std::unique_ptr<std::vector<std::unique_ptr<std::string>>> copied_operands_;
bool operands_reversed_ = true;
};

Expand Down

0 comments on commit 16e225f

Please sign in to comment.