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

Side by Side Diff: chrome/browser/devtools/devtools_ui_bindings.h

Issue 427143003: [DevTools] Move DevToolsClientHost functionality out of DevToolsFrontendHost. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 4 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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 #ifndef CHROME_BROWSER_DEVTOOLS_DEVTOOLS_UI_BINDINGS_H_ 5 #ifndef CHROME_BROWSER_DEVTOOLS_DEVTOOLS_UI_BINDINGS_H_
6 #define CHROME_BROWSER_DEVTOOLS_DEVTOOLS_UI_BINDINGS_H_ 6 #define CHROME_BROWSER_DEVTOOLS_DEVTOOLS_UI_BINDINGS_H_
7 7
8 #include <string> 8 #include <string>
9 #include <vector> 9 #include <vector>
10 10
11 #include "base/basictypes.h" 11 #include "base/basictypes.h"
12 #include "base/memory/scoped_ptr.h" 12 #include "base/memory/scoped_ptr.h"
13 #include "base/memory/weak_ptr.h" 13 #include "base/memory/weak_ptr.h"
14 #include "base/strings/string16.h" 14 #include "base/strings/string16.h"
15 #include "chrome/browser/devtools/device/devtools_android_bridge.h" 15 #include "chrome/browser/devtools/device/devtools_android_bridge.h"
16 #include "chrome/browser/devtools/devtools_embedder_message_dispatcher.h" 16 #include "chrome/browser/devtools/devtools_embedder_message_dispatcher.h"
17 #include "chrome/browser/devtools/devtools_file_helper.h" 17 #include "chrome/browser/devtools/devtools_file_helper.h"
18 #include "chrome/browser/devtools/devtools_file_system_indexer.h" 18 #include "chrome/browser/devtools/devtools_file_system_indexer.h"
19 #include "chrome/browser/devtools/devtools_targets_ui.h" 19 #include "chrome/browser/devtools/devtools_targets_ui.h"
20 #include "content/public/browser/devtools_client_host.h" 20 #include "content/public/browser/devtools_client_host.h"
21 #include "content/public/browser/devtools_frontend_host_delegate.h" 21 #include "content/public/browser/devtools_frontend_host.h"
22 #include "content/public/browser/notification_observer.h" 22 #include "content/public/browser/notification_observer.h"
23 #include "content/public/browser/notification_registrar.h" 23 #include "content/public/browser/notification_registrar.h"
24 #include "ui/gfx/size.h" 24 #include "ui/gfx/size.h"
25 25
26 class InfoBarService; 26 class InfoBarService;
27 class Profile; 27 class Profile;
28 28
29 namespace content { 29 namespace content {
30 class DevToolsClientHost; 30 class DevToolsClientHost;
31 struct FileChooserParams; 31 struct FileChooserParams;
32 class WebContents; 32 class WebContents;
33 } 33 }
34 34
35 // Base implementation of DevTools bindings around front-end. 35 // Base implementation of DevTools bindings around front-end.
36 class DevToolsUIBindings : public content::NotificationObserver, 36 class DevToolsUIBindings : public content::NotificationObserver,
37 public content::DevToolsFrontendHostDelegate, 37 public content::DevToolsFrontendHost::Delegate,
38 public DevToolsEmbedderMessageDispatcher::Delegate, 38 public DevToolsEmbedderMessageDispatcher::Delegate,
39 public DevToolsAndroidBridge::DeviceCountListener { 39 public DevToolsAndroidBridge::DeviceCountListener,
40 public content::DevToolsClientHost {
40 public: 41 public:
41 static GURL ApplyThemeToURL(Profile* profile, const GURL& base_url); 42 static GURL ApplyThemeToURL(Profile* profile, const GURL& base_url);
42 43
43 class Delegate { 44 class Delegate {
44 public: 45 public:
45 virtual ~Delegate() {} 46 virtual ~Delegate() {}
46 virtual void ActivateWindow() = 0; 47 virtual void ActivateWindow() = 0;
47 virtual void CloseWindow() = 0; 48 virtual void CloseWindow() = 0;
48 virtual void SetInspectedPageBounds(const gfx::Rect& rect) = 0; 49 virtual void SetInspectedPageBounds(const gfx::Rect& rect) = 0;
49 virtual void SetContentsResizingStrategy( 50 virtual void SetContentsResizingStrategy(
50 const gfx::Insets& insets, const gfx::Size& min_size) = 0; 51 const gfx::Insets& insets, const gfx::Size& min_size) = 0;
51 virtual void InspectElementCompleted() = 0; 52 virtual void InspectElementCompleted() = 0;
52 virtual void MoveWindow(int x, int y) = 0; 53 virtual void MoveWindow(int x, int y) = 0;
53 virtual void SetIsDocked(bool is_docked) = 0; 54 virtual void SetIsDocked(bool is_docked) = 0;
54 virtual void OpenInNewTab(const std::string& url) = 0; 55 virtual void OpenInNewTab(const std::string& url) = 0;
55 virtual void SetWhitelistedShortcuts(const std::string& message) = 0; 56 virtual void SetWhitelistedShortcuts(const std::string& message) = 0;
56 57
57 virtual void InspectedContentsClosing() = 0; 58 virtual void InspectedContentsClosing() = 0;
58 virtual void OnLoadCompleted() = 0; 59 virtual void OnLoadCompleted() = 0;
59 virtual InfoBarService* GetInfoBarService() = 0; 60 virtual InfoBarService* GetInfoBarService() = 0;
60 virtual void RenderProcessGone() = 0; 61 virtual void RenderProcessGone() = 0;
61 }; 62 };
62 63
63 DevToolsUIBindings(content::WebContents* web_contents, const GURL& url); 64 DevToolsUIBindings(content::WebContents* web_contents, const GURL& url);
64 virtual ~DevToolsUIBindings(); 65 virtual ~DevToolsUIBindings();
65 66
66 content::WebContents* web_contents() { return web_contents_; } 67 content::WebContents* web_contents() { return web_contents_; }
67 Profile* profile() { return profile_; } 68 Profile* profile() { return profile_; }
68 content::DevToolsClientHost* frontend_host() { return frontend_host_.get(); }
69 69
70 // Takes ownership over the |delegate|. 70 // Takes ownership over the |delegate|.
71 void SetDelegate(Delegate* delegate); 71 void SetDelegate(Delegate* delegate);
72 void CallClientFunction(const std::string& function_name, 72 void CallClientFunction(const std::string& function_name,
73 const base::Value* arg1, 73 const base::Value* arg1,
74 const base::Value* arg2, 74 const base::Value* arg2,
75 const base::Value* arg3); 75 const base::Value* arg3);
76 private: 76 private:
77 // content::NotificationObserver: 77 // content::NotificationObserver overrides.
78 virtual void Observe(int type, 78 virtual void Observe(int type,
79 const content::NotificationSource& source, 79 const content::NotificationSource& source,
80 const content::NotificationDetails& details) OVERRIDE; 80 const content::NotificationDetails& details) OVERRIDE;
81 81
82 // content::DevToolsFrontendHostDelegate override: 82 // content::DevToolsFrontendHost::Delegate implementation.
83 virtual bool ShouldSetupDevToolsFrontendForUrl(const GURL& url) OVERRIDE;
pfeldman 2014/07/31 11:47:25 Can there be a devtools frontend host that does no
dgozman 2014/07/31 13:05:31 Removed.
84 virtual void HandleMessageFromDevToolsFrontend(
85 const std::string& message) OVERRIDE;
86 virtual void HandleMessageFromDevToolsFrontendToBackend(
pfeldman 2014/07/31 11:47:25 New naming is really confusing.
dgozman 2014/07/31 13:05:31 Next step is removing this method (see TODO in dev
87 const std::string& message) OVERRIDE;
88
89 // content::DevToolsClientHost implementation.
90 virtual void DispatchOnInspectorFrontend(const std::string& message) OVERRIDE;
83 virtual void InspectedContentsClosing() OVERRIDE; 91 virtual void InspectedContentsClosing() OVERRIDE;
84 virtual void DispatchOnEmbedder(const std::string& message) OVERRIDE; 92 virtual void ReplacedWithAnotherClient() OVERRIDE;
85 93
86 // DevToolsEmbedderMessageDispatcher::Delegate overrides: 94 // DevToolsEmbedderMessageDispatcher::Delegate implementation.
87 virtual void ActivateWindow() OVERRIDE; 95 virtual void ActivateWindow() OVERRIDE;
88 virtual void CloseWindow() OVERRIDE; 96 virtual void CloseWindow() OVERRIDE;
89 virtual void SetInspectedPageBounds(const gfx::Rect& rect) OVERRIDE; 97 virtual void SetInspectedPageBounds(const gfx::Rect& rect) OVERRIDE;
90 virtual void SetContentsResizingStrategy( 98 virtual void SetContentsResizingStrategy(
91 const gfx::Insets& insets, const gfx::Size& min_size) OVERRIDE; 99 const gfx::Insets& insets, const gfx::Size& min_size) OVERRIDE;
92 virtual void InspectElementCompleted() OVERRIDE; 100 virtual void InspectElementCompleted() OVERRIDE;
93 virtual void InspectedURLChanged(const std::string& url) OVERRIDE; 101 virtual void InspectedURLChanged(const std::string& url) OVERRIDE;
94 virtual void MoveWindow(int x, int y) OVERRIDE; 102 virtual void MoveWindow(int x, int y) OVERRIDE;
95 virtual void SetIsDocked(bool is_docked) OVERRIDE; 103 virtual void SetIsDocked(bool is_docked) OVERRIDE;
96 virtual void OpenInNewTab(const std::string& url) OVERRIDE; 104 virtual void OpenInNewTab(const std::string& url) OVERRIDE;
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
156 void AddDevToolsExtensionsToClient(); 164 void AddDevToolsExtensionsToClient();
157 165
158 class FrontendWebContentsObserver; 166 class FrontendWebContentsObserver;
159 friend class FrontendWebContentsObserver; 167 friend class FrontendWebContentsObserver;
160 scoped_ptr<FrontendWebContentsObserver> frontend_contents_observer_; 168 scoped_ptr<FrontendWebContentsObserver> frontend_contents_observer_;
161 169
162 Profile* profile_; 170 Profile* profile_;
163 content::WebContents* web_contents_; 171 content::WebContents* web_contents_;
164 scoped_ptr<Delegate> delegate_; 172 scoped_ptr<Delegate> delegate_;
165 content::NotificationRegistrar registrar_; 173 content::NotificationRegistrar registrar_;
166 scoped_ptr<content::DevToolsClientHost> frontend_host_; 174 scoped_ptr<content::DevToolsFrontendHost> frontend_host_;
167 scoped_ptr<DevToolsFileHelper> file_helper_; 175 scoped_ptr<DevToolsFileHelper> file_helper_;
168 scoped_refptr<DevToolsFileSystemIndexer> file_system_indexer_; 176 scoped_refptr<DevToolsFileSystemIndexer> file_system_indexer_;
169 typedef std::map< 177 typedef std::map<
170 int, 178 int,
171 scoped_refptr<DevToolsFileSystemIndexer::FileSystemIndexingJob> > 179 scoped_refptr<DevToolsFileSystemIndexer::FileSystemIndexingJob> >
172 IndexingJobsMap; 180 IndexingJobsMap;
173 IndexingJobsMap indexing_jobs_; 181 IndexingJobsMap indexing_jobs_;
174 182
175 bool device_count_updates_enabled_; 183 bool device_count_updates_enabled_;
176 bool devices_updates_enabled_; 184 bool devices_updates_enabled_;
177 scoped_ptr<DevToolsTargetsUIHandler> remote_targets_handler_; 185 scoped_ptr<DevToolsTargetsUIHandler> remote_targets_handler_;
178 scoped_ptr<DevToolsEmbedderMessageDispatcher> embedder_message_dispatcher_; 186 scoped_ptr<DevToolsEmbedderMessageDispatcher> embedder_message_dispatcher_;
179 GURL url_; 187 GURL url_;
180 base::WeakPtrFactory<DevToolsUIBindings> weak_factory_; 188 base::WeakPtrFactory<DevToolsUIBindings> weak_factory_;
181 189
182 DISALLOW_COPY_AND_ASSIGN(DevToolsUIBindings); 190 DISALLOW_COPY_AND_ASSIGN(DevToolsUIBindings);
183 }; 191 };
184 192
185 #endif // CHROME_BROWSER_DEVTOOLS_DEVTOOLS_UI_BINDINGS_H_ 193 #endif // CHROME_BROWSER_DEVTOOLS_DEVTOOLS_UI_BINDINGS_H_
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/devtools/devtools_ui_bindings.cc » ('j') | chrome/browser/devtools/devtools_ui_bindings.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698