Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(278)

Side by Side Diff: Source/bindings/v8/custom/V8ServiceWorkerCustom.cpp

Issue 185643009: Implement ServiceWorker::postMessage() [Blink] (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Add layout test Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "config.h"
6 #include "V8ServiceWorker.h"
7
8 #include "bindings/v8/ExceptionMessages.h"
9 #include "bindings/v8/ExceptionState.h"
10 #include "bindings/v8/SerializedScriptValue.h"
11 #include "bindings/v8/V8Binding.h"
12 #include "core/dom/MessagePort.h"
13 #include "modules/serviceworkers/ServiceWorker.h"
14 #include "wtf/ArrayBuffer.h"
15
16 namespace WebCore {
17
18 void V8ServiceWorker::postMessageMethodCustom(const v8::FunctionCallbackInfo<v8: :Value>& info)
19 {
20 ExceptionState exceptionState(ExceptionState::ExecutionContext, "postMessage ", "ServiceWorker", info.Holder(), info.GetIsolate());
21 ServiceWorker* worker = V8ServiceWorker::toNative(info.Holder());
22 MessagePortArray ports;
23 ArrayBufferArray arrayBuffers;
24 if (info.Length() > 1) {
25 const int transferablesArgIndex = 1;
26 if (!SerializedScriptValue::extractTransferables(info[transferablesArgIn dex], transferablesArgIndex, ports, arrayBuffers, exceptionState, info.GetIsolat e())) {
27 exceptionState.throwIfNeeded();
28 return;
29 }
30 }
31 RefPtr<SerializedScriptValue> message = SerializedScriptValue::create(info[0 ], &ports, &arrayBuffers, exceptionState, info.GetIsolate());
32 if (exceptionState.throwIfNeeded())
33 return;
34 worker->postMessage(message.release(), &ports, exceptionState);
35 exceptionState.throwIfNeeded();
kinuko 2014/03/11 07:13:36 (It's a bit sad that we seem to have mostly same c
jsbell 2014/03/11 15:56:41 Yep. I'll move the common code into V8Binding.cpp
jsbell 2014/03/11 20:10:51 I gave this a shot, but it ended up not saving man
36 }
37
38 } // namespace WebCore
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698