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

Unified Diff: chrome/renderer/websharedworker_impl.cc

Issue 340036: Initial pass of shared workers renderer-side code (Closed)
Patch Set: Changes reflecting review feedback Created 11 years, 2 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 side-by-side diff with in-line comments
Download patch
Index: chrome/renderer/websharedworker_impl.cc
diff --git a/chrome/renderer/websharedworker_impl.cc b/chrome/renderer/websharedworker_impl.cc
new file mode 100644
index 0000000000000000000000000000000000000000..f5e20cecc87a3670efbdd7cbb9a4d4e3e0a5d167
--- /dev/null
+++ b/chrome/renderer/websharedworker_impl.cc
@@ -0,0 +1,58 @@
+// Copyright (c) 2009 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/renderer/websharedworker_impl.h"
+
+#include "chrome/common/render_messages.h"
+#include "chrome/common/webmessageportchannel_impl.h"
+#include "chrome/common/worker_messages.h"
+#include "webkit/api/public/WebURL.h"
+
+WebSharedWorkerImpl::WebSharedWorkerImpl(const GURL& url,
+ const string16& name,
+ ChildThread* child_thread,
+ int route_id,
+ int render_view_route_id)
+ : WebWorkerBase(child_thread, route_id, render_view_route_id),
+ url_(url),
+ name_(name) {
+}
+
+bool WebSharedWorkerImpl::isStarted() {
+ return IsStarted();
+}
+
+void WebSharedWorkerImpl::startWorkerContext(
+ const WebKit::WebURL& script_url,
+ const WebKit::WebString& user_agent,
+ const WebKit::WebString& source_code) {
+ DCHECK(url_ == script_url);
+ IPC::Message* create_message = new ViewHostMsg_CreateSharedWorker(
+ url_, name_, render_view_route_id_, &route_id_);
+ CreateWorkerContext(create_message, script_url, user_agent, source_code);
+}
+
+void WebSharedWorkerImpl::connect(WebKit::WebMessagePortChannel* channel) {
+ WebMessagePortChannelImpl* webchannel =
+ static_cast<WebMessagePortChannelImpl*>(channel);
+
+ int message_port_id = webchannel->message_port_id();
+ DCHECK(message_port_id != MSG_ROUTING_NONE);
+ webchannel->QueueMessages();
+
+ Send(new WorkerMsg_Connect(route_id_, message_port_id, MSG_ROUTING_NONE));
+}
+
+void WebSharedWorkerImpl::OnMessageReceived(const IPC::Message& message) {
+ IPC_BEGIN_MESSAGE_MAP(WebSharedWorkerImpl, message)
+ IPC_MESSAGE_HANDLER(ViewMsg_WorkerCreated, OnWorkerCreated)
+ IPC_END_MESSAGE_MAP()
+}
+
+void WebSharedWorkerImpl::OnWorkerCreated() {
+ // The worker is created - now send off the CreateWorkerContext message and
+ // any other queued messages
+ SendQueuedMessages();
+}
+

Powered by Google App Engine
This is Rietveld 408576698