Chromium Code Reviews| Index: third_party/WebKit/Source/bindings/modules/v8/SerializedScriptValueForModulesFactory.cpp |
| diff --git a/third_party/WebKit/Source/bindings/modules/v8/SerializedScriptValueForModulesFactory.cpp b/third_party/WebKit/Source/bindings/modules/v8/SerializedScriptValueForModulesFactory.cpp |
| index bafa2c93bb6ca9d27d78816fd336e5b080bb6385..2d1931c537c1624f86a7118300e4de116c58462e 100644 |
| --- a/third_party/WebKit/Source/bindings/modules/v8/SerializedScriptValueForModulesFactory.cpp |
| +++ b/third_party/WebKit/Source/bindings/modules/v8/SerializedScriptValueForModulesFactory.cpp |
| @@ -7,6 +7,7 @@ |
| #include "bindings/core/v8/ExceptionState.h" |
| #include "bindings/core/v8/SerializedScriptValue.h" |
| #include "bindings/modules/v8/ScriptValueSerializerForModules.h" |
| +#include "bindings/modules/v8/TransferableOffscreenCanvas.h" |
| #include "core/dom/ExceptionCode.h" |
| namespace blink { |
| @@ -50,6 +51,33 @@ PassRefPtr<SerializedScriptValue> SerializedScriptValueForModulesFactory::create |
| return createFromWire(wireData); |
| } |
| +void SerializedScriptValueForModulesFactory::transferData(SerializedScriptValue* serializedValue, SerializedScriptValueWriter& writer, Transferables* transferables, ExceptionState& exceptionState, v8::Isolate* isolate) |
| +{ |
| + serializedValue->setData(writer.takeWireString()); |
| + ASSERT(serializedValue->data().impl()->hasOneRef()); |
| + const auto& offscreenCanvases = static_cast<TransferableOffscreenCanvas*>(transferables)->offscreenCanvases; |
| + if (offscreenCanvases.size()) { |
| + for (size_t i = 0; i < offscreenCanvases.size(); i++) { |
| + if (offscreenCanvases[i]->isNeutered()) { |
| + exceptionState.throwDOMException(DataCloneError, "OffscreenCanvas at index " + String::number(i) + " is already neutered."); |
| + return; |
| + } |
| + if (offscreenCanvases[i]->renderingContext()) { |
| + exceptionState.throwDOMException(DataCloneError, "OffscreenCanvas at index " + String::number(i) + " has an associated context."); |
| + return; |
| + } |
| + } |
| + HeapHashSet<Member<OffscreenCanvas>> visited; |
| + for (size_t i = 0; i < offscreenCanvases.size(); i++) { |
|
haraken
2016/04/19 00:48:10
Can we avoid iterating over offscreenCanvases twic
xidachen
2016/04/19 15:29:50
Done.
|
| + if (visited.contains(offscreenCanvases[i].get())) |
| + continue; |
| + visited.add(offscreenCanvases[i].get()); |
| + offscreenCanvases[i].get()->setNeutered(); |
| + } |
| + } |
| + SerializedScriptValueFactory::transferData(serializedValue, writer, transferables, exceptionState, isolate); |
| +} |
| + |
| ScriptValueSerializer::Status SerializedScriptValueForModulesFactory::doSerialize(v8::Local<v8::Value> value, SerializedScriptValueWriter& writer, Transferables* transferables, WebBlobInfoArray* blobInfo, BlobDataHandleMap& blobDataHandles, v8::TryCatch& tryCatch, String& errorMessage, v8::Isolate* isolate) |
| { |
| ScriptValueSerializerForModules serializer(writer, transferables, blobInfo, blobDataHandles, tryCatch, ScriptState::current(isolate)); |