Commit b6912850 authored by vchigrin's avatar vchigrin Committed by Commit bot

Protect SerializedData from copying.

Compiler-generated copy constructor does not generate
correct code for this class, so make it move-only type.

Review-Url: https://codereview.chromium.org/2781993005
Cr-Commit-Position: refs/heads/master@{#44266}
parent d389d473
...@@ -485,7 +485,7 @@ Vector<const uint32_t> SerializedCodeData::CodeStubKeys() const { ...@@ -485,7 +485,7 @@ Vector<const uint32_t> SerializedCodeData::CodeStubKeys() const {
SerializedCodeData::SerializedCodeData(ScriptData* data) SerializedCodeData::SerializedCodeData(ScriptData* data)
: SerializedData(const_cast<byte*>(data->data()), data->length()) {} : SerializedData(const_cast<byte*>(data->data()), data->length()) {}
const SerializedCodeData SerializedCodeData::FromCachedData( SerializedCodeData SerializedCodeData::FromCachedData(
Isolate* isolate, ScriptData* cached_data, uint32_t expected_source_hash, Isolate* isolate, ScriptData* cached_data, uint32_t expected_source_hash,
SanityCheckResult* rejection_result) { SanityCheckResult* rejection_result) {
DisallowHeapAllocation no_gc; DisallowHeapAllocation no_gc;
......
...@@ -116,9 +116,10 @@ class SerializedCodeData : public SerializedData { ...@@ -116,9 +116,10 @@ class SerializedCodeData : public SerializedData {
static const int kHeaderSize = POINTER_SIZE_ALIGN(kUnalignedHeaderSize); static const int kHeaderSize = POINTER_SIZE_ALIGN(kUnalignedHeaderSize);
// Used when consuming. // Used when consuming.
static const SerializedCodeData FromCachedData( static SerializedCodeData FromCachedData(Isolate* isolate,
Isolate* isolate, ScriptData* cached_data, uint32_t expected_source_hash, ScriptData* cached_data,
SanityCheckResult* rejection_result); uint32_t expected_source_hash,
SanityCheckResult* rejection_result);
// Used when producing. // Used when producing.
SerializedCodeData(const List<byte>* payload, const CodeSerializer* cs); SerializedCodeData(const List<byte>* payload, const CodeSerializer* cs);
......
...@@ -239,6 +239,11 @@ class SerializedData { ...@@ -239,6 +239,11 @@ class SerializedData {
SerializedData(byte* data, int size) SerializedData(byte* data, int size)
: data_(data), size_(size), owns_data_(false) {} : data_(data), size_(size), owns_data_(false) {}
SerializedData() : data_(NULL), size_(0), owns_data_(false) {} SerializedData() : data_(NULL), size_(0), owns_data_(false) {}
SerializedData(SerializedData&& other)
: data_(other.data_), size_(other.size_), owns_data_(other.owns_data_) {
// Ensure |other| will not attempt to destroy our data in destructor.
other.owns_data_ = false;
}
~SerializedData() { ~SerializedData() {
if (owns_data_) DeleteArray<byte>(data_); if (owns_data_) DeleteArray<byte>(data_);
...@@ -295,6 +300,9 @@ class SerializedData { ...@@ -295,6 +300,9 @@ class SerializedData {
byte* data_; byte* data_;
int size_; int size_;
bool owns_data_; bool owns_data_;
private:
DISALLOW_COPY_AND_ASSIGN(SerializedData);
}; };
} // namespace internal } // namespace internal
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment