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

Unified Diff: chrome/worker/worker_thread.cc

Issue 6691004: Move worker code from chrome\worker to content\worker. (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/worker/worker_thread.h ('k') | chrome/worker/worker_uitest.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/worker/worker_thread.cc
===================================================================
--- chrome/worker/worker_thread.cc (revision 78005)
+++ chrome/worker/worker_thread.cc (working copy)
@@ -1,127 +0,0 @@
-// 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/worker/worker_thread.h"
-
-#include "base/command_line.h"
-#include "base/lazy_instance.h"
-#include "base/threading/thread_local.h"
-#include "chrome/worker/webworker_stub.h"
-#include "chrome/worker/websharedworker_stub.h"
-#include "chrome/worker/worker_webkitclient_impl.h"
-#include "content/common/appcache/appcache_dispatcher.h"
-#include "content/common/content_switches.h"
-#include "content/common/db_message_filter.h"
-#include "content/common/web_database_observer_impl.h"
-#include "content/common/worker_messages.h"
-#include "ipc/ipc_sync_channel.h"
-#include "third_party/WebKit/Source/WebKit/chromium/public/WebBlobRegistry.h"
-#include "third_party/WebKit/Source/WebKit/chromium/public/WebDatabase.h"
-#include "third_party/WebKit/Source/WebKit/chromium/public/WebKit.h"
-#include "third_party/WebKit/Source/WebKit/chromium/public/WebRuntimeFeatures.h"
-#include "webkit/glue/webkit_glue.h"
-
-using WebKit::WebRuntimeFeatures;
-
-static base::LazyInstance<base::ThreadLocalPointer<WorkerThread> > lazy_tls(
- base::LINKER_INITIALIZED);
-
-
-WorkerThread::WorkerThread() {
- lazy_tls.Pointer()->Set(this);
- webkit_client_.reset(new WorkerWebKitClientImpl);
- WebKit::initialize(webkit_client_.get());
-
- appcache_dispatcher_.reset(new AppCacheDispatcher(this));
-
- web_database_observer_impl_.reset(new WebDatabaseObserverImpl(this));
- WebKit::WebDatabase::setObserver(web_database_observer_impl_.get());
- db_message_filter_ = new DBMessageFilter();
- channel()->AddFilter(db_message_filter_.get());
-
- const CommandLine& command_line = *CommandLine::ForCurrentProcess();
-
- webkit_glue::EnableWebCoreLogChannels(
- command_line.GetSwitchValueASCII(switches::kWebCoreLogChannels));
-
- WebKit::WebRuntimeFeatures::enableDatabase(
- !command_line.HasSwitch(switches::kDisableDatabases));
-
- WebKit::WebRuntimeFeatures::enableApplicationCache(
- !command_line.HasSwitch(switches::kDisableApplicationCache));
-
-#if defined(OS_WIN)
- // We don't yet support notifications on non-Windows, so hide it from pages.
- WebRuntimeFeatures::enableNotifications(
- !command_line.HasSwitch(switches::kDisableDesktopNotifications));
-#endif
-
- WebRuntimeFeatures::enableSockets(
- !command_line.HasSwitch(switches::kDisableWebSockets));
-
- WebRuntimeFeatures::enableFileSystem(
- !command_line.HasSwitch(switches::kDisableFileSystem));
-
- WebRuntimeFeatures::enableWebGL(
- !command_line.HasSwitch(switches::kDisable3DAPIs) &&
- !command_line.HasSwitch(switches::kDisableExperimentalWebGL));
-}
-
-WorkerThread::~WorkerThread() {
- // Shutdown in reverse of the initialization order.
- channel()->RemoveFilter(db_message_filter_.get());
- db_message_filter_ = NULL;
-
- WebKit::shutdown();
- lazy_tls.Pointer()->Set(NULL);
-}
-
-WorkerThread* WorkerThread::current() {
- return lazy_tls.Pointer()->Get();
-}
-
-bool WorkerThread::OnControlMessageReceived(const IPC::Message& msg) {
- // Appcache messages are handled by a delegate.
- if (appcache_dispatcher_->OnMessageReceived(msg))
- return true;
-
- bool handled = true;
- IPC_BEGIN_MESSAGE_MAP(WorkerThread, msg)
- IPC_MESSAGE_HANDLER(WorkerProcessMsg_CreateWorker, OnCreateWorker)
- IPC_MESSAGE_UNHANDLED(handled = false)
- IPC_END_MESSAGE_MAP()
- return handled;
-}
-
-void WorkerThread::OnCreateWorker(
- const WorkerProcessMsg_CreateWorker_Params& params) {
- WorkerAppCacheInitInfo appcache_init_info(
- params.is_shared, params.creator_process_id,
- params.creator_appcache_host_id,
- params.shared_worker_appcache_id);
-
- // WebWorkerStub and WebSharedWorkerStub own themselves.
- if (params.is_shared)
- new WebSharedWorkerStub(params.name, params.route_id, appcache_init_info);
- else
- new WebWorkerStub(params.url, params.route_id, appcache_init_info);
-}
-
-// The browser process is likely dead. Terminate all workers.
-void WorkerThread::OnChannelError() {
- set_on_channel_error_called(true);
-
- for (WorkerStubsList::iterator it = worker_stubs_.begin();
- it != worker_stubs_.end(); ++it) {
- (*it)->OnChannelError();
- }
-}
-
-void WorkerThread::RemoveWorkerStub(WebWorkerStubBase* stub) {
- worker_stubs_.erase(stub);
-}
-
-void WorkerThread::AddWorkerStub(WebWorkerStubBase* stub) {
- worker_stubs_.insert(stub);
-}
« no previous file with comments | « chrome/worker/worker_thread.h ('k') | chrome/worker/worker_uitest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698