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

Side by Side Diff: content/renderer/worker_devtools_agent_proxy.cc

Issue 6990059: DevTools: devtools message plumbing between worker and page processes (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Comments addressed, WebWorkerBase::DevToolsDelegate removed Created 9 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "content/renderer/worker_devtools_agent_proxy.h"
6
7 #include "content/common/devtools_messages.h"
8 #include "content/renderer/webworker_base.h"
9 #include "third_party/WebKit/Source/WebKit/chromium/public/WebCString.h"
10 #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h"
11 #include "third_party/WebKit/Source/WebKit/chromium/public/WebWorkerClient.h"
12
13 using WebKit::WebString;
14 using WebKit::WebWorkerClient;
15
16 WorkerDevToolsAgentProxy::WorkerDevToolsAgentProxy(WebWorkerBase* webworker,
17 int route_id,
18 WebWorkerClient* client)
19 : route_id_(route_id),
20 webworker_(webworker),
21 webworker_client_(client) {
22 }
23
24 WorkerDevToolsAgentProxy::~WorkerDevToolsAgentProxy() {
25 }
26
27 void WorkerDevToolsAgentProxy::WorkerProxyDestroyed() {
28 delete this;
29 }
30
31 void WorkerDevToolsAgentProxy::SetRouteId(int route_id) {
32 route_id_ = route_id;
33 }
34
35 // Called on the Renderer thread.
36 bool WorkerDevToolsAgentProxy::OnMessageReceived(const IPC::Message& message) {
37 bool handled = true;
38 IPC_BEGIN_MESSAGE_MAP(WorkerDevToolsAgentProxy, message)
39 IPC_MESSAGE_HANDLER(DevToolsAgentMsg_DispatchMessageFromWorker,
40 OnDispatchMessageFromWorker)
41 IPC_MESSAGE_UNHANDLED(handled = false)
42 IPC_END_MESSAGE_MAP()
43 return handled;
44 }
45
46 void WorkerDevToolsAgentProxy::AttachDevTools() {
47 Send(new WorkerDevToolsAgentMsg_Attach(route_id_));
48 }
49
50 void WorkerDevToolsAgentProxy::DetachDevTools() {
51 Send(new WorkerDevToolsAgentMsg_Detach(route_id_));
52 }
53
54 void WorkerDevToolsAgentProxy::SendDevToolsMessage(
55 const std::string& message) {
56 Send(new WorkerDevToolsAgentMsg_DispatchOnInspectorBackend(route_id_,
57 message));
58 }
59
60 void WorkerDevToolsAgentProxy::OnDispatchMessageFromWorker(
61 const std::string& message) {
62 webworker_client_->dispatchDevToolsMessage(WebString::fromUTF8(message));
63 }
64
65 void WorkerDevToolsAgentProxy::Send(IPC::Message* message) {
66 webworker_->Send(message);
67 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698