diff options
author | jam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-04 00:39:56 +0000 |
---|---|---|
committer | jam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-03-04 00:39:56 +0000 |
commit | eb47a137b7ce84a6df0ccc9550c75b6bec60eb68 (patch) | |
tree | 7f6c4e1d169bf60465a0b642a4434a239aaf0f6d /chrome/common/child_process_host.cc | |
parent | 0ff03ae3f1bf6f877a4aa32263f6418f2c5797d2 (diff) | |
download | chromium_src-eb47a137b7ce84a6df0ccc9550c75b6bec60eb68.zip chromium_src-eb47a137b7ce84a6df0ccc9550c75b6bec60eb68.tar.gz chromium_src-eb47a137b7ce84a6df0ccc9550c75b6bec60eb68.tar.bz2 |
Initial checkin of the out of process worker implementation.
WebWorkerClient/WebWorker are parallel interfaces of WebCore::{WorkerObjectProxy, WorkerContextProxy} that use Chrome data types. When WebKit requests a WorkerObjectProxy, we create an instance of WebWorkerClientImpl. This class creates an object that implements a Chromium version of WorkerObjectProxy (i.e. with Chrome data types) through WebViewDelegate. That object is a WebWorkerProxy and talks over IPC to a WebWorker object in the worker process. The WebWorker object creates the actual WebCore::Worker object using another class in glue: WebWorkerImpl.
When the WebCore::Worker object running in the worker process wants to talk back to the code running in the renderer, it talks to WebWorkerImpl which implements WebCore::WorkerObjectProxy. WebWorkerImpl converts the data types to Chrome compatible ones, and then calls the WebWorkerClient version which does IPC to get to the renderer process. This ends up at WebWorkerProxy, which calls WebWorkerClientImpl (the original class).
In future changes, sandboxing, multiple worker processes etc will be added. Note that I also had to make two small changes to WebKit, since WorkerMessagingProxy couldn't be created as is for the nested worker case. I'll either check it in myself or work with Jian to do so.
Review URL: http://codereview.chromium.org/27157
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@10847 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/common/child_process_host.cc')
-rw-r--r-- | chrome/common/child_process_host.cc | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/chrome/common/child_process_host.cc b/chrome/common/child_process_host.cc index 66d3ebf..15d8daa 100644 --- a/chrome/common/child_process_host.cc +++ b/chrome/common/child_process_host.cc @@ -154,18 +154,20 @@ void ChildProcessHost::ListenerHook::OnChannelError() { ChildProcessHost::Iterator::Iterator() : all_(true) { - iterator_ = Singleton<ChildProcessList>::get()->begin(); DCHECK(MessageLoop::current() == ChromeThread::GetMessageLoop(ChromeThread::IO)) << "ChildProcessInfo::Iterator must be used on the IO thread."; + iterator_ = Singleton<ChildProcessList>::get()->begin(); } ChildProcessHost::Iterator::Iterator(ProcessType type) : all_(false), type_(type) { - iterator_ = Singleton<ChildProcessList>::get()->begin(); DCHECK(MessageLoop::current() == ChromeThread::GetMessageLoop(ChromeThread::IO)) << "ChildProcessInfo::Iterator must be used on the IO thread."; + iterator_ = Singleton<ChildProcessList>::get()->begin(); + if (!Done() && (*iterator_)->type() != type_) + iterator_++; } ChildProcessInfo* ChildProcessHost::Iterator::operator++() { |