diff options
author | atwilson@chromium.org <atwilson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-05 08:04:18 +0000 |
---|---|---|
committer | atwilson@chromium.org <atwilson@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-11-05 08:04:18 +0000 |
commit | f94ead7d53296e14f1254ad1cdd4b73f3d6b9130 (patch) | |
tree | 9a69ebed813f36d6f410f5a99193c40edd6aac07 /chrome/worker/webworkerclient_proxy.cc | |
parent | e796881505363ef53a4082bb0450cd169f1d8d44 (diff) | |
download | chromium_src-f94ead7d53296e14f1254ad1cdd4b73f3d6b9130.zip chromium_src-f94ead7d53296e14f1254ad1cdd4b73f3d6b9130.tar.gz chromium_src-f94ead7d53296e14f1254ad1cdd4b73f3d6b9130.tar.bz2 |
Revert "Added beginnings of browser-process support for shared workers."
This reverts commit 31077.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@31080 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/worker/webworkerclient_proxy.cc')
-rw-r--r-- | chrome/worker/webworkerclient_proxy.cc | 76 |
1 files changed, 67 insertions, 9 deletions
diff --git a/chrome/worker/webworkerclient_proxy.cc b/chrome/worker/webworkerclient_proxy.cc index baff23c..9fe0870 100644 --- a/chrome/worker/webworkerclient_proxy.cc +++ b/chrome/worker/webworkerclient_proxy.cc @@ -5,12 +5,13 @@ #include "chrome/worker/webworkerclient_proxy.h" #include "base/command_line.h" +#include "chrome/common/child_process.h" #include "chrome/common/chrome_switches.h" #include "chrome/common/webmessageportchannel_impl.h" #include "chrome/common/worker_messages.h" #include "chrome/renderer/webworker_proxy.h" -#include "chrome/worker/webworker_stub_base.h" #include "chrome/worker/worker_thread.h" +#include "chrome/worker/nativewebworker_impl.h" #include "ipc/ipc_logging.h" #include "webkit/api/public/WebString.h" #include "webkit/api/public/WebURL.h" @@ -25,14 +26,43 @@ using WebKit::WebWorkerClient; // How long to wait for worker to finish after it's been told to terminate. #define kMaxTimeForRunawayWorkerMs 3000 -WebWorkerClientProxy::WebWorkerClientProxy(int route_id, - WebWorkerStubBase* stub) - : route_id_(route_id), - stub_(stub), +static bool UrlIsNativeWorker(const GURL& url) { + // If the renderer was not passed the switch to enable native workers, + // then the URL should be treated as a JavaScript worker. + if (!CommandLine::ForCurrentProcess()->HasSwitch( + switches::kEnableNativeWebWorkers)) { + return false; + } + // Based on the suffix, decide whether the url should be considered + // a NativeWebWorker (for .nexe) or a WebWorker (for anything else). + const std::string kNativeSuffix(".nexe"); + std::string worker_url = url.path(); + // Compute the start index of the suffix. + std::string::size_type suffix_index = + worker_url.length() - kNativeSuffix.length(); + std::string::size_type pos = worker_url.find(kNativeSuffix, suffix_index); + return (suffix_index == pos); +} + +WebWorkerClientProxy::WebWorkerClientProxy(const GURL& url, int route_id) + : url_(url), + route_id_(route_id), ALLOW_THIS_IN_INITIALIZER_LIST(kill_process_factory_(this)) { + if (UrlIsNativeWorker(url)) { + // Launch a native worker. + impl_ = NativeWebWorkerImpl::create(this); + } else { + // Launch a JavaScript worker. + impl_ = WebWorker::create(this); + } + WorkerThread::current()->AddRoute(route_id_, this); + ChildProcess::current()->AddRefProcess(); } WebWorkerClientProxy::~WebWorkerClientProxy() { + impl_->clientDestroyed(); + WorkerThread::current()->RemoveRoute(route_id_); + ChildProcess::current()->ReleaseProcess(); } void WebWorkerClientProxy::postMessageToWorkerObject( @@ -93,9 +123,8 @@ void WebWorkerClientProxy::reportPendingActivity(bool has_pending_activity) { void WebWorkerClientProxy::workerContextDestroyed() { Send(new WorkerHostMsg_WorkerContextDestroyed(route_id_)); - // Tell the stub that the worker has shutdown - frees this object. - if (stub_) - stub_->Shutdown(); + + delete this; } WebKit::WebWorker* WebWorkerClientProxy::createWorker( @@ -107,7 +136,24 @@ bool WebWorkerClientProxy::Send(IPC::Message* message) { return WorkerThread::current()->Send(message); } -void WebWorkerClientProxy::EnsureWorkerContextTerminates() { +void WebWorkerClientProxy::OnMessageReceived(const IPC::Message& message) { + if (!impl_) + return; + + IPC_BEGIN_MESSAGE_MAP(WebWorkerClientProxy, message) + IPC_MESSAGE_FORWARD(WorkerMsg_StartWorkerContext, impl_, + WebWorker::startWorkerContext) + IPC_MESSAGE_HANDLER(WorkerMsg_TerminateWorkerContext, + OnTerminateWorkerContext) + IPC_MESSAGE_HANDLER(WorkerMsg_PostMessage, OnPostMessage) + IPC_MESSAGE_FORWARD(WorkerMsg_WorkerObjectDestroyed, impl_, + WebWorker::workerObjectDestroyed) + IPC_END_MESSAGE_MAP() +} + +void WebWorkerClientProxy::OnTerminateWorkerContext() { + impl_->terminateWorkerContext(); + // Avoid a worker doing a while(1) from never exiting. if (CommandLine::ForCurrentProcess()->HasSwitch( switches::kWebWorkerShareProcesses)) { @@ -126,3 +172,15 @@ void WebWorkerClientProxy::EnsureWorkerContextTerminates() { kMaxTimeForRunawayWorkerMs); } +void WebWorkerClientProxy::OnPostMessage( + const string16& message, + const std::vector<int>& sent_message_port_ids, + const std::vector<int>& new_routing_ids) { + WebMessagePortChannelArray channels(sent_message_port_ids.size()); + for (size_t i = 0; i < sent_message_port_ids.size(); i++) { + channels[i] = new WebMessagePortChannelImpl( + new_routing_ids[i], sent_message_port_ids[i]); + } + + impl_->postMessageToWorkerContext(message, channels); +} |