Fix API changes in DevToolsManagerDelegate.

This commit is contained in:
Haojian Wu 2015-07-23 18:18:03 +08:00 committed by Cheng Zhao
parent 2dd8bc0c78
commit 7d22da5169
4 changed files with 48 additions and 116 deletions

View file

@ -12,27 +12,21 @@
#include "base/strings/string_number_conversions.h" #include "base/strings/string_number_conversions.h"
#include "base/strings/stringprintf.h" #include "base/strings/stringprintf.h"
#include "base/strings/utf_string_conversions.h" #include "base/strings/utf_string_conversions.h"
#include "browser/browser_context.h" #include "common/content_client.h"
#include "components/devtools_discovery/basic_target_descriptor.h"
#include "components/devtools_http_handler/devtools_http_handler.h"
#include "content/public/browser/devtools_agent_host.h" #include "content/public/browser/devtools_agent_host.h"
#include "content/public/browser/devtools_http_handler.h" #include "content/public/browser/devtools_frontend_host.h"
#include "content/public/browser/devtools_target.h"
#include "content/public/browser/favicon_status.h" #include "content/public/browser/favicon_status.h"
#include "content/public/browser/navigation_entry.h" #include "content/public/browser/navigation_entry.h"
#include "content/public/browser/render_view_host.h"
#include "content/public/browser/web_contents.h"
#include "content/public/common/content_switches.h" #include "content/public/common/content_switches.h"
#include "content/public/common/url_constants.h" #include "content/public/common/url_constants.h"
#include "content/public/common/user_agent.h" #include "content/public/common/user_agent.h"
#include "net/base/net_errors.h"
#include "net/socket/tcp_server_socket.h" #include "net/socket/tcp_server_socket.h"
#include "net/socket/stream_socket.h" #include "net/socket/stream_socket.h"
#include "ui/base/resource/resource_bundle.h" #include "ui/base/resource/resource_bundle.h"
using content::DevToolsAgentHost;
using content::RenderViewHost;
using content::WebContents;
using content::BrowserContext;
using content::DevToolsTarget;
using content::DevToolsHttpHandler;
namespace brightray { namespace brightray {
@ -43,12 +37,8 @@ namespace {
// since libcontentchromium doesn't expose content_shell resources. // since libcontentchromium doesn't expose content_shell resources.
const int kIDR_CONTENT_SHELL_DEVTOOLS_DISCOVERY_PAGE = 25500; const int kIDR_CONTENT_SHELL_DEVTOOLS_DISCOVERY_PAGE = 25500;
const char kTargetTypePage[] = "page";
const char kTargetTypeServiceWorker[] = "service_worker";
const char kTargetTypeOther[] = "other";
class TCPServerSocketFactory class TCPServerSocketFactory
: public content::DevToolsHttpHandler::ServerSocketFactory { : public devtools_http_handler::DevToolsHttpHandler::ServerSocketFactory {
public: public:
TCPServerSocketFactory(const std::string& address, int port) TCPServerSocketFactory(const std::string& address, int port)
: address_(address), port_(port) { : address_(address), port_(port) {
@ -71,7 +61,7 @@ class TCPServerSocketFactory
DISALLOW_COPY_AND_ASSIGN(TCPServerSocketFactory); DISALLOW_COPY_AND_ASSIGN(TCPServerSocketFactory);
}; };
scoped_ptr<content::DevToolsHttpHandler::ServerSocketFactory> scoped_ptr<devtools_http_handler::DevToolsHttpHandler::ServerSocketFactory>
CreateSocketFactory() { CreateSocketFactory() {
auto& command_line = *base::CommandLine::ForCurrentProcess(); auto& command_line = *base::CommandLine::ForCurrentProcess();
// See if the user specified a port on the command line (useful for // See if the user specified a port on the command line (useful for
@ -88,77 +78,24 @@ CreateSocketFactory() {
DLOG(WARNING) << "Invalid http debugger port number " << temp_port; DLOG(WARNING) << "Invalid http debugger port number " << temp_port;
} }
} }
return scoped_ptr<content::DevToolsHttpHandler::ServerSocketFactory>( return scoped_ptr<
new TCPServerSocketFactory("127.0.0.1", port)); devtools_http_handler::DevToolsHttpHandler::ServerSocketFactory>(
new TCPServerSocketFactory("127.0.0.1", port));
} }
class Target : public content::DevToolsTarget {
public:
explicit Target(scoped_refptr<DevToolsAgentHost> agent_host);
std::string GetId() const override { return agent_host_->GetId(); }
std::string GetParentId() const override { return std::string(); }
std::string GetType() const override {
switch (agent_host_->GetType()) {
case DevToolsAgentHost::TYPE_WEB_CONTENTS:
return kTargetTypePage;
case DevToolsAgentHost::TYPE_SERVICE_WORKER:
return kTargetTypeServiceWorker;
default:
break;
}
return kTargetTypeOther;
}
std::string GetTitle() const override { return agent_host_->GetTitle(); }
std::string GetDescription() const override { return std::string(); }
GURL GetURL() const override { return agent_host_->GetURL(); }
GURL GetFaviconURL() const override { return favicon_url_; }
base::TimeTicks GetLastActivityTime() const override {
return last_activity_time_;
}
bool IsAttached() const override { return agent_host_->IsAttached(); }
scoped_refptr<DevToolsAgentHost> GetAgentHost() const override {
return agent_host_;
}
bool Activate() const override;
bool Close() const override;
private:
scoped_refptr<DevToolsAgentHost> agent_host_;
GURL favicon_url_;
base::TimeTicks last_activity_time_;
};
Target::Target(scoped_refptr<DevToolsAgentHost> agent_host)
: agent_host_(agent_host) {
if (WebContents* web_contents = agent_host_->GetWebContents()) {
content::NavigationController& controller = web_contents->GetController();
content::NavigationEntry* entry = controller.GetActiveEntry();
if (entry != NULL && entry->GetURL().is_valid())
favicon_url_ = entry->GetFavicon().url;
last_activity_time_ = web_contents->GetLastActiveTime();
}
}
bool Target::Activate() const {
return agent_host_->Activate();
}
bool Target::Close() const {
return agent_host_->Close();
}
// DevToolsDelegate -------------------------------------------------------- // DevToolsDelegate --------------------------------------------------------
class DevToolsDelegate : public content::DevToolsHttpHandlerDelegate { class DevToolsDelegate :
public devtools_http_handler::DevToolsHttpHandlerDelegate {
public: public:
DevToolsDelegate(); DevToolsDelegate();
virtual ~DevToolsDelegate(); virtual ~DevToolsDelegate();
// content::DevToolsHttpHandlerDelegate. // devtools_http_handler::DevToolsHttpHandlerDelegate.
std::string GetDiscoveryPageHTML() override; std::string GetDiscoveryPageHTML() override;
bool BundlesFrontendResources() override; std::string GetFrontendResource(const std::string& path) override;
base::FilePath GetDebugFrontendDir() override; std::string GetPageThumbnailData(const GURL& url) override;
private: private:
DISALLOW_COPY_AND_ASSIGN(DevToolsDelegate); DISALLOW_COPY_AND_ASSIGN(DevToolsDelegate);
@ -175,12 +112,14 @@ std::string DevToolsDelegate::GetDiscoveryPageHTML() {
kIDR_CONTENT_SHELL_DEVTOOLS_DISCOVERY_PAGE).as_string(); kIDR_CONTENT_SHELL_DEVTOOLS_DISCOVERY_PAGE).as_string();
} }
bool DevToolsDelegate::BundlesFrontendResources() {
return true; std::string DevToolsDelegate::GetFrontendResource(
const std::string& path) {
return content::DevToolsFrontendHost::GetFrontendResource(path).as_string();
} }
base::FilePath DevToolsDelegate::GetDebugFrontendDir() { std::string DevToolsDelegate::GetPageThumbnailData(const GURL& url) {
return base::FilePath(); return std::string();
} }
} // namespace } // namespace
@ -188,12 +127,16 @@ base::FilePath DevToolsDelegate::GetDebugFrontendDir() {
// DevToolsManagerDelegate --------------------------------------------------- // DevToolsManagerDelegate ---------------------------------------------------
// static // static
content::DevToolsHttpHandler* devtools_http_handler::DevToolsHttpHandler*
DevToolsManagerDelegate::CreateHttpHandler() { DevToolsManagerDelegate::CreateHttpHandler() {
return DevToolsHttpHandler::Start(CreateSocketFactory(), return new devtools_http_handler::DevToolsHttpHandler(
std::string(), CreateSocketFactory(),
new DevToolsDelegate, std::string(),
base::FilePath()); new DevToolsDelegate,
base::FilePath(),
base::FilePath(),
std::string(),
GetBrightrayUserAgent());
} }
DevToolsManagerDelegate::DevToolsManagerDelegate() { DevToolsManagerDelegate::DevToolsManagerDelegate() {
@ -208,22 +151,4 @@ base::DictionaryValue* DevToolsManagerDelegate::HandleCommand(
return NULL; return NULL;
} }
std::string DevToolsManagerDelegate::GetPageThumbnailData(
const GURL& url) {
return std::string();
}
scoped_ptr<content::DevToolsTarget>
DevToolsManagerDelegate::CreateNewTarget(const GURL& url) {
return scoped_ptr<content::DevToolsTarget>();
}
void DevToolsManagerDelegate::EnumerateTargets(TargetCallback callback) {
TargetList targets;
for (const auto& agent_host : DevToolsAgentHost::GetOrCreateAll()) {
targets.push_back(new Target(agent_host));
}
callback.Run(targets);
}
} // namespace brightray } // namespace brightray

View file

@ -7,10 +7,10 @@
#include "base/basictypes.h" #include "base/basictypes.h"
#include "base/compiler_specific.h" #include "base/compiler_specific.h"
#include "content/public/browser/devtools_http_handler_delegate.h" #include "components/devtools_http_handler/devtools_http_handler_delegate.h"
#include "content/public/browser/devtools_manager_delegate.h" #include "content/public/browser/devtools_manager_delegate.h"
namespace content { namespace devtools_http_handler {
class DevToolsHttpHandler; class DevToolsHttpHandler;
} }
@ -18,7 +18,7 @@ namespace brightray {
class DevToolsManagerDelegate : public content::DevToolsManagerDelegate { class DevToolsManagerDelegate : public content::DevToolsManagerDelegate {
public: public:
static content::DevToolsHttpHandler* CreateHttpHandler(); static devtools_http_handler::DevToolsHttpHandler* CreateHttpHandler();
DevToolsManagerDelegate(); DevToolsManagerDelegate();
virtual ~DevToolsManagerDelegate(); virtual ~DevToolsManagerDelegate();
@ -30,9 +30,6 @@ class DevToolsManagerDelegate : public content::DevToolsManagerDelegate {
bool attached) override {} bool attached) override {}
base::DictionaryValue* HandleCommand(content::DevToolsAgentHost* agent_host, base::DictionaryValue* HandleCommand(content::DevToolsAgentHost* agent_host,
base::DictionaryValue* command) override; base::DictionaryValue* command) override;
scoped_ptr<content::DevToolsTarget> CreateNewTarget(const GURL& url) override;
void EnumerateTargets(TargetCallback callback) override;
std::string GetPageThumbnailData(const GURL& url) override;
private: private:
DISALLOW_COPY_AND_ASSIGN(DevToolsManagerDelegate); DISALLOW_COPY_AND_ASSIGN(DevToolsManagerDelegate);

View file

@ -14,6 +14,17 @@
namespace brightray { namespace brightray {
std::string GetProductInternal() {
auto name = GetApplicationName();
base::RemoveChars(name, base::kWhitespaceASCII, &name);
return base::StringPrintf("%s/%s",
name.c_str(), GetApplicationVersion().c_str());
}
std::string GetBrightrayUserAgent() {
return content::BuildUserAgentFromProduct(GetProductInternal());
}
ContentClient::ContentClient() { ContentClient::ContentClient() {
} }
@ -21,14 +32,11 @@ ContentClient::~ContentClient() {
} }
std::string ContentClient::GetProduct() const { std::string ContentClient::GetProduct() const {
auto name = GetApplicationName(); return GetProductInternal();
base::RemoveChars(name, base::kWhitespaceASCII, &name);
return base::StringPrintf("%s/%s",
name.c_str(), GetApplicationVersion().c_str());
} }
std::string ContentClient::GetUserAgent() const { std::string ContentClient::GetUserAgent() const {
return content::BuildUserAgentFromProduct(GetProduct()); return GetBrightrayUserAgent();
} }
base::string16 ContentClient::GetLocalizedString(int message_id) const { base::string16 ContentClient::GetLocalizedString(int message_id) const {

View file

@ -10,6 +10,8 @@
namespace brightray { namespace brightray {
std::string GetBrightrayUserAgent();
class ContentClient : public content::ContentClient { class ContentClient : public content::ContentClient {
public: public:
ContentClient(); ContentClient();