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

Side by Side Diff: Source/modules/serviceworkers/StashedMessagePort.cpp

Issue 1008533005: Initial implementation of stashed message ports, blink side (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 5 years, 7 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
OLDNEW
(Empty)
1 // Copyright 2015 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 "modules/serviceworkers/StashedMessagePort.h"
7
8 #include "bindings/core/v8/SerializedScriptValue.h"
9 #include "core/dom/CrossThreadTask.h"
10 #include "core/events/MessageEvent.h"
11 #include "modules/serviceworkers/ServiceWorkerGlobalScope.h"
12 #include "modules/serviceworkers/StashedPortCollection.h"
13 #include "public/platform/WebTraceLocation.h"
14
15 namespace blink {
16
17 PassRefPtrWillBeRawPtr<StashedMessagePort> StashedMessagePort::create(ExecutionC ontext& executionContext, PassOwnPtr<WebMessagePortChannel> remote, const String & name)
18 {
19 RefPtrWillBeRawPtr<StashedMessagePort> port = adoptRefWillBeNoop(new Stashed MessagePort(executionContext, remote, name));
20 port->suspendIfNeeded();
21 return port.release();
22 }
23
24 StashedMessagePort::StashedMessagePort(ExecutionContext& executionContext, PassO wnPtr<WebMessagePortChannel> remote, const String& name)
scheib 2015/05/06 21:44:30 definitions in the corresponding .cc file should b
Marijn Kruisselbrink 2015/05/12 06:56:40 yes, while that's true it's pretty common in at le
25 : MessagePort(executionContext), m_weakFactory(this), m_name(name)
26 {
27 entangle(remote);
28 start();
29 }
30
31 StashedMessagePort::~StashedMessagePort()
32 {
33 }
34
35 PassOwnPtrWillBeRawPtr<StashedMessagePortArray> StashedMessagePort::toStashedMes sagePortArray(ExecutionContext* context, const WebMessagePortChannelArray& webCh annels, const WebVector<WebString>& channelKeys)
36 {
37 OwnPtrWillBeRawPtr<StashedMessagePortArray> ports = adoptPtrWillBeNoop(new S tashedMessagePortArray(webChannels.size()));
38 for (size_t i = 0; i < webChannels.size(); ++i) {
39 OwnPtr<WebMessagePortChannel> channel(adoptPtr(webChannels[i]));
40 (*ports)[i] = StashedMessagePort::create(*context, channel.release(), ch annelKeys[i]);
41 }
42 return ports.release();
43 }
44
45 String StashedMessagePort::name() const
46 {
47 return m_name;
48 }
49
50 DEFINE_TRACE(StashedMessagePort)
scheib 2015/05/06 21:44:30 Maybe use DEFINE_TRACE_INLINE for this in .h?
Marijn Kruisselbrink 2015/05/12 06:56:40 Done.
51 {
52 MessagePort::trace(visitor);
53 }
54
55 void StashedMessagePort::messageAvailable()
56 {
57 ASSERT(executionContext());
58 executionContext()->postTask(FROM_HERE, createCrossThreadTask(&StashedMessag ePort::dispatchMessages, m_weakFactory.createWeakPtr()));
59 }
60
61 void StashedMessagePort::dispatchMessages()
scheib 2015/05/06 21:44:30 There's no need to check the closed, started state
Marijn Kruisselbrink 2015/05/12 06:56:40 !isEntangled() implies !closed(), and for now I'm
62 {
63 if (!isEntangled())
64 return;
65 ASSERT(executionContext()->isServiceWorkerGlobalScope());
66 RefPtr<StashedPortCollection> stashedPorts = toServiceWorkerGlobalScope(exec utionContext())->ports();
67
68 RefPtr<SerializedScriptValue> message;
69 OwnPtr<MessagePortChannelArray> channels;
70 while (tryGetMessage(message, channels)) {
71 OwnPtrWillBeRawPtr<MessagePortArray> ports = MessagePort::entanglePorts( *executionContext(), channels.release());
72 RefPtrWillBeRawPtr<Event> evt = MessageEvent::create(ports.release(), me ssage.release(), String(), String(), this);
73
74 stashedPorts->dispatchEvent(evt.release(), ASSERT_NO_EXCEPTION);
75 }
76 }
77
78 } // namespace blink
79
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698