Merge InspectableWebContentsImpl and DevToolsFrontend

While this prevents clients from easily implementing their own devtools
windows, it gives us much easier control over the devtools experience.
This commit is contained in:
Adam Roben 2013-03-27 10:33:00 -04:00
parent 881a203b57
commit d20ecc0e2b
5 changed files with 124 additions and 160 deletions

View file

@ -28,8 +28,6 @@
'browser/default_web_contents_delegate_mac.mm', 'browser/default_web_contents_delegate_mac.mm',
'browser/devtools_delegate.cc', 'browser/devtools_delegate.cc',
'browser/devtools_delegate.h', 'browser/devtools_delegate.h',
'browser/devtools_frontend.cc',
'browser/devtools_frontend.h',
'browser/inspectable_web_contents.cc', 'browser/inspectable_web_contents.cc',
'browser/inspectable_web_contents.h', 'browser/inspectable_web_contents.h',
'browser/inspectable_web_contents_impl.cc', 'browser/inspectable_web_contents_impl.cc',

View file

@ -1,92 +0,0 @@
// Copyright (c) 2012 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-CHROMIUM file.
#include "devtools_frontend.h"
#include "browser/browser_client.h"
#include "browser/browser_main_parts.h"
#include "content/public/browser/devtools_agent_host.h"
#include "content/public/browser/devtools_client_host.h"
#include "content/public/browser/devtools_http_handler.h"
#include "content/public/browser/devtools_manager.h"
#include "content/public/browser/web_contents.h"
namespace brightray {
content::WebContents* DevToolsFrontend::Show(content::WebContents* inspected_contents) {
// frontend will delete itself when the WebContents closes.
auto frontend = new DevToolsFrontend(inspected_contents);
return frontend->web_contents();
}
DevToolsFrontend::DevToolsFrontend(content::WebContents* inspected_contents)
: WebContentsObserver(content::WebContents::Create(content::WebContents::CreateParams(inspected_contents->GetBrowserContext()))),
inspected_web_contents_(inspected_contents),
agent_host_(content::DevToolsAgentHost::GetOrCreateFor(inspected_contents->GetRenderViewHost())),
frontend_host_(content::DevToolsClientHost::CreateDevToolsFrontendHost(web_contents(), this)) {
web_contents()->SetDelegate(this);
auto client = static_cast<BrowserClient*>(content::GetContentClient()->browser());
auto handler = client->browser_main_parts()->devtools_http_handler();
auto url = handler->GetFrontendURL(nullptr);
web_contents()->GetController().LoadURL(url, content::Referrer(), content::PAGE_TRANSITION_AUTO_TOPLEVEL, std::string());
}
DevToolsFrontend::~DevToolsFrontend() {
}
void DevToolsFrontend::ActivateWindow() {
}
void DevToolsFrontend::ChangeAttachedWindowHeight(unsigned height) {
}
void DevToolsFrontend::CloseWindow() {
}
void DevToolsFrontend::MoveWindow(int x, int y) {
}
void DevToolsFrontend::SetDockSide(const std::string& side) {
}
void DevToolsFrontend::OpenInNewTab(const std::string& url) {
}
void DevToolsFrontend::SaveToFile(const std::string& url, const std::string& content, bool save_as) {
}
void DevToolsFrontend::AppendToFile(const std::string& url, const std::string& content) {
}
void DevToolsFrontend::RequestFileSystems() {
}
void DevToolsFrontend::AddFileSystem() {
}
void DevToolsFrontend::RemoveFileSystem(const std::string& file_system_path) {
}
void DevToolsFrontend::InspectedContentsClosing() {
}
void DevToolsFrontend::RenderViewCreated(content::RenderViewHost* render_view_host) {
content::DevToolsClientHost::SetupDevToolsFrontendClient(web_contents()->GetRenderViewHost());
content::DevToolsManager::GetInstance()->RegisterDevToolsClientHostFor(agent_host_, frontend_host_.get());
}
void DevToolsFrontend::WebContentsDestroyed(content::WebContents*) {
content::DevToolsManager::GetInstance()->ClientHostClosing(frontend_host_.get());
delete this;
}
void DevToolsFrontend::HandleKeyboardEvent(content::WebContents* source, const content::NativeWebKeyboardEvent& event) {
auto delegate = inspected_web_contents_->GetDelegate();
if (delegate)
delegate->HandleKeyboardEvent(source, event);
}
}

View file

@ -1,62 +0,0 @@
// Copyright (c) 2012 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-CHROMIUM file.
#ifndef BRIGHTRAY_BROWSER_DEVTOOLS_FRONTEND_H_
#define BRIGHTRAY_BROWSER_DEVTOOLS_FRONTEND_H_
#include "base/memory/scoped_ptr.h"
#include "content/public/browser/devtools_frontend_host_delegate.h"
#include "content/public/browser/web_contents_delegate.h"
#include "content/public/browser/web_contents_observer.h"
namespace content {
class DevToolsAgentHost;
class DevToolsClientHost;
}
namespace brightray {
class DevToolsFrontend : content::DevToolsFrontendHostDelegate, content::WebContentsObserver, content::WebContentsDelegate {
public:
static content::WebContents* Show(content::WebContents* inspected_contents);
private:
DevToolsFrontend(content::WebContents* inspected_contents);
~DevToolsFrontend();
// content::DevToolsFrontendHostDelegate
virtual void ActivateWindow() OVERRIDE;
virtual void ChangeAttachedWindowHeight(unsigned height) OVERRIDE;
virtual void CloseWindow() OVERRIDE;
virtual void MoveWindow(int x, int y) OVERRIDE;
virtual void SetDockSide(const std::string& side) OVERRIDE;
virtual void OpenInNewTab(const std::string& url) OVERRIDE;
virtual void SaveToFile(const std::string& url,
const std::string& content,
bool save_as) OVERRIDE;
virtual void AppendToFile(const std::string& url,
const std::string& content) OVERRIDE;
virtual void RequestFileSystems() OVERRIDE;
virtual void AddFileSystem() OVERRIDE;
virtual void RemoveFileSystem(const std::string& file_system_path) OVERRIDE;
virtual void InspectedContentsClosing() OVERRIDE;
// content::WebContentsObserver
virtual void RenderViewCreated(content::RenderViewHost*) OVERRIDE;
virtual void WebContentsDestroyed(content::WebContents*) OVERRIDE;
// content::WebContentsDelegate
virtual void HandleKeyboardEvent(content::WebContents*, const content::NativeWebKeyboardEvent&) OVERRIDE;
content::WebContents* inspected_web_contents_;
scoped_refptr<content::DevToolsAgentHost> agent_host_;
scoped_ptr<content::DevToolsClientHost> frontend_host_;
};
}
#endif

View file

@ -1,8 +1,19 @@
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Copyright (c) 2013 Adam Roben <adam@roben.org>. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE-CHROMIUM file.
#include "browser/inspectable_web_contents_impl.h" #include "browser/inspectable_web_contents_impl.h"
#include "browser/devtools_frontend.h" #include "browser/browser_client.h"
#include "browser/browser_main_parts.h"
#include "browser/inspectable_web_contents_view.h" #include "browser/inspectable_web_contents_view.h"
#include "content/public/browser/devtools_agent_host.h"
#include "content/public/browser/devtools_client_host.h"
#include "content/public/browser/devtools_http_handler.h"
#include "content/public/browser/devtools_manager.h"
namespace brightray { namespace brightray {
// Implemented separately on each platform. // Implemented separately on each platform.
@ -25,9 +36,76 @@ content::WebContents* InspectableWebContentsImpl::GetWebContents() const {
} }
void InspectableWebContentsImpl::ShowDevTools() { void InspectableWebContentsImpl::ShowDevTools() {
if (!devtools_web_contents_) if (!devtools_web_contents_) {
devtools_web_contents_.reset(DevToolsFrontend::Show(web_contents_.get())); devtools_web_contents_.reset(content::WebContents::Create(content::WebContents::CreateParams(web_contents_->GetBrowserContext())));
Observe(devtools_web_contents_.get());
devtools_web_contents_->SetDelegate(this);
agent_host_ = content::DevToolsAgentHost::GetOrCreateFor(web_contents_->GetRenderViewHost());
frontend_host_.reset(content::DevToolsClientHost::CreateDevToolsFrontendHost(devtools_web_contents_.get(), this));
auto client = static_cast<BrowserClient*>(content::GetContentClient()->browser());
auto handler = client->browser_main_parts()->devtools_http_handler();
auto url = handler->GetFrontendURL(nullptr);
devtools_web_contents_->GetController().LoadURL(url, content::Referrer(), content::PAGE_TRANSITION_AUTO_TOPLEVEL, std::string());
}
view_->ShowDevTools(); view_->ShowDevTools();
} }
void InspectableWebContentsImpl::ActivateWindow() {
}
void InspectableWebContentsImpl::ChangeAttachedWindowHeight(unsigned height) {
}
void InspectableWebContentsImpl::CloseWindow() {
}
void InspectableWebContentsImpl::MoveWindow(int x, int y) {
}
void InspectableWebContentsImpl::SetDockSide(const std::string& side) {
}
void InspectableWebContentsImpl::OpenInNewTab(const std::string& url) {
}
void InspectableWebContentsImpl::SaveToFile(const std::string& url, const std::string& content, bool save_as) {
}
void InspectableWebContentsImpl::AppendToFile(const std::string& url, const std::string& content) {
}
void InspectableWebContentsImpl::RequestFileSystems() {
}
void InspectableWebContentsImpl::AddFileSystem() {
}
void InspectableWebContentsImpl::RemoveFileSystem(const std::string& file_system_path) {
}
void InspectableWebContentsImpl::InspectedContentsClosing() {
}
void InspectableWebContentsImpl::RenderViewCreated(content::RenderViewHost* render_view_host) {
content::DevToolsClientHost::SetupDevToolsFrontendClient(web_contents()->GetRenderViewHost());
content::DevToolsManager::GetInstance()->RegisterDevToolsClientHostFor(agent_host_, frontend_host_.get());
}
void InspectableWebContentsImpl::WebContentsDestroyed(content::WebContents*) {
content::DevToolsManager::GetInstance()->ClientHostClosing(frontend_host_.get());
Observe(nullptr);
agent_host_ = nullptr;
frontend_host_.reset();
devtools_web_contents_.reset();
}
void InspectableWebContentsImpl::HandleKeyboardEvent(content::WebContents* source, const content::NativeWebKeyboardEvent& event) {
auto delegate = web_contents_->GetDelegate();
if (delegate)
delegate->HandleKeyboardEvent(source, event);
}
} }

View file

@ -3,11 +3,24 @@
#include "browser/inspectable_web_contents.h" #include "browser/inspectable_web_contents.h"
#include "content/public/browser/devtools_frontend_host_delegate.h"
#include "content/public/browser/web_contents_delegate.h"
#include "content/public/browser/web_contents_observer.h"
namespace content {
class DevToolsAgentHost;
class DevToolsClientHost;
}
namespace brightray { namespace brightray {
class InspectableWebContentsView; class InspectableWebContentsView;
class InspectableWebContentsImpl : public InspectableWebContents { class InspectableWebContentsImpl :
public InspectableWebContents,
content::DevToolsFrontendHostDelegate,
content::WebContentsObserver,
content::WebContentsDelegate {
public: public:
InspectableWebContentsImpl(const content::WebContents::CreateParams&); InspectableWebContentsImpl(const content::WebContents::CreateParams&);
virtual ~InspectableWebContentsImpl() OVERRIDE; virtual ~InspectableWebContentsImpl() OVERRIDE;
@ -20,9 +33,38 @@ public:
content::WebContents* devtools_web_contents() { return devtools_web_contents_.get(); } content::WebContents* devtools_web_contents() { return devtools_web_contents_.get(); }
private: private:
// content::DevToolsFrontendHostDelegate
virtual void ActivateWindow() OVERRIDE;
virtual void ChangeAttachedWindowHeight(unsigned height) OVERRIDE;
virtual void CloseWindow() OVERRIDE;
virtual void MoveWindow(int x, int y) OVERRIDE;
virtual void SetDockSide(const std::string& side) OVERRIDE;
virtual void OpenInNewTab(const std::string& url) OVERRIDE;
virtual void SaveToFile(const std::string& url,
const std::string& content,
bool save_as) OVERRIDE;
virtual void AppendToFile(const std::string& url,
const std::string& content) OVERRIDE;
virtual void RequestFileSystems() OVERRIDE;
virtual void AddFileSystem() OVERRIDE;
virtual void RemoveFileSystem(const std::string& file_system_path) OVERRIDE;
virtual void InspectedContentsClosing() OVERRIDE;
// content::WebContentsObserver
virtual void RenderViewCreated(content::RenderViewHost*) OVERRIDE;
virtual void WebContentsDestroyed(content::WebContents*) OVERRIDE;
// content::WebContentsDelegate
virtual void HandleKeyboardEvent(content::WebContents*, const content::NativeWebKeyboardEvent&) OVERRIDE;
scoped_ptr<content::WebContents> web_contents_; scoped_ptr<content::WebContents> web_contents_;
scoped_ptr<content::WebContents> devtools_web_contents_; scoped_ptr<content::WebContents> devtools_web_contents_;
scoped_ptr<InspectableWebContentsView> view_; scoped_ptr<InspectableWebContentsView> view_;
scoped_refptr<content::DevToolsAgentHost> agent_host_;
scoped_ptr<content::DevToolsClientHost> frontend_host_;
DISALLOW_COPY_AND_ASSIGN(InspectableWebContentsImpl); DISALLOW_COPY_AND_ASSIGN(InspectableWebContentsImpl);
}; };