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

Side by Side Diff: chrome/renderer/websharedworker_proxy.cc

Issue 372047: Fixed worker startup issue (Closed)
Patch Set: Removed tests to a separate patch. Created 11 years, 1 month 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
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/renderer/websharedworker_proxy.h" 5 #include "chrome/renderer/websharedworker_proxy.h"
6 6
7 #include "chrome/common/render_messages.h" 7 #include "chrome/common/render_messages.h"
8 #include "chrome/common/webmessageportchannel_impl.h" 8 #include "chrome/common/webmessageportchannel_impl.h"
9 #include "chrome/common/worker_messages.h" 9 #include "chrome/common/worker_messages.h"
10 #include "webkit/api/public/WebURL.h" 10 #include "webkit/api/public/WebURL.h"
11 11
12 WebSharedWorkerProxy::WebSharedWorkerProxy(ChildThread* child_thread, 12 WebSharedWorkerProxy::WebSharedWorkerProxy(ChildThread* child_thread,
13 int route_id, 13 int route_id,
14 int render_view_route_id) 14 int render_view_route_id)
15 : WebWorkerBase(child_thread, route_id, render_view_route_id) { 15 : WebWorkerBase(child_thread, route_id, render_view_route_id),
16 m_connectListener(NULL) {
16 } 17 }
17 18
18 bool WebSharedWorkerProxy::isStarted() { 19 bool WebSharedWorkerProxy::isStarted() {
19 return IsStarted(); 20 return IsStarted();
20 } 21 }
21 22
22 void WebSharedWorkerProxy::startWorkerContext( 23 void WebSharedWorkerProxy::startWorkerContext(
23 const WebKit::WebURL& script_url, 24 const WebKit::WebURL& script_url,
24 const WebKit::WebString& name, 25 const WebKit::WebString& name,
25 const WebKit::WebString& user_agent, 26 const WebKit::WebString& user_agent,
26 const WebKit::WebString& source_code) { 27 const WebKit::WebString& source_code) {
27 CreateWorkerContext(script_url, true, name, user_agent, source_code); 28 CreateWorkerContext(script_url, true, name, user_agent, source_code);
28 } 29 }
29 30
30 void WebSharedWorkerProxy::terminateWorkerContext() { 31 void WebSharedWorkerProxy::terminateWorkerContext() {
31 // This API should only be invoked from worker context. 32 // This API should only be invoked from worker context.
32 NOTREACHED(); 33 NOTREACHED();
33 } 34 }
34 35
35 void WebSharedWorkerProxy::clientDestroyed() { 36 void WebSharedWorkerProxy::clientDestroyed() {
36 // This API should only be invoked from worker context. 37 // This API should only be invoked from worker context.
37 NOTREACHED(); 38 NOTREACHED();
38 } 39 }
39 40
40 void WebSharedWorkerProxy::connect(WebKit::WebMessagePortChannel* channel) { 41 void WebSharedWorkerProxy::connect(WebKit::WebMessagePortChannel* channel,
42 ConnectListener* listener) {
41 WebMessagePortChannelImpl* webchannel = 43 WebMessagePortChannelImpl* webchannel =
42 static_cast<WebMessagePortChannelImpl*>(channel); 44 static_cast<WebMessagePortChannelImpl*>(channel);
43 45
44 int message_port_id = webchannel->message_port_id(); 46 int message_port_id = webchannel->message_port_id();
45 DCHECK(message_port_id != MSG_ROUTING_NONE); 47 DCHECK(message_port_id != MSG_ROUTING_NONE);
46 webchannel->QueueMessages(); 48 webchannel->QueueMessages();
47 49
48 Send(new WorkerMsg_Connect(route_id_, message_port_id, MSG_ROUTING_NONE)); 50 Send(new WorkerMsg_Connect(route_id_, message_port_id, MSG_ROUTING_NONE));
51 if (HasQueuedMessages()) {
52 m_connectListener = listener;
53 } else {
54 // The listener may free this object, so do not access the object after
55 // this point.
56 listener->connected();
57 }
49 } 58 }
50 59
51 void WebSharedWorkerProxy::OnMessageReceived(const IPC::Message& message) { 60 void WebSharedWorkerProxy::OnMessageReceived(const IPC::Message& message) {
52 IPC_BEGIN_MESSAGE_MAP(WebSharedWorkerProxy, message) 61 IPC_BEGIN_MESSAGE_MAP(WebSharedWorkerProxy, message)
53 IPC_MESSAGE_HANDLER(ViewMsg_WorkerCreated, OnWorkerCreated) 62 IPC_MESSAGE_HANDLER(ViewMsg_WorkerCreated, OnWorkerCreated)
54 IPC_END_MESSAGE_MAP() 63 IPC_END_MESSAGE_MAP()
55 } 64 }
56 65
57 void WebSharedWorkerProxy::OnWorkerCreated() { 66 void WebSharedWorkerProxy::OnWorkerCreated() {
58 // The worker is created - now send off the CreateWorkerContext message and 67 // The worker is created - now send off the CreateWorkerContext message and
59 // any other queued messages 68 // any other queued messages
60 SendQueuedMessages(); 69 SendQueuedMessages();
70
71 // Inform any listener that the pending connect event has been sent
72 // (this can result in this object being freed).
73 if (m_connectListener) {
74 m_connectListener->connected();
jam 2009/11/09 02:53:03 nit: chrome style is not to use brace brackets for
75 }
61 } 76 }
62 77
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698