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

Side by Side Diff: content/worker/worker_devtools_agent.cc

Issue 7248076: DevTools: add initial support for shared workers debugging (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Comments addressed Created 9 years, 5 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
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 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 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/worker/worker_devtools_agent.h" 5 #include "content/worker/worker_devtools_agent.h"
6 6
7 #include "content/common/devtools_messages.h" 7 #include "content/common/devtools_messages.h"
8 #include "content/worker/worker_thread.h" 8 #include "content/worker/worker_thread.h"
9 #include "third_party/WebKit/Source/WebKit/chromium/public/WebCString.h" 9 #include "third_party/WebKit/Source/WebKit/chromium/public/WebCString.h"
10 #include "third_party/WebKit/Source/WebKit/chromium/public/WebSharedWorker.h"
10 #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h" 11 #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h"
11 #include "third_party/WebKit/Source/WebKit/chromium/public/WebWorker.h" 12 #include "third_party/WebKit/Source/WebKit/chromium/public/WebWorker.h"
12 13
14 using WebKit::WebSharedWorker;
13 using WebKit::WebString; 15 using WebKit::WebString;
14 using WebKit::WebWorker; 16 using WebKit::WebWorker;
15 17
16 WorkerDevToolsAgent::WorkerDevToolsAgent(int route_id, WebWorker* webworker) 18 namespace {
17 : route_id_(route_id), 19
18 webworker_(webworker) { 20 class DedicatedWorkerDevToolsAgent : public WorkerDevToolsAgent {
21 public:
22 DedicatedWorkerDevToolsAgent(int route_id, WebWorker* webworker)
23 : WorkerDevToolsAgent(route_id),
24 webworker_(webworker) {}
25
26 private:
27 virtual ~DedicatedWorkerDevToolsAgent() {}
28
29 // Called on the Worker thread.
30 virtual bool OnMessageReceived(const IPC::Message& message) {
31 bool handled = true;
32 IPC_BEGIN_MESSAGE_MAP(DedicatedWorkerDevToolsAgent, message)
33 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_Attach, OnAttach)
34 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_Detach, OnDetach)
35 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_DispatchOnInspectorBackend,
36 OnDispatchOnInspectorBackend)
37 IPC_MESSAGE_UNHANDLED(handled = false)
38 IPC_END_MESSAGE_MAP()
39 return handled;
40 }
41
42 virtual void SendDevToolsMessage(const WebKit::WebString& message) {
43 Send(new DevToolsAgentMsg_DispatchMessageFromWorker(route_id_,
44 message.utf8()));
45 }
46
47 void OnAttach() {
48 webworker_->attachDevTools();
49 }
50
51 void OnDetach() {
52 webworker_->detachDevTools();
53 }
54
55 void OnDispatchOnInspectorBackend(
56 const std::string& message) {
57 webworker_->dispatchDevToolsMessage(WebString::fromUTF8(message));
58 }
59
60 WebKit::WebWorker* webworker_;
61
62 DISALLOW_COPY_AND_ASSIGN(DedicatedWorkerDevToolsAgent);
63 };
64
65
66 class SharedWorkerDevToolsAgent : public WorkerDevToolsAgent {
jam 2011/07/08 17:49:09 It's unfortunate that this class is duplicated for
pfeldman 2011/07/11 12:07:16 I think templates won't harm readability of this c
yurys 2011/07/11 15:13:11 WebWorker and WebSharedWorker don't have common an
yurys 2011/07/11 15:13:11 See my response to John.
jam 2011/07/11 16:53:37 You can send DevToolsAgentMsg_DispatchOnInspectorB
yurys 2011/07/12 13:58:46 Done. Converted the class into template and reused
67 public:
68 SharedWorkerDevToolsAgent(int route_id, WebSharedWorker* webshared_worker)
69 : WorkerDevToolsAgent(route_id),
70 webshared_worker_(webshared_worker) { }
71
72 private:
73 // Called on the Worker thread.
74 virtual bool OnMessageReceived(const IPC::Message& message) {
75 bool handled = true;
76 IPC_BEGIN_MESSAGE_MAP(SharedWorkerDevToolsAgent, message)
77 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_Attach, OnAttach)
78 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_Detach, OnDetach)
79 IPC_MESSAGE_HANDLER(DevToolsAgentMsg_DispatchOnInspectorBackend,
80 OnDispatchOnInspectorBackend)
81 IPC_MESSAGE_UNHANDLED(handled = false)
82 IPC_END_MESSAGE_MAP()
83 return handled;
84 }
85
86 virtual void SendDevToolsMessage(const WebString& message) {
87 IPC::Message m = DevToolsClientMsg_DispatchOnInspectorFrontend(
88 message.utf8());
89 m.set_routing_id(route_id_);
90 Send(new DevToolsHostMsg_ForwardToClient(route_id_, m));
91 }
92
93 void OnAttach() {
94 webshared_worker_->attachDevTools();
95 }
96 void OnDetach() {
97 webshared_worker_->detachDevTools();
98 }
99 void OnDispatchOnInspectorBackend(const std::string& message) {
100 webshared_worker_->dispatchDevToolsMessage(WebString::fromUTF8(message));
101 }
102
103 WebSharedWorker* webshared_worker_;
104
105 DISALLOW_COPY_AND_ASSIGN(SharedWorkerDevToolsAgent);
106 };
107
108 } // namespace
109
110 WorkerDevToolsAgent::WorkerDevToolsAgent(int route_id)
111 : route_id_(route_id) {
19 } 112 }
20 113
21 WorkerDevToolsAgent::~WorkerDevToolsAgent() { 114 WorkerDevToolsAgent* WorkerDevToolsAgent::CreateForDedicatedWorker(
115 int route_id,
116 WebKit::WebWorker* webworker) {
117 return new DedicatedWorkerDevToolsAgent(route_id, webworker);
22 } 118 }
23 119
24 // Called on the Worker thread. 120 WorkerDevToolsAgent* WorkerDevToolsAgent::CreateForSharedWorker(
25 bool WorkerDevToolsAgent::OnMessageReceived(const IPC::Message& message) { 121 int route_id, WebKit::WebSharedWorker* webshared_worker) {
26 bool handled = true; 122 return new SharedWorkerDevToolsAgent(route_id, webshared_worker);
27 IPC_BEGIN_MESSAGE_MAP(WorkerDevToolsAgent, message)
28 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_Attach, OnAttach)
29 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_Detach, OnDetach)
30 IPC_MESSAGE_HANDLER(WorkerDevToolsAgentMsg_DispatchOnInspectorBackend,
31 OnDispatchOnInspectorBackend)
32 IPC_MESSAGE_UNHANDLED(handled = false)
33 IPC_END_MESSAGE_MAP()
34 return handled;
35 } 123 }
36 124
37 void WorkerDevToolsAgent::OnAttach() {
38 webworker_->attachDevTools();
39 }
40 125
41 void WorkerDevToolsAgent::OnDetach() { 126 WorkerDevToolsAgent::~WorkerDevToolsAgent() {
42 webworker_->detachDevTools();
43 }
44
45 void WorkerDevToolsAgent::OnDispatchOnInspectorBackend(
46 const std::string& message) {
47 webworker_->dispatchDevToolsMessage(WebString::fromUTF8(message));
48 } 127 }
49 128
50 bool WorkerDevToolsAgent::Send(IPC::Message* message) { 129 bool WorkerDevToolsAgent::Send(IPC::Message* message) {
51 return WorkerThread::current()->Send(message); 130 return WorkerThread::current()->Send(message);
52 } 131 }
53
54 void WorkerDevToolsAgent::SendDevToolsMessage(const WebString& message) {
55 Send(new DevToolsAgentMsg_DispatchMessageFromWorker(route_id_,
56 message.utf8()));
57 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698