summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorvkuzkokov <vkuzkokov@chromium.org>2014-09-25 09:44:24 -0700
committerCommit bot <commit-bot@chromium.org>2014-09-25 16:44:38 +0000
commit4b0b62979ddd96b65064364eb669ec9dda7e5e5e (patch)
tree178ed2dca79152314e41fcf993975eeaa88b214a
parentca032c3aed93e5afd7c32da76147f36a72dc4341 (diff)
downloadchromium_src-4b0b62979ddd96b65064364eb669ec9dda7e5e5e.zip
chromium_src-4b0b62979ddd96b65064364eb669ec9dda7e5e5e.tar.gz
chromium_src-4b0b62979ddd96b65064364eb669ec9dda7e5e5e.tar.bz2
DevTools: Protocol handler generator for content
BUG=405566 Review URL: https://codereview.chromium.org/508973003 Cr-Commit-Position: refs/heads/master@{#296723}
-rw-r--r--content/browser/BUILD.gn2
-rw-r--r--content/browser/devtools/BUILD.gn25
-rw-r--r--content/browser/devtools/devtools.gyp44
-rw-r--r--content/browser/devtools/protocol/devtools_protocol_client.cc93
-rw-r--r--content/browser/devtools/protocol/devtools_protocol_client.h76
-rwxr-xr-xcontent/browser/devtools/protocol/devtools_protocol_handler_generator.py777
-rw-r--r--content/browser/devtools/protocol/dom_handler.cc26
-rw-r--r--content/browser/devtools/protocol/dom_handler.h32
-rw-r--r--content/browser/devtools/protocol/input_handler.cc111
-rw-r--r--content/browser/devtools/protocol/input_handler.h46
-rw-r--r--content/browser/devtools/protocol/inspector_handler.cc23
-rw-r--r--content/browser/devtools/protocol/inspector_handler.h31
-rw-r--r--content/browser/devtools/protocol/network_handler.cc40
-rw-r--r--content/browser/devtools/protocol/network_handler.h38
-rw-r--r--content/browser/devtools/protocol/page_handler.cc131
-rw-r--r--content/browser/devtools/protocol/page_handler.h80
-rw-r--r--content/browser/devtools/protocol/power_handler.cc41
-rw-r--r--content/browser/devtools/protocol/power_handler.h38
-rw-r--r--content/browser/devtools/protocol/tracing_handler.cc40
-rw-r--r--content/browser/devtools/protocol/tracing_handler.h42
-rw-r--r--content/browser/devtools/protocol/worker_handler.cc30
-rw-r--r--content/browser/devtools/protocol/worker_handler.h35
-rw-r--r--content/browser/devtools/render_view_devtools_agent_host.cc13
-rw-r--r--content/browser/devtools/render_view_devtools_agent_host.h6
-rw-r--r--content/browser/devtools/renderer_overrides_handler.cc175
-rw-r--r--content/browser/devtools/renderer_overrides_handler.h11
-rw-r--r--content/content_browser.gypi22
27 files changed, 1842 insertions, 186 deletions
diff --git a/content/browser/BUILD.gn b/content/browser/BUILD.gn
index 8819aa3..726e98c 100644
--- a/content/browser/BUILD.gn
+++ b/content/browser/BUILD.gn
@@ -84,6 +84,8 @@ source_set("browser") {
"$root_gen_dir/ui/resources/grit/webui_resources_map.cc",
"$root_gen_dir/content/browser/devtools/devtools_protocol_constants.cc",
"$root_gen_dir/content/browser/devtools/devtools_protocol_constants.h",
+ "$root_gen_dir/content/browser/devtools/protocol/devtools_protocol_handler_impl.cc",
+ "$root_gen_dir/content/browser/devtools/protocol/devtools_protocol_handler_impl.h",
], ".")
# Non-iOS deps.
diff --git a/content/browser/devtools/BUILD.gn b/content/browser/devtools/BUILD.gn
index bc2b60d..75777316 100644
--- a/content/browser/devtools/BUILD.gn
+++ b/content/browser/devtools/BUILD.gn
@@ -9,6 +9,7 @@ group("resources") {
deps = [
":devtools_resources",
":devtools_protocol_constants",
+ ":devtools_protocol_handler",
]
}
@@ -56,7 +57,31 @@ action("gen_devtools_protocol_constants") {
]
}
+action("gen_devtools_protocol_handler") {
+ visibility = [ ":devtools_protocol_handler" ]
+
+ script = "//content/browser/devtools/protocol/" +
+ "devtools_protocol_handler_generator.py"
+
+ blink_protocol = "//third_party/WebKit/Source/devtools/protocol.json"
+ inputs = [ blink_protocol ]
+
+ outputs = [
+ "$target_gen_dir/protocol/devtools_protocol_handler_impl.cc",
+ "$target_gen_dir/protocol/devtools_protocol_handler_impl.h",
+ ]
+
+ args = [
+ rebase_path(blink_protocol, root_build_dir),
+ ] + rebase_path(outputs, root_build_dir)
+}
+
source_set("devtools_protocol_constants") {
visibility = [ ":resources" ]
sources = get_target_outputs(":gen_devtools_protocol_constants")
}
+
+source_set("devtools_protocol_handler") {
+ visibility = [ ":resources" ]
+ sources = get_target_outputs(":gen_devtools_protocol_handler")
+}
diff --git a/content/browser/devtools/devtools.gyp b/content/browser/devtools/devtools.gyp
new file mode 100644
index 0000000..a67eca8
--- /dev/null
+++ b/content/browser/devtools/devtools.gyp
@@ -0,0 +1,44 @@
+# Copyright 2014 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 file.
+
+{
+ 'targets': [
+ {
+ 'target_name': 'devtools_protocol_handler',
+ 'type': 'none',
+ 'actions': [
+ {
+ 'action_name': 'devtools_protocol_handler',
+ 'variables': {
+ 'blink_protocol': '../../../third_party/WebKit/Source/devtools/protocol.json',
+ 'generator': 'protocol/devtools_protocol_handler_generator.py',
+ 'output_cc': '<(SHARED_INTERMEDIATE_DIR)/content/browser/devtools/protocol/devtools_protocol_handler_impl.cc',
+ 'output_h': '<(SHARED_INTERMEDIATE_DIR)/content/browser/devtools/protocol/devtools_protocol_handler_impl.h',
+ },
+ 'inputs': [
+ '<(blink_protocol)',
+ '<(generator)',
+ ],
+ 'outputs': [
+ '<(output_cc)',
+ '<(output_h)',
+ ],
+ 'action':[
+ 'python',
+ '<(generator)',
+ '<(blink_protocol)',
+ '<(output_cc)',
+ '<(output_h)',
+ ],
+ 'message': 'Generating DevTools protocol browser-side handlers from <(blink_protocol)'
+ },
+ ],
+ 'direct_dependent_settings': {
+ 'include_dirs': [
+ '<(SHARED_INTERMEDIATE_DIR)',
+ ]
+ },
+ },
+ ],
+}
diff --git a/content/browser/devtools/protocol/devtools_protocol_client.cc b/content/browser/devtools/protocol/devtools_protocol_client.cc
new file mode 100644
index 0000000..a0d9547
--- /dev/null
+++ b/content/browser/devtools/protocol/devtools_protocol_client.cc
@@ -0,0 +1,93 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/devtools_protocol_client.h"
+
+namespace content {
+
+DevToolsProtocolClient::DevToolsProtocolClient(
+ const EventCallback& event_callback,
+ const ResponseCallback& response_callback)
+ : event_callback_(event_callback),
+ response_callback_(response_callback) {
+}
+
+DevToolsProtocolClient::~DevToolsProtocolClient() {
+}
+
+void DevToolsProtocolClient::SendNotification(const std::string& method,
+ base::DictionaryValue* params) {
+ event_callback_.Run(method, params);
+}
+
+void DevToolsProtocolClient::SendAsyncResponse(
+ scoped_refptr<DevToolsProtocol::Response> response) {
+ response_callback_.Run(response);
+}
+
+void DevToolsProtocolClient::SendInvalidParamsResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const std::string& message) {
+ SendAsyncResponse(command->InvalidParamResponse(message));
+}
+
+void DevToolsProtocolClient::SendInternalErrorResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const std::string& message) {
+ SendAsyncResponse(command->InternalErrorResponse(message));
+}
+
+void DevToolsProtocolClient::SendServerErrorResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const std::string& message) {
+ SendAsyncResponse(command->ServerErrorResponse(message));
+}
+
+typedef DevToolsProtocolClient::Response Response;
+
+Response Response::FallThrough() {
+ Response response;
+ response.status_ = ResponseStatus::RESPONSE_STATUS_FALLTHROUGH;
+ return response;
+}
+
+Response Response::OK() {
+ Response response;
+ response.status_ = ResponseStatus::RESPONSE_STATUS_OK;
+ return response;
+}
+
+Response Response::InvalidParams(const std::string& message) {
+ Response response;
+ response.status_ = ResponseStatus::RESPONSE_STATUS_INVALID_PARAMS;
+ response.message_ = message;
+ return response;
+}
+
+Response Response::InternalError(const std::string& message) {
+ Response response;
+ response.status_ = ResponseStatus::RESPONSE_STATUS_INTERNAL_ERROR;
+ response.message_ = message;
+ return response;
+}
+
+Response Response::ServerError(const std::string& message) {
+ Response response;
+ response.status_ = ResponseStatus::RESPONSE_STATUS_SERVER_ERROR;
+ response.message_ = message;
+ return response;
+}
+
+DevToolsProtocolClient::ResponseStatus Response::status() const {
+ return status_;
+}
+
+const std::string& Response::message() const {
+ return message_;
+}
+
+Response::Response() {
+}
+
+} // namespace content
diff --git a/content/browser/devtools/protocol/devtools_protocol_client.h b/content/browser/devtools/protocol/devtools_protocol_client.h
new file mode 100644
index 0000000..b2f95b7
--- /dev/null
+++ b/content/browser/devtools/protocol/devtools_protocol_client.h
@@ -0,0 +1,76 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DEVTOOLS_PROTOCOL_CLIENT_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DEVTOOLS_PROTOCOL_CLIENT_H_
+
+#include "content/browser/devtools/devtools_protocol.h"
+
+namespace content {
+
+class DevToolsProtocolClient {
+ public:
+ typedef base::Callback<void(const std::string& event,
+ base::DictionaryValue* params)> EventCallback;
+
+ typedef base::Callback<void(scoped_refptr<DevToolsProtocol::Response>)>
+ ResponseCallback;
+
+ enum ResponseStatus {
+ RESPONSE_STATUS_FALLTHROUGH,
+ RESPONSE_STATUS_OK,
+ RESPONSE_STATUS_INVALID_PARAMS,
+ RESPONSE_STATUS_INTERNAL_ERROR,
+ RESPONSE_STATUS_SERVER_ERROR,
+ };
+
+ struct Response {
+ public:
+ static Response FallThrough();
+ static Response OK();
+ static Response InvalidParams(const std::string& message);
+ static Response InternalError(const std::string& message);
+ static Response ServerError(const std::string& message);
+
+ ResponseStatus status() const;
+ const std::string& message() const;
+
+ private:
+ Response();
+
+ ResponseStatus status_;
+ std::string message_;
+ };
+
+ void SendInvalidParamsResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const std::string& message);
+ void SendInternalErrorResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const std::string& message);
+ void SendServerErrorResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const std::string& message);
+
+ protected:
+ DevToolsProtocolClient(const EventCallback& event_callback,
+ const ResponseCallback& response_callback);
+
+ virtual ~DevToolsProtocolClient();
+
+ void SendNotification(const std::string& method,
+ base::DictionaryValue* params);
+
+ void SendAsyncResponse(scoped_refptr<DevToolsProtocol::Response> response);
+
+ private:
+ EventCallback event_callback_;
+ ResponseCallback response_callback_;
+
+ DISALLOW_COPY_AND_ASSIGN(DevToolsProtocolClient);
+};
+
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DEVTOOLS_PROTOCOL_CLIENT_H_
diff --git a/content/browser/devtools/protocol/devtools_protocol_handler_generator.py b/content/browser/devtools/protocol/devtools_protocol_handler_generator.py
new file mode 100755
index 0000000..aa7c507
--- /dev/null
+++ b/content/browser/devtools/protocol/devtools_protocol_handler_generator.py
@@ -0,0 +1,777 @@
+#!/usr/bin/env python
+# Copyright 2014 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 file.
+
+import sys
+import string
+import json
+
+input_json_path = sys.argv[1]
+output_cc_path = sys.argv[2]
+output_h_path = sys.argv[3]
+
+header = """\
+// Copyright 2014 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 file.
+
+// THIS FILE IS AUTOGENERATED. DO NOT EDIT.
+// Generated by
+// content/public/browser/devtools_protocol_handler_generator.py from
+// third_party/WebKit/Source/devtools/protocol.json
+"""
+
+template_h = string.Template(header + """\
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DEVTOOLS_PROTOCOL_HANDLER_IMPL_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DEVTOOLS_PROTOCOL_HANDLER_IMPL_H_
+
+#include "content/browser/devtools/devtools_protocol.h"
+#include "content/browser/devtools/protocol/devtools_protocol_client.h"
+
+namespace content {
+
+class DevToolsProtocolHandlerImpl;
+
+namespace devtools {
+
+${types}\
+
+} // namespace devtools
+
+class DevToolsProtocolHandlerImpl : public DevToolsProtocol::Handler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+ typedef DevToolsProtocolClient::ResponseStatus ResponseStatus;
+
+ DevToolsProtocolHandlerImpl();
+ virtual ~DevToolsProtocolHandlerImpl();
+
+${setters}\
+
+ private:
+${friends}\
+
+${methods}\
+
+${fields}\
+};
+
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DEVTOOLS_PROTOCOL_HANDLER_IMPL_H_
+""")
+
+tmpl_typedef = string.Template("""\
+namespace ${domain} {
+typedef ${param_type} ${declared_name};
+} // namespace ${domain}
+""")
+
+tmpl_struct = string.Template("""\
+namespace ${domain} {
+struct ${declared_name} {
+ public:
+ ${declared_name}();
+
+${methods}\
+
+ private:
+ friend class ::content::DevToolsProtocolHandlerImpl;
+
+${fields}\
+};
+} // namespace ${domain}
+""")
+
+tmpl_struct_setter = string.Template("""\
+ void set_${param}(${pass_type} ${param});
+""")
+
+tmpl_struct_field = string.Template("""\
+ ${param_type} ${param}_;
+ bool has_${param}_;
+""")
+
+tmpl_enum = string.Template("""\
+namespace ${domain} {
+namespace ${command_underscored} {
+${values}\
+} // namespace ${command_underscored}
+} // namespace ${domain}
+""")
+
+tmpl_enum_value = string.Template("""\
+extern const char k${Param}${Value}[];
+""")
+
+tmpl_enum_value_def = string.Template("""\
+const char k${Param}${Value}[] = "${value}";
+""")
+
+tmpl_handler = string.Template("""\
+namespace ${domain} {
+class ${Domain}Handler;
+} // namespace domain
+""")
+
+tmpl_client = string.Template("""\
+namespace ${domain} {
+class Client : public DevToolsProtocolClient {
+ public:
+ Client(const EventCallback& event_callback,
+ const ResponseCallback& response_callback);
+ virtual ~Client();
+
+${methods}\
+};
+} // namespace ${domain}
+""")
+
+tmpl_event = string.Template("""\
+ void ${Command}(
+ const ${Command}Params& params);
+""")
+
+tmpl_response = string.Template("""\
+ void Send${Command}Response(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const ${Command}Response& params);
+""")
+
+tmpl_setter = string.Template("""\
+ void Set${Domain}Handler(
+ devtools::${domain}::${Domain}Handler* ${domain}_handler);
+""")
+
+tmpl_friend = string.Template("""\
+ friend class devtools::${domain}::Client;
+""")
+
+tmpl_callback = string.Template("""\
+ scoped_refptr<DevToolsProtocol::Response>
+ On${Domain}${Command}(
+ scoped_refptr<DevToolsProtocol::Command> command);
+""")
+
+tmpl_to_value = string.Template("""\
+ static base::DictionaryValue* ToValue(
+ const devtools::${domain}::${declared_name}& src);
+""")
+
+tmpl_field = string.Template("""\
+ devtools::${domain}::${Domain}Handler* ${domain}_handler_;
+""")
+
+template_cc = string.Template(header + """\
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+#include "base/bind.h"
+${includes}\
+
+namespace content {
+
+DevToolsProtocolHandlerImpl::DevToolsProtocolHandlerImpl()
+ : ${fields_init} {
+}
+
+DevToolsProtocolHandlerImpl::~DevToolsProtocolHandlerImpl() {
+}
+
+namespace {
+
+typedef DevToolsProtocolClient::ResponseStatus ResponseStatus;
+
+bool CreateCommonResponse(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const DevToolsProtocolClient::Response& response,
+ scoped_refptr<DevToolsProtocol::Response>* protocol_response) {
+ switch (response.status()) {
+ case ResponseStatus::RESPONSE_STATUS_FALLTHROUGH:
+ *protocol_response = NULL;
+ break;
+ case ResponseStatus::RESPONSE_STATUS_OK:
+ return false;
+ case ResponseStatus::RESPONSE_STATUS_INVALID_PARAMS:
+ *protocol_response = command->InvalidParamResponse(response.message());
+ break;
+ case ResponseStatus::RESPONSE_STATUS_INTERNAL_ERROR:
+ *protocol_response = command->InternalErrorResponse(response.message());
+ break;
+ case ResponseStatus::RESPONSE_STATUS_SERVER_ERROR:
+ *protocol_response = command->ServerErrorResponse(response.message());
+ break;
+ }
+ return true;
+}
+
+} // namespace
+
+${methods}\
+
+namespace devtools {
+
+${types}\
+
+} // namespace devtools
+
+} // namespace content
+""")
+
+tmpl_include = string.Template("""\
+#include "content/browser/devtools/protocol/${domain}_handler.h"
+""")
+
+tmpl_field_init = string.Template("${domain}_handler_(NULL)")
+
+tmpl_setter_impl = string.Template("""\
+void DevToolsProtocolHandlerImpl::Set${Domain}Handler(
+ devtools::${domain}::${Domain}Handler* ${domain}_handler) {
+ DCHECK(!${domain}_handler_);
+ ${domain}_handler_ = ${domain}_handler;
+${initializations}\
+}
+""")
+
+tmpl_register = string.Template("""\
+ RegisterCommandHandler(
+ "${Domain}.${command}",
+ base::Bind(
+ &DevToolsProtocolHandlerImpl::On${Domain}${Command},
+ base::Unretained(this)));
+""")
+
+tmpl_init_client = string.Template("""\
+ ${domain}_handler_->SetClient(make_scoped_ptr(
+ new devtools::${domain}::Client(
+ base::Bind(&DevToolsProtocolHandlerImpl::SendNotification,
+ base::Unretained(this)),
+ base::Bind(&DevToolsProtocolHandlerImpl::SendAsyncResponse,
+ base::Unretained(this)))));
+""")
+
+tmpl_callback_impl = string.Template("""\
+scoped_refptr<DevToolsProtocol::Response>
+DevToolsProtocolHandlerImpl::On${Domain}${Command}(
+ scoped_refptr<DevToolsProtocol::Command> command) {
+${prep}\
+ Response response = ${domain}_handler_->${Command}(${args});
+ scoped_refptr<DevToolsProtocol::Response> protocol_response;
+ if (CreateCommonResponse(command, response, &protocol_response))
+ return protocol_response;
+ base::DictionaryValue* dict = new base::DictionaryValue();
+${wrap}\
+ return command->SuccessResponse(dict);
+}
+""")
+
+tmpl_callback_async_impl = string.Template("""\
+scoped_refptr<DevToolsProtocol::Response>
+DevToolsProtocolHandlerImpl::On${Domain}${Command}(
+ scoped_refptr<DevToolsProtocol::Command> command) {
+${prep}\
+ return ${domain}_handler_->${Command}(${args});
+}
+""")
+
+params_prep = """\
+ base::DictionaryValue* params = command->params();
+"""
+
+tmpl_prep_req = string.Template("""\
+ ${param_type} in_${param}${init};
+ if (!params ||
+ !params->Get${Type}("${proto_param}", &in_${param}))
+ return command->InvalidParamResponse("${proto_param}");
+""")
+
+tmpl_prep_req_list = string.Template("""\
+ base::ListValue* list_${param} = NULL;
+ if (!params || !params->GetList("${proto_param}", &list_${param}))
+ return command->InvalidParamResponse("${proto_param}");
+ ${param_type} in_${param};
+ for (base::ListValue::const_iterator it =
+ list_${param}->begin(); it != list_${param}->end(); ++it) {
+ ${item_type} item${item_init};
+ if (!(*it)->GetAs${ItemType}(&item))
+ return command->InvalidParamResponse("${proto_param}");
+ in_${param}.push_back(item);
+ }
+""")
+
+tmpl_prep_opt = string.Template("""\
+ ${param_type} in_${param}${init};
+ bool ${param}_found = params && params->Get${Type}(
+ "${proto_param}",
+ &in_${param});
+""")
+
+tmpl_prep_output = string.Template("""\
+ ${param_type} out_${param}${init};
+""")
+
+tmpl_arg_req = string.Template("in_${param}")
+
+tmpl_arg_opt = string.Template(
+ "${param}_found ?\n &in_${param} : NULL")
+
+tmpl_arg_output = string.Template("&out_${param}")
+
+tmpl_to_value_impl = string.Template("""\
+// static
+base::DictionaryValue* DevToolsProtocolHandlerImpl::ToValue(
+ const devtools::${domain}::${declared_name}& src) {
+ base::DictionaryValue* dict = new base::DictionaryValue();
+${dchecks}\
+${wrap}\
+ return dict;
+}
+""")
+
+tmpl_dcheck = string.Template("""\
+ DCHECK(${cond_name});
+""")
+
+tmpl_struct_impl = string.Template("""\
+namespace ${domain} {
+
+${declared_name}::${declared_name}()${fields} {
+}
+
+${methods}\
+
+} // namespace ${domain}
+""")
+
+tmpl_struct_field_init = string.Template("has_${param}_(false)")
+
+tmpl_struct_setter_impl = string.Template("""\
+void ${declared_name}::set_${param}(
+ ${pass_type} ${param}) {
+ ${param}_ = ${param};
+ has_${param}_ = true;
+}
+""")
+
+tmpl_client_impl = string.Template("""\
+namespace ${domain} {
+
+Client::Client(const EventCallback& event_callback,
+ const ResponseCallback& response_callback)
+ : DevToolsProtocolClient(event_callback, response_callback) {
+}
+
+Client::~Client() {
+}
+
+${methods}\
+
+} // namespace ${domain}
+""")
+
+tmpl_event_impl = string.Template("""\
+void Client::${Command}(
+ const ${Command}Params& params) {
+ SendNotification("${Domain}.${command}",
+ DevToolsProtocolHandlerImpl::ToValue(params));
+}
+""")
+
+tmpl_response_impl = string.Template("""\
+void Client::Send${Command}Response(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const ${Command}Response& params) {
+ SendAsyncResponse(
+ command->SuccessResponse(DevToolsProtocolHandlerImpl::ToValue(params)));
+}
+""")
+
+tmpl_wrap = string.Template("""\
+ dict->Set${Type}("${proto_param}", ${var_name});
+""")
+
+tmpl_wrap_dict = string.Template("""\
+ dict->Set("${proto_param}",
+ DevToolsProtocolHandlerImpl::ToValue(${var_name}));
+""")
+
+tmpl_wrap_obj = string.Template("""\
+ dict->Set("${proto_param}", ${var_name});
+""")
+
+tmpl_wrap_list = string.Template("""\
+ base::ListValue* list_${param} = new base::ListValue();
+ for (${param_type}::const_iterator it =
+ ${var_name}.begin(); it != ${var_name}.end(); ++it) {
+${append}\
+ }
+ dict->Set("${proto_param}", list_${param});
+""")
+
+tmpl_append = string.Template("""\
+ list_${param}->Append${Type}(*it);
+""")
+
+tmpl_append_dict = string.Template("""\
+ list_${param}->Append(DevToolsProtocolHandlerImpl::ToValue(*it));
+""")
+
+tmpl_append_obj = string.Template("""\
+ list_${param}->Append(*it);
+""")
+
+tmpl_wrap_opt = string.Template("""\
+ if (${cond_name})
+ dict->Set${Type}("${proto_param}", ${var_name});
+""")
+
+tmpl_typename = string.Template("devtools::${domain}::${declared_name}")
+
+def Capitalize(s):
+ return s[:1].upper() + s[1:]
+
+def Decapitalize(s):
+ return s.lower()
+
+def Uncamelcase(s):
+ result = ""
+ for i, c in enumerate(s):
+ if c.isupper():
+ if (i > 0) and ((i < len(s)-1) and s[i+1].islower() or s[i-1].islower()):
+ result += "_"
+ result += c.lower()
+ else:
+ result += c
+ return result
+
+types = {}
+json_api = json.loads(open(input_json_path, "r").read())
+type_decls = []
+type_impls = []
+handler_methods = []
+handler_method_impls = []
+
+for json_domain in json_api["domains"]:
+ if "types" in json_domain:
+ for json_type in json_domain["types"]:
+ types["%s.%s" % (json_domain["domain"], json_type["id"])] = json_type
+
+def DeclareStruct(json_properties, mapping):
+ methods = []
+ fields = []
+ fields_init = []
+ method_impls = []
+ dchecks = []
+ wrap = []
+ for json_prop in json_properties:
+ prop_map = mapping.copy()
+ prop_map["proto_param"] = json_prop["name"]
+ prop_map["param"] = Uncamelcase(json_prop["name"])
+ prop_map["var_name"] = "src.%s_" % prop_map["param"]
+ prop_map["cond_name"] = "src.has_%s_" % prop_map["param"]
+ ResolveType(json_prop, prop_map)
+ prop_map["declared_name"] = mapping["declared_name"]
+ methods.append(tmpl_struct_setter.substitute(prop_map))
+ fields.append(tmpl_struct_field.substitute(prop_map))
+ fields_init.append(tmpl_struct_field_init.substitute(prop_map))
+ method_impls.append(tmpl_struct_setter_impl.substitute(prop_map))
+ if json_prop.get("optional"):
+ if param_map["Type"] in ["List", "Dictionary"]:
+ # TODO(vkuzkokov) Implement.
+ raise Exception(
+ "Optional array and object properties are not implemented")
+ wrap.append(tmpl_wrap_opt.substitute(prop_map))
+ else:
+ dchecks.append(tmpl_dcheck.substitute(prop_map));
+ if not "wrap" in prop_map:
+ raise Exception("Arrays of arrays are not implemented")
+ wrap.append(prop_map["wrap"])
+
+ type_decls.append(tmpl_struct.substitute(mapping,
+ methods = "".join(methods),
+ fields = "".join(fields)))
+ fields_init_str = ""
+ if len(fields_init) > 0:
+ fields_init_str = "\n : " + (",\n ".join(fields_init))
+ type_impls.append(tmpl_struct_impl.substitute(mapping,
+ fields = fields_init_str,
+ methods = "\n".join(method_impls)))
+ handler_methods.append(tmpl_to_value.substitute(mapping))
+ handler_method_impls.append(tmpl_to_value_impl.substitute(mapping,
+ dchecks = "".join(dchecks),
+ wrap = "".join(wrap)))
+
+def ResolveRef(json, mapping):
+ dot_pos = json["$ref"].find(".")
+ if dot_pos == -1:
+ domain_name = mapping["Domain"]
+ type_name = json["$ref"]
+ else:
+ domain_name = json["$ref"][:dot_pos]
+ type_name = json["$ref"][dot_pos + 1:]
+ json_type = types["%s.%s" % (domain_name, type_name)]
+ mapping["declared_name"] = Capitalize(type_name)
+ mapping["Domain"] = domain_name
+ mapping["domain"] = Decapitalize(domain_name)
+ mapping["param_type"] = tmpl_typename.substitute(mapping)
+ if json_type.get("enum"):
+ # TODO(vkuzkokov) Implement. Approximate template:
+ # namespace ${domain} { const char k${declared_name}${Value}; }
+ raise Exception("Named enumerations are not implemented")
+ ResolveType(json_type, mapping)
+ if not "___struct_declared" in json_type:
+ json_type["___struct_declared"] = True;
+ if (json_type.get("type") == "object") and ("properties" in json_type):
+ DeclareStruct(json_type["properties"], mapping)
+ else:
+ type_decls.append(tmpl_typedef.substitute(mapping))
+ mapping["param_type"] = tmpl_typename.substitute(mapping)
+
+def ResolveArray(json, mapping):
+ items_map = mapping.copy()
+ ResolveType(json["items"], items_map)
+ mapping["param_type"] = "std::vector<%s>" % items_map["param_type"]
+ mapping["Type"] = "List"
+ if "append" in items_map:
+ mapping["wrap"] = tmpl_wrap_list.substitute(mapping,
+ append = items_map["append"])
+ mapping["pass_type"] = "const %s&" % mapping["param_type"]
+ mapping["prep_req"] = tmpl_prep_req_list.substitute(mapping,
+ item_type = items_map["param_type"],
+ item_init = items_map["init"],
+ ItemType = items_map["Type"])
+ # TODO(vkuzkokov) mapping["append"]: template for array of arrays.
+
+def ResolveObject(json, mapping):
+ mapping["Type"] = "Dictionary"
+ if "properties" in json:
+ if not "declared_name" in mapping:
+ mapping["declared_name"] = ("%s%s" %
+ (mapping["Command"], Capitalize(mapping["proto_param"])))
+ mapping["param_type"] = tmpl_typename.substitute(mapping)
+ DeclareStruct(json["properties"], mapping)
+ mapping["append"] = tmpl_append_dict.substitute(mapping)
+ mapping["wrap"] = tmpl_wrap_dict.substitute(mapping)
+ mapping["pass_type"] = "const %s&" % mapping["param_type"]
+ else:
+ mapping["param_type"] = "base::DictionaryValue*"
+ mapping["append"] = tmpl_append_obj.substitute(mapping)
+ mapping["wrap"] = tmpl_wrap_obj.substitute(mapping)
+ mapping["pass_type"] = mapping["param_type"]
+
+def ResolvePrimitive(json, mapping):
+ jsonrpc_type = json["type"]
+ if jsonrpc_type == "boolean":
+ mapping["param_type"] = "bool"
+ mapping["Type"] = "Boolean"
+ mapping["init"] = " = false"
+ elif jsonrpc_type == "integer":
+ mapping["param_type"] = "int"
+ mapping["Type"] = "Integer"
+ mapping["init"] = " = 0"
+ elif jsonrpc_type == "number":
+ mapping["param_type"] = "double"
+ mapping["Type"] = "Double"
+ mapping["init"] = " = 0.0"
+ elif jsonrpc_type == "string":
+ mapping["param_type"] = "std::string"
+ mapping["pass_type"] = "const std::string&"
+ mapping["Type"] = "String"
+ if "enum" in json:
+ values = []
+ value_defs = []
+ mapping["command_underscored"] = Uncamelcase(mapping["command"])
+ mapping["Param"] = Capitalize(mapping["proto_param"])
+ for enum_value in json["enum"]:
+ values.append(tmpl_enum_value.substitute(mapping,
+ Value = Capitalize(enum_value)))
+ value_defs.append(tmpl_enum_value_def.substitute(mapping,
+ value = enum_value,
+ Value = Capitalize(enum_value)))
+ type_decls.append(tmpl_enum.substitute(mapping,
+ values = "".join(values)))
+ type_impls.append(tmpl_enum.substitute(mapping,
+ values = "".join(value_defs)))
+ else:
+ raise Exception("Unknown type: %s" % json_type)
+ mapping["wrap"] = tmpl_wrap.substitute(mapping)
+ mapping["append"] = tmpl_append.substitute(mapping)
+ mapping["prep_req"] = tmpl_prep_req.substitute(mapping)
+ if jsonrpc_type != "string":
+ mapping["pass_type"] = mapping["param_type"]
+
+def ResolveType(json, mapping):
+ mapping["init"] = ""
+ if "$ref" in json:
+ ResolveRef(json, mapping)
+ elif "type" in json:
+ jsonrpc_type = json["type"]
+ if jsonrpc_type == "array":
+ ResolveArray(json, mapping)
+ elif jsonrpc_type == "object":
+ ResolveObject(json, mapping)
+ else:
+ ResolvePrimitive(json, mapping)
+ else:
+ raise Exception("Unknown type at %s.%s %s" %
+ (mapping["Domain"], mapping["command"], mapping["proto_param"]))
+
+setters = []
+friends = []
+fields = []
+
+includes = []
+fields_init = []
+
+for json_domain in json_api["domains"]:
+ domain_map = {}
+ domain_map["Domain"] = json_domain["domain"]
+ domain_map["domain"] = Decapitalize(json_domain["domain"])
+
+ initializations = []
+ client_methods = []
+ client_method_impls = []
+ domain_empty = True
+ domain_needs_client = False
+
+ if "commands" in json_domain:
+ for json_command in json_domain["commands"]:
+ if (not ("handlers" in json_command) or
+ not ("browser" in json_command["handlers"])):
+ continue
+ domain_empty = False
+
+ command_map = domain_map.copy()
+ command_map["command"] = json_command["name"]
+ command_map["Command"] = Capitalize(json_command["name"])
+
+ prep = []
+ args = []
+
+ if "parameters" in json_command:
+ for json_param in json_command["parameters"]:
+ param_map = command_map.copy()
+ param_map["proto_param"] = json_param["name"]
+ param_map["param"] = Uncamelcase(json_param["name"])
+ param_map["var_name"] = "in_%s" % param_map["param"]
+
+ ResolveType(json_param, param_map)
+ if len(prep) == 0:
+ prep.append(params_prep)
+ if json_param.get("optional"):
+ if param_map["Type"] in ["List", "Dictionary"]:
+ # TODO(vkuzkokov) Implement transformation of base::ListValue
+ # to std::vector and base::DictonaryValue to struct.
+ raise Exception(
+ "Optional array and object parameters are not implemented")
+ prep.append(tmpl_prep_opt.substitute(param_map))
+ args.append(tmpl_arg_opt.substitute(param_map))
+ else:
+ prep.append(param_map["prep_req"])
+ args.append(tmpl_arg_req.substitute(param_map))
+
+ if json_command.get("async"):
+ domain_needs_client = True
+ json_returns = []
+ if "returns" in json_command:
+ json_returns = json_command["returns"]
+ command_map["declared_name"] = "%sResponse" % command_map["Command"]
+ DeclareStruct(json_returns, command_map)
+ # TODO(vkuzkokov) Pass async callback instance similar to how
+ # InspectorBackendDispatcher does it. This, however, can work
+ # only if Blink and Chrome are in the same repo.
+ args.append("command")
+ handler_method_impls.append(
+ tmpl_callback_async_impl.substitute(command_map,
+ prep = "".join(prep),
+ args = "\n " + ",\n ".join(args)))
+ client_methods.append(tmpl_response.substitute(command_map))
+ client_method_impls.append(tmpl_response_impl.substitute(command_map))
+ else:
+ wrap = []
+ if "returns" in json_command:
+ for json_param in json_command["returns"]:
+ param_map = command_map.copy()
+ param_map["proto_param"] = json_param["name"]
+ param_map["param"] = Uncamelcase(json_param["name"])
+ param_map["var_name"] = "out_%s" % param_map["param"]
+
+ if json_param.get("optional"):
+ # TODO(vkuzkokov) Implement Optional<T> for value types.
+ raise Exception("Optional return values are not implemented")
+ ResolveType(json_param, param_map)
+ prep.append(tmpl_prep_output.substitute(param_map))
+ args.append(tmpl_arg_output.substitute(param_map))
+ if not "wrap" in param_map:
+ raise Exception("Arrays of arrays are not implemented")
+ wrap.append(param_map["wrap"])
+
+ args_str = ""
+ if len(args) > 0:
+ args_str = "\n " + ",\n ".join(args)
+ handler_method_impls.append(tmpl_callback_impl.substitute(command_map,
+ prep = "".join(prep),
+ args = args_str,
+ wrap = "".join(wrap)))
+
+ initializations.append(tmpl_register.substitute(command_map))
+ handler_methods.append(tmpl_callback.substitute(command_map))
+
+ if "events" in json_domain:
+ for json_event in json_domain["events"]:
+ if (not ("handlers" in json_event) or
+ not ("browser" in json_event["handlers"])):
+ continue
+ domain_empty = False
+ domain_needs_client = True
+
+ event_map = domain_map.copy()
+ event_map["command"] = json_event["name"]
+ event_map["Command"] = Capitalize(json_event["name"])
+
+ json_parameters = []
+ if "parameters" in json_event:
+ json_parameters = json_event["parameters"]
+ event_map["declared_name"] = "%sParams" % event_map["Command"]
+ DeclareStruct(json_parameters, event_map);
+
+ client_methods.append(tmpl_event.substitute(event_map))
+ client_method_impls.append(tmpl_event_impl.substitute(event_map))
+
+ if domain_empty:
+ continue
+ type_decls.append(tmpl_handler.substitute(domain_map))
+ setters.append(tmpl_setter.substitute(domain_map))
+ fields.append(tmpl_field.substitute(domain_map))
+ includes.append(tmpl_include.substitute(domain_map))
+ fields_init.append(tmpl_field_init.substitute(domain_map))
+ if domain_needs_client:
+ type_decls.append(tmpl_client.substitute(domain_map,
+ methods = "".join(client_methods)))
+ friends.append(tmpl_friend.substitute(domain_map))
+ initializations.append(tmpl_init_client.substitute(domain_map))
+ type_impls.append(tmpl_client_impl.substitute(domain_map,
+ methods = "\n".join(client_method_impls)))
+ handler_method_impls.append(tmpl_setter_impl.substitute(domain_map,
+ initializations = "".join(initializations)))
+
+
+output_h_file = open(output_h_path, "w")
+output_cc_file = open(output_cc_path, "w")
+
+output_h_file.write(template_h.substitute({},
+ types = "\n".join(type_decls),
+ setters = "".join(setters),
+ friends = "".join(friends),
+ methods = "".join(handler_methods),
+ fields = "".join(fields)))
+output_h_file.close()
+
+output_cc_file.write(template_cc.substitute({},
+ includes = "".join(sorted(includes)),
+ fields_init = ",\n ".join(fields_init),
+ methods = "\n".join(handler_method_impls),
+ types = "\n".join(type_impls)))
+output_cc_file.close()
diff --git a/content/browser/devtools/protocol/dom_handler.cc b/content/browser/devtools/protocol/dom_handler.cc
new file mode 100644
index 0000000..8453335
--- /dev/null
+++ b/content/browser/devtools/protocol/dom_handler.cc
@@ -0,0 +1,26 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/dom_handler.h"
+
+namespace content {
+namespace devtools {
+namespace dom {
+
+typedef DevToolsProtocolClient::Response Response;
+
+DOMHandler::DOMHandler() {
+}
+
+DOMHandler::~DOMHandler() {
+}
+
+Response DOMHandler::SetFileInputFiles(NodeId node_id,
+ const std::vector<std::string>& files) {
+ return Response::FallThrough();
+}
+
+} // namespace dom
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/dom_handler.h b/content/browser/devtools/protocol/dom_handler.h
new file mode 100644
index 0000000..9718426
--- /dev/null
+++ b/content/browser/devtools/protocol/dom_handler.h
@@ -0,0 +1,32 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DOM_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DOM_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+namespace devtools {
+namespace dom {
+
+class DOMHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ DOMHandler();
+ virtual ~DOMHandler();
+
+ Response SetFileInputFiles(NodeId node_id,
+ const std::vector<std::string>& files);
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(DOMHandler);
+};
+
+} // namespace dom
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_DOM_HANDLER_H_
diff --git a/content/browser/devtools/protocol/input_handler.cc b/content/browser/devtools/protocol/input_handler.cc
new file mode 100644
index 0000000..05cff61
--- /dev/null
+++ b/content/browser/devtools/protocol/input_handler.cc
@@ -0,0 +1,111 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/input_handler.h"
+
+#include "base/strings/stringprintf.h"
+#include "content/browser/renderer_host/render_view_host_impl.h"
+#include "third_party/WebKit/public/web/WebInputEvent.h"
+
+namespace content {
+namespace devtools {
+namespace input {
+
+typedef DevToolsProtocolClient::Response Response;
+
+InputHandler::InputHandler()
+ : host_(NULL) {
+}
+
+InputHandler::~InputHandler() {
+}
+
+void InputHandler::SetRenderViewHost(RenderViewHostImpl* host) {
+ host_ = host;
+}
+
+Response InputHandler::EmulateTouchFromMouseEvent(const std::string& type,
+ int x,
+ int y,
+ double timestamp,
+ const std::string& button,
+ double* delta_x,
+ double* delta_y,
+ int* modifiers,
+ int* click_count) {
+ blink::WebMouseWheelEvent wheel_event;
+ blink::WebMouseEvent mouse_event;
+ blink::WebMouseEvent* event = &mouse_event;
+
+ if (type == emulate_touch_from_mouse_event::kTypeMousePressed) {
+ event->type = blink::WebInputEvent::MouseDown;
+ } else if (type == emulate_touch_from_mouse_event::kTypeMouseReleased) {
+ event->type = blink::WebInputEvent::MouseUp;
+ } else if (type == emulate_touch_from_mouse_event::kTypeMouseMoved) {
+ event->type = blink::WebInputEvent::MouseMove;
+ } else if (type == emulate_touch_from_mouse_event::kTypeMouseWheel) {
+ if (!delta_x || !delta_y) {
+ return Response::InvalidParams(
+ "'deltaX' and 'deltaY' are expected for mouseWheel event");
+ }
+ wheel_event.deltaX = static_cast<float>(*delta_x);
+ wheel_event.deltaY = static_cast<float>(*delta_y);
+ event = &wheel_event;
+ event->type = blink::WebInputEvent::MouseWheel;
+ } else {
+ return Response::InvalidParams(
+ base::StringPrintf("Unexpected event type '%s'", type.c_str()));
+ }
+
+ if (modifiers) {
+ if (*modifiers & 1)
+ event->modifiers |= blink::WebInputEvent::AltKey;
+ if (*modifiers & 2)
+ event->modifiers |= blink::WebInputEvent::ControlKey;
+ if (*modifiers & 4)
+ event->modifiers |= blink::WebInputEvent::MetaKey;
+ if (*modifiers & 8)
+ event->modifiers |= blink::WebInputEvent::ShiftKey;
+ }
+
+ event->timeStampSeconds = timestamp;
+ event->x = x;
+ event->y = y;
+ event->windowX = x;
+ event->windowY = y;
+ event->globalX = x;
+ event->globalY = y;
+
+ if (click_count)
+ event->clickCount = *click_count;
+
+ if (button == emulate_touch_from_mouse_event::kButtonNone) {
+ event->button = blink::WebMouseEvent::ButtonNone;
+ } else if (button == emulate_touch_from_mouse_event::kButtonLeft) {
+ event->button = blink::WebMouseEvent::ButtonLeft;
+ event->modifiers |= blink::WebInputEvent::LeftButtonDown;
+ } else if (button == emulate_touch_from_mouse_event::kButtonMiddle) {
+ event->button = blink::WebMouseEvent::ButtonMiddle;
+ event->modifiers |= blink::WebInputEvent::MiddleButtonDown;
+ } else if (button == emulate_touch_from_mouse_event::kButtonRight) {
+ event->button = blink::WebMouseEvent::ButtonRight;
+ event->modifiers |= blink::WebInputEvent::RightButtonDown;
+ } else {
+ return Response::InvalidParams(
+ base::StringPrintf("Unexpected mouse button '%s'", button.c_str()));
+ }
+
+ if (!host_)
+ return Response::ServerError("Could not connect to view");
+
+ if (event->type == blink::WebInputEvent::MouseWheel)
+ host_->ForwardWheelEvent(wheel_event);
+ else
+ host_->ForwardMouseEvent(mouse_event);
+ return Response::OK();
+}
+
+} // namespace input
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/input_handler.h b/content/browser/devtools/protocol/input_handler.h
new file mode 100644
index 0000000..1a85b2a
--- /dev/null
+++ b/content/browser/devtools/protocol/input_handler.h
@@ -0,0 +1,46 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_INPUT_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_INPUT_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+
+class RenderViewHostImpl;
+
+namespace devtools {
+namespace input {
+
+class InputHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ InputHandler();
+ virtual ~InputHandler();
+
+ void SetRenderViewHost(RenderViewHostImpl* host);
+
+ Response EmulateTouchFromMouseEvent(const std::string& type,
+ int x,
+ int y,
+ double timestamp,
+ const std::string& button,
+ double* delta_x,
+ double* delta_y,
+ int* modifiers,
+ int* click_count);
+
+ private:
+ RenderViewHostImpl* host_;
+
+ DISALLOW_COPY_AND_ASSIGN(InputHandler);
+};
+
+} // namespace inpue
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_INPUT_HANDLER_H_
diff --git a/content/browser/devtools/protocol/inspector_handler.cc b/content/browser/devtools/protocol/inspector_handler.cc
new file mode 100644
index 0000000..4dbbd04
--- /dev/null
+++ b/content/browser/devtools/protocol/inspector_handler.cc
@@ -0,0 +1,23 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/inspector_handler.h"
+
+namespace content {
+namespace devtools {
+namespace inspector {
+
+InspectorHandler::InspectorHandler() {
+}
+
+InspectorHandler::~InspectorHandler() {
+}
+
+void InspectorHandler::SetClient(scoped_ptr<Client> client) {
+ client_.swap(client);
+}
+
+} // namespace inspector
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/inspector_handler.h b/content/browser/devtools/protocol/inspector_handler.h
new file mode 100644
index 0000000..d6b449e
--- /dev/null
+++ b/content/browser/devtools/protocol/inspector_handler.h
@@ -0,0 +1,31 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_INSPECTOR_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_INSPECTOR_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+namespace devtools {
+namespace inspector {
+
+class InspectorHandler {
+ public:
+ InspectorHandler();
+ virtual ~InspectorHandler();
+
+ void SetClient(scoped_ptr<Client> client);
+
+ private:
+ scoped_ptr<Client> client_;
+
+ DISALLOW_COPY_AND_ASSIGN(InspectorHandler);
+};
+
+} // namespace inspector
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_INSPECTOR_HANDLER_H_
diff --git a/content/browser/devtools/protocol/network_handler.cc b/content/browser/devtools/protocol/network_handler.cc
new file mode 100644
index 0000000..b47cb49
--- /dev/null
+++ b/content/browser/devtools/protocol/network_handler.cc
@@ -0,0 +1,40 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/network_handler.h"
+
+namespace content {
+namespace devtools {
+namespace network {
+
+typedef DevToolsProtocolClient::Response Response;
+
+NetworkHandler::NetworkHandler() {
+}
+
+NetworkHandler::~NetworkHandler() {
+}
+
+Response NetworkHandler::ClearBrowserCache() {
+ return Response::FallThrough();
+}
+
+Response NetworkHandler::ClearBrowserCookies() {
+ return Response::FallThrough();
+}
+
+Response NetworkHandler::CanEmulateNetworkConditions(bool* result) {
+ return Response::FallThrough();
+}
+
+Response NetworkHandler::EmulateNetworkConditions(bool offline,
+ double latency,
+ double download_throughput,
+ double upload_throughput) {
+ return Response::FallThrough();
+}
+
+} // namespace dom
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/network_handler.h b/content/browser/devtools/protocol/network_handler.h
new file mode 100644
index 0000000..20ba235
--- /dev/null
+++ b/content/browser/devtools/protocol/network_handler.h
@@ -0,0 +1,38 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_NETWORK_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_NETWORK_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+namespace devtools {
+namespace network {
+
+class NetworkHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ NetworkHandler();
+ virtual ~NetworkHandler();
+
+ Response ClearBrowserCache();
+ Response ClearBrowserCookies();
+ Response CanEmulateNetworkConditions(bool* result);
+
+ Response EmulateNetworkConditions(bool offline,
+ double latency,
+ double download_throughput,
+ double upload_throughput);
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(NetworkHandler);
+};
+
+} // namespace network
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_NETWORK_HANDLER_H_
diff --git a/content/browser/devtools/protocol/page_handler.cc b/content/browser/devtools/protocol/page_handler.cc
new file mode 100644
index 0000000..33fac54
--- /dev/null
+++ b/content/browser/devtools/protocol/page_handler.cc
@@ -0,0 +1,131 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/page_handler.h"
+
+#include "base/base64.h"
+#include "content/browser/renderer_host/render_view_host_impl.h"
+
+namespace content {
+namespace devtools {
+namespace page {
+
+typedef DevToolsProtocolClient::Response Response;
+
+PageHandler::PageHandler()
+ : weak_factory_(this) {
+}
+
+PageHandler::~PageHandler() {
+}
+
+void PageHandler::SetRenderViewHost(RenderViewHostImpl* host) {
+ host_ = host;
+}
+
+void PageHandler::SetClient(scoped_ptr<Client> client) {
+ client_.swap(client);
+}
+
+Response PageHandler::Enable() {
+ return Response::FallThrough();
+}
+
+Response PageHandler::Disable() {
+ return Response::FallThrough();
+}
+
+Response PageHandler::Reload(const bool* ignoreCache,
+ const std::string* script_to_evaluate_on_load,
+ const std::string* script_preprocessor) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::Navigate(const std::string& url,
+ FrameId* frame_id) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::GetNavigationHistory(
+ int* current_index,
+ std::vector<NavigationEntry>* entries) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::NavigateToHistoryEntry(int entry_id) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::SetTouchEmulationEnabled(bool enabled) {
+ return Response::FallThrough();
+}
+
+scoped_refptr<DevToolsProtocol::Response> PageHandler::CaptureScreenshot(
+ scoped_refptr<DevToolsProtocol::Command> command) {
+ if (!host_ || !host_->GetView())
+ return command->InternalErrorResponse("Could not connect to view");
+
+ host_->GetSnapshotFromBrowser(
+ base::Bind(&PageHandler::ScreenshotCaptured,
+ weak_factory_.GetWeakPtr(), command));
+ return command->AsyncResponsePromise();
+}
+
+Response PageHandler::CanScreencast(bool* result) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::CanEmulate(bool* result) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::StartScreencast(const std::string* format,
+ const int* quality,
+ const int* max_width,
+ const int* max_height) {
+ return Response::FallThrough();
+}
+
+Response PageHandler::StopScreencast() {
+ return Response::FallThrough();
+}
+
+Response PageHandler::HandleJavaScriptDialog(bool accept,
+ const std::string* prompt_text) {
+ return Response::FallThrough();
+}
+
+scoped_refptr<DevToolsProtocol::Response> PageHandler::QueryUsageAndQuota(
+ const std::string& security_origin,
+ scoped_refptr<DevToolsProtocol::Command> command) {
+ return NULL;
+}
+
+Response PageHandler::SetColorPickerEnabled(bool enabled) {
+ return Response::FallThrough();
+}
+
+void PageHandler::ScreenshotCaptured(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const unsigned char* png_data,
+ size_t png_size) {
+ if (!png_data || !png_size) {
+ client_->SendInternalErrorResponse(command,
+ "Unable to capture screenshot");
+ return;
+ }
+
+ std::string base_64_data;
+ base::Base64Encode(
+ base::StringPiece(reinterpret_cast<const char*>(png_data), png_size),
+ &base_64_data);
+
+ CaptureScreenshotResponse response;
+ response.set_data(base_64_data);
+ client_->SendCaptureScreenshotResponse(command, response);
+}
+
+} // namespace page
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/page_handler.h b/content/browser/devtools/protocol/page_handler.h
new file mode 100644
index 0000000..f63756f2
--- /dev/null
+++ b/content/browser/devtools/protocol/page_handler.h
@@ -0,0 +1,80 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_PAGE_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_PAGE_HANDLER_H_
+
+#include "base/memory/weak_ptr.h"
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+
+class RenderViewHostImpl;
+
+namespace devtools {
+namespace page {
+
+class PageHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ PageHandler();
+ virtual ~PageHandler();
+
+ void SetRenderViewHost(RenderViewHostImpl* host);
+ void SetClient(scoped_ptr<Client> client);
+
+ Response Enable();
+ Response Disable();
+
+ Response Reload(const bool* ignoreCache,
+ const std::string* script_to_evaluate_on_load,
+ const std::string* script_preprocessor);
+
+ Response Navigate(const std::string& url, FrameId* frame_id);
+
+ Response GetNavigationHistory(int* current_index,
+ std::vector<NavigationEntry>* entries);
+
+ Response NavigateToHistoryEntry(int entry_id);
+ Response SetTouchEmulationEnabled(bool enabled);
+
+ scoped_refptr<DevToolsProtocol::Response> CaptureScreenshot(
+ scoped_refptr<DevToolsProtocol::Command> command);
+
+ Response CanScreencast(bool* result);
+ Response CanEmulate(bool* result);
+
+ Response StartScreencast(const std::string* format,
+ const int* quality,
+ const int* max_width,
+ const int* max_height);
+
+ Response StopScreencast();
+ Response HandleJavaScriptDialog(bool accept, const std::string* prompt_text);
+
+ scoped_refptr<DevToolsProtocol::Response> QueryUsageAndQuota(
+ const std::string& security_origin,
+ scoped_refptr<DevToolsProtocol::Command> command);
+
+ Response SetColorPickerEnabled(bool enabled);
+
+ private:
+ RenderViewHostImpl* host_;
+ scoped_ptr<Client> client_;
+ base::WeakPtrFactory<PageHandler> weak_factory_;
+
+ void ScreenshotCaptured(
+ scoped_refptr<DevToolsProtocol::Command> command,
+ const unsigned char* png_data,
+ size_t png_size);
+
+ DISALLOW_COPY_AND_ASSIGN(PageHandler);
+};
+
+} // namespace page
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_PAGE_HANDLER_H_
diff --git a/content/browser/devtools/protocol/power_handler.cc b/content/browser/devtools/protocol/power_handler.cc
new file mode 100644
index 0000000..1265110
--- /dev/null
+++ b/content/browser/devtools/protocol/power_handler.cc
@@ -0,0 +1,41 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/power_handler.h"
+
+namespace content {
+namespace devtools {
+namespace power {
+
+typedef DevToolsProtocolClient::Response Response;
+
+PowerHandler::PowerHandler() {
+}
+
+PowerHandler::~PowerHandler() {
+}
+
+void PowerHandler::SetClient(scoped_ptr<Client> client) {
+ client_.swap(client);
+}
+
+Response PowerHandler::Start() {
+ return Response::FallThrough();
+}
+
+Response PowerHandler::End() {
+ return Response::FallThrough();
+}
+
+Response PowerHandler::CanProfilePower(bool* result) {
+ return Response::FallThrough();
+}
+
+Response PowerHandler::GetAccuracyLevel(std::string* result) {
+ return Response::FallThrough();
+}
+
+} // namespace power
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/power_handler.h b/content/browser/devtools/protocol/power_handler.h
new file mode 100644
index 0000000..00ac4ee
--- /dev/null
+++ b/content/browser/devtools/protocol/power_handler.h
@@ -0,0 +1,38 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_POWER_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_POWER_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+namespace devtools {
+namespace power {
+
+class PowerHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ PowerHandler();
+ virtual ~PowerHandler();
+
+ void SetClient(scoped_ptr<Client> client);
+
+ Response Start();
+ Response End();
+ Response CanProfilePower(bool* result);
+ Response GetAccuracyLevel(std::string* result);
+
+ private:
+ scoped_ptr<Client> client_;
+
+ DISALLOW_COPY_AND_ASSIGN(PowerHandler);
+};
+
+} // namespace power
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_POWER_HANDLER_H_
diff --git a/content/browser/devtools/protocol/tracing_handler.cc b/content/browser/devtools/protocol/tracing_handler.cc
new file mode 100644
index 0000000..e3da76c
--- /dev/null
+++ b/content/browser/devtools/protocol/tracing_handler.cc
@@ -0,0 +1,40 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/tracing_handler.h"
+
+namespace content {
+namespace devtools {
+namespace tracing {
+
+typedef DevToolsProtocolClient::Response Response;
+
+TracingHandler::TracingHandler() {
+}
+
+TracingHandler::~TracingHandler() {
+}
+
+void TracingHandler::SetClient(scoped_ptr<Client> client) {
+ client_.swap(client);
+}
+
+Response TracingHandler::Start(const std::string& categories,
+ const std::string& options,
+ const double* buffer_usage_reporting_interval) {
+ return Response::FallThrough();
+}
+
+Response TracingHandler::End() {
+ return Response::FallThrough();
+}
+
+scoped_refptr<DevToolsProtocol::Response> TracingHandler::GetCategories(
+ scoped_refptr<DevToolsProtocol::Command> command) {
+ return NULL;
+}
+
+} // namespace tracing
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/tracing_handler.h b/content/browser/devtools/protocol/tracing_handler.h
new file mode 100644
index 0000000..2ec9508
--- /dev/null
+++ b/content/browser/devtools/protocol/tracing_handler.h
@@ -0,0 +1,42 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+namespace devtools {
+namespace tracing {
+
+class TracingHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ TracingHandler();
+ virtual ~TracingHandler();
+
+ void SetClient(scoped_ptr<Client> client);
+
+ Response Start(const std::string& categories,
+ const std::string& options,
+ const double* buffer_usage_reporting_interval);
+
+ Response End();
+
+ scoped_refptr<DevToolsProtocol::Response> GetCategories(
+ scoped_refptr<DevToolsProtocol::Command> command);
+
+ private:
+ scoped_ptr<Client> client_;
+
+ DISALLOW_COPY_AND_ASSIGN(TracingHandler);
+};
+
+} // namespace tracing
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_
diff --git a/content/browser/devtools/protocol/worker_handler.cc b/content/browser/devtools/protocol/worker_handler.cc
new file mode 100644
index 0000000..fd8fc09
--- /dev/null
+++ b/content/browser/devtools/protocol/worker_handler.cc
@@ -0,0 +1,30 @@
+// Copyright 2014 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 file.
+
+#include "content/browser/devtools/protocol/worker_handler.h"
+
+namespace content {
+namespace devtools {
+namespace worker {
+
+typedef DevToolsProtocolClient::Response Response;
+typedef DevToolsProtocolClient::ResponseStatus ResponseStatus;
+
+WorkerHandler::WorkerHandler() {
+}
+
+WorkerHandler::~WorkerHandler() {
+}
+
+void WorkerHandler::SetClient(scoped_ptr<Client> client) {
+ client_.swap(client);
+}
+
+Response WorkerHandler::DisconnectFromWorker(int worker_id) {
+ return Response::FallThrough();
+}
+
+} // namespace worker
+} // namespace devtools
+} // namespace content
diff --git a/content/browser/devtools/protocol/worker_handler.h b/content/browser/devtools/protocol/worker_handler.h
new file mode 100644
index 0000000..1c1faaf
--- /dev/null
+++ b/content/browser/devtools/protocol/worker_handler.h
@@ -0,0 +1,35 @@
+// Copyright 2014 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 file.
+
+#ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_WORKER_HANDLER_H_
+#define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_WORKER_HANDLER_H_
+
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
+
+namespace content {
+namespace devtools {
+namespace worker {
+
+class WorkerHandler {
+ public:
+ typedef DevToolsProtocolClient::Response Response;
+
+ WorkerHandler();
+ virtual ~WorkerHandler();
+
+ void SetClient(scoped_ptr<Client> client);
+
+ Response DisconnectFromWorker(int worker_id);
+
+ private:
+ scoped_ptr<Client> client_;
+
+ DISALLOW_COPY_AND_ASSIGN(WorkerHandler);
+};
+
+} // namespace worker
+} // namespace devtools
+} // namespace content
+
+#endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_WORKER_HANDLER_H_
diff --git a/content/browser/devtools/render_view_devtools_agent_host.cc b/content/browser/devtools/render_view_devtools_agent_host.cc
index 7045b37..3da9a23 100644
--- a/content/browser/devtools/render_view_devtools_agent_host.cc
+++ b/content/browser/devtools/render_view_devtools_agent_host.cc
@@ -13,6 +13,7 @@
#include "content/browser/devtools/devtools_protocol.h"
#include "content/browser/devtools/devtools_protocol_constants.h"
#include "content/browser/devtools/devtools_tracing_handler.h"
+#include "content/browser/devtools/protocol/devtools_protocol_handler_impl.h"
#include "content/browser/devtools/renderer_overrides_handler.h"
#include "content/browser/renderer_host/render_process_host_impl.h"
#include "content/browser/renderer_host/render_view_host_impl.h"
@@ -109,15 +110,21 @@ void RenderViewDevToolsAgentHost::OnCancelPendingNavigation(
RenderViewDevToolsAgentHost::RenderViewDevToolsAgentHost(RenderViewHost* rvh)
: render_view_host_(NULL),
+ input_handler_(new devtools::input::InputHandler()),
+ page_handler_(new devtools::page::PageHandler()),
+ handler_impl_(new DevToolsProtocolHandlerImpl()),
overrides_handler_(new RendererOverridesHandler()),
tracing_handler_(
new DevToolsTracingHandler(DevToolsTracingHandler::Renderer)),
power_handler_(new DevToolsPowerHandler()),
reattaching_(false) {
+ handler_impl_->SetInputHandler(input_handler_.get());
+ handler_impl_->SetPageHandler(page_handler_.get());
SetRenderViewHost(rvh);
DevToolsProtocol::Notifier notifier(base::Bind(
&RenderViewDevToolsAgentHost::OnDispatchOnInspectorFrontend,
base::Unretained(this)));
+ handler_impl_->SetNotifier(notifier);
overrides_handler_->SetNotifier(notifier);
tracing_handler_->SetNotifier(notifier);
power_handler_->SetNotifier(notifier);
@@ -156,6 +163,8 @@ void RenderViewDevToolsAgentHost::DispatchProtocolMessage(
overridden_response = tracing_handler_->HandleCommand(command);
if (!overridden_response.get())
overridden_response = power_handler_->HandleCommand(command);
+ if (!overridden_response.get())
+ overridden_response = handler_impl_->HandleCommand(command);
if (overridden_response.get()) {
if (!overridden_response->is_async_promise())
OnDispatchOnInspectorFrontend(overridden_response->Serialize());
@@ -354,6 +363,8 @@ void RenderViewDevToolsAgentHost::SetRenderViewHost(RenderViewHost* rvh) {
WebContentsObserver::Observe(WebContents::FromRenderViewHost(rvh));
overrides_handler_->SetRenderViewHost(render_view_host_);
+ input_handler_->SetRenderViewHost(render_view_host_);
+ page_handler_->SetRenderViewHost(render_view_host_);
registrar_.Add(
this,
@@ -369,6 +380,8 @@ void RenderViewDevToolsAgentHost::ClearRenderViewHost() {
content::Source<RenderWidgetHost>(render_view_host_));
render_view_host_ = NULL;
overrides_handler_->ClearRenderViewHost();
+ input_handler_->SetRenderViewHost(NULL);
+ page_handler_->SetRenderViewHost(NULL);
}
void RenderViewDevToolsAgentHost::DisconnectWebContents() {
diff --git a/content/browser/devtools/render_view_devtools_agent_host.h b/content/browser/devtools/render_view_devtools_agent_host.h
index 7b35388..089933c 100644
--- a/content/browser/devtools/render_view_devtools_agent_host.h
+++ b/content/browser/devtools/render_view_devtools_agent_host.h
@@ -11,6 +11,8 @@
#include "base/compiler_specific.h"
#include "base/memory/scoped_ptr.h"
#include "content/browser/devtools/ipc_devtools_agent_host.h"
+#include "content/browser/devtools/protocol/input_handler.h"
+#include "content/browser/devtools/protocol/page_handler.h"
#include "content/common/content_export.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
@@ -23,6 +25,7 @@ class CompositorFrameMetadata;
namespace content {
class DevToolsPowerHandler;
+class DevToolsProtocolHandlerImpl;
class DevToolsTracingHandler;
class RendererOverridesHandler;
class RenderViewHost;
@@ -104,6 +107,9 @@ class CONTENT_EXPORT RenderViewDevToolsAgentHost
void InnerClientDetachedFromRenderer();
RenderViewHostImpl* render_view_host_;
+ scoped_ptr<devtools::input::InputHandler> input_handler_;
+ scoped_ptr<devtools::page::PageHandler> page_handler_;
+ scoped_ptr<DevToolsProtocolHandlerImpl> handler_impl_;
scoped_ptr<RendererOverridesHandler> overrides_handler_;
scoped_ptr<DevToolsTracingHandler> tracing_handler_;
scoped_ptr<DevToolsPowerHandler> power_handler_;
diff --git a/content/browser/devtools/renderer_overrides_handler.cc b/content/browser/devtools/renderer_overrides_handler.cc
index 3c126ff..e0b45da 100644
--- a/content/browser/devtools/renderer_overrides_handler.cc
+++ b/content/browser/devtools/renderer_overrides_handler.cc
@@ -135,11 +135,6 @@ RendererOverridesHandler::RendererOverridesHandler()
&RendererOverridesHandler::PageNavigateToHistoryEntry,
base::Unretained(this)));
RegisterCommandHandler(
- devtools::Page::captureScreenshot::kName,
- base::Bind(
- &RendererOverridesHandler::PageCaptureScreenshot,
- base::Unretained(this)));
- RegisterCommandHandler(
devtools::Page::setTouchEmulationEnabled::kName,
base::Bind(
&RendererOverridesHandler::PageSetTouchEmulationEnabled,
@@ -174,11 +169,6 @@ RendererOverridesHandler::RendererOverridesHandler()
base::Bind(
&RendererOverridesHandler::PageSetColorPickerEnabled,
base::Unretained(this)));
- RegisterCommandHandler(
- devtools::Input::emulateTouchFromMouseEvent::kName,
- base::Bind(
- &RendererOverridesHandler::InputEmulateTouchFromMouseEvent,
- base::Unretained(this)));
mouse_event_callback_ = base::Bind(
&RendererOverridesHandler::HandleMouseEvent,
base::Unretained(this));
@@ -518,40 +508,6 @@ RendererOverridesHandler::PageNavigateToHistoryEntry(
}
scoped_refptr<DevToolsProtocol::Response>
-RendererOverridesHandler::PageCaptureScreenshot(
- scoped_refptr<DevToolsProtocol::Command> command) {
- if (!host_ || !host_->GetView())
- return command->InternalErrorResponse("Could not connect to view");
-
- host_->GetSnapshotFromBrowser(
- base::Bind(&RendererOverridesHandler::ScreenshotCaptured,
- weak_factory_.GetWeakPtr(), command));
- return command->AsyncResponsePromise();
-}
-
-void RendererOverridesHandler::ScreenshotCaptured(
- scoped_refptr<DevToolsProtocol::Command> command,
- const unsigned char* png_data,
- size_t png_size) {
- if (!png_data || !png_size) {
- SendAsyncResponse(
- command->InternalErrorResponse("Unable to capture screenshot"));
- return;
- }
-
- std::string base_64_data;
- base::Base64Encode(
- base::StringPiece(reinterpret_cast<const char*>(png_data), png_size),
- &base_64_data);
-
- base::DictionaryValue* response = new base::DictionaryValue();
- response->SetString(devtools::Page::screencastFrame::kParamData,
- base_64_data);
-
- SendAsyncResponse(command->SuccessResponse(response));
-}
-
-scoped_refptr<DevToolsProtocol::Response>
RendererOverridesHandler::PageSetTouchEmulationEnabled(
scoped_refptr<DevToolsProtocol::Command> command) {
base::DictionaryValue* params = command->params();
@@ -1191,137 +1147,6 @@ void RendererOverridesHandler::UpdateColorPickerCursor() {
host_->SetCursor(cursor);
}
-// Input agent handlers ------------------------------------------------------
-
-scoped_refptr<DevToolsProtocol::Response>
-RendererOverridesHandler::InputEmulateTouchFromMouseEvent(
- scoped_refptr<DevToolsProtocol::Command> command) {
- if (!screencast_command_.get())
- return command->InternalErrorResponse("Screencast should be turned on");
-
- base::DictionaryValue* params = command->params();
- if (!params)
- return command->NoSuchMethodErrorResponse();
-
- std::string type;
- if (!params->GetString(
- devtools::Input::emulateTouchFromMouseEvent::kParamType,
- &type)) {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamType);
- }
-
- blink::WebMouseWheelEvent wheel_event;
- blink::WebMouseEvent mouse_event;
- blink::WebMouseEvent* event = &mouse_event;
-
- if (type ==
- devtools::Input::emulateTouchFromMouseEvent::Type::kEnumMousePressed) {
- event->type = WebInputEvent::MouseDown;
- } else if (type ==
- devtools::Input::emulateTouchFromMouseEvent::Type::kEnumMouseReleased) {
- event->type = WebInputEvent::MouseUp;
- } else if (type ==
- devtools::Input::emulateTouchFromMouseEvent::Type::kEnumMouseMoved) {
- event->type = WebInputEvent::MouseMove;
- } else if (type ==
- devtools::Input::emulateTouchFromMouseEvent::Type::kEnumMouseWheel) {
- double deltaX = 0;
- double deltaY = 0;
- if (!params->GetDouble(
- devtools::Input::emulateTouchFromMouseEvent::kParamDeltaX,
- &deltaX)) {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamDeltaX);
- }
- if (!params->GetDouble(
- devtools::Input::emulateTouchFromMouseEvent::kParamDeltaY,
- &deltaY)) {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamDeltaY);
- }
- wheel_event.deltaX = static_cast<float>(deltaX);
- wheel_event.deltaY = static_cast<float>(deltaY);
- event = &wheel_event;
- event->type = WebInputEvent::MouseWheel;
- } else {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamType);
- }
-
- int modifiers = 0;
- if (params->GetInteger(
- devtools::Input::emulateTouchFromMouseEvent::kParamModifiers,
- &modifiers)) {
- if (modifiers & 1)
- event->modifiers |= WebInputEvent::AltKey;
- if (modifiers & 2)
- event->modifiers |= WebInputEvent::ControlKey;
- if (modifiers & 4)
- event->modifiers |= WebInputEvent::MetaKey;
- if (modifiers & 8)
- event->modifiers |= WebInputEvent::ShiftKey;
- }
-
- params->GetDouble(
- devtools::Input::emulateTouchFromMouseEvent::kParamTimestamp,
- &event->timeStampSeconds);
-
- if (!params->GetInteger(devtools::Input::emulateTouchFromMouseEvent::kParamX,
- &event->x)) {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamX);
- }
-
- if (!params->GetInteger(devtools::Input::emulateTouchFromMouseEvent::kParamY,
- &event->y)) {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamY);
- }
-
- event->windowX = event->x;
- event->windowY = event->y;
- event->globalX = event->x;
- event->globalY = event->y;
-
- params->GetInteger(
- devtools::Input::emulateTouchFromMouseEvent::kParamClickCount,
- &event->clickCount);
-
- std::string button;
- if (!params->GetString(
- devtools::Input::emulateTouchFromMouseEvent::kParamButton,
- &button)) {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamButton);
- }
-
- if (button == "none") {
- event->button = WebMouseEvent::ButtonNone;
- } else if (button == "left") {
- event->button = WebMouseEvent::ButtonLeft;
- event->modifiers |= WebInputEvent::LeftButtonDown;
- } else if (button == "middle") {
- event->button = WebMouseEvent::ButtonMiddle;
- event->modifiers |= WebInputEvent::MiddleButtonDown;
- } else if (button == "right") {
- event->button = WebMouseEvent::ButtonRight;
- event->modifiers |= WebInputEvent::RightButtonDown;
- } else {
- return command->InvalidParamResponse(
- devtools::Input::emulateTouchFromMouseEvent::kParamButton);
- }
-
- if (!host_)
- return command->InternalErrorResponse("Could not connect to view");
-
- if (event->type == WebInputEvent::MouseWheel)
- host_->ForwardWheelEvent(wheel_event);
- else
- host_->ForwardMouseEvent(mouse_event);
- return command->SuccessResponse(NULL);
-}
-
void RendererOverridesHandler::UpdateTouchEventEmulationState() {
if (!host_)
return;
diff --git a/content/browser/devtools/renderer_overrides_handler.h b/content/browser/devtools/renderer_overrides_handler.h
index b8bf255..988a7c2 100644
--- a/content/browser/devtools/renderer_overrides_handler.h
+++ b/content/browser/devtools/renderer_overrides_handler.h
@@ -82,8 +82,6 @@ class CONTENT_EXPORT RendererOverridesHandler
scoped_refptr<DevToolsProtocol::Command> command);
scoped_refptr<DevToolsProtocol::Response> PageSetTouchEmulationEnabled(
scoped_refptr<DevToolsProtocol::Command> command);
- scoped_refptr<DevToolsProtocol::Response> PageCaptureScreenshot(
- scoped_refptr<DevToolsProtocol::Command> command);
scoped_refptr<DevToolsProtocol::Response> PageCanEmulate(
scoped_refptr<DevToolsProtocol::Command> command);
scoped_refptr<DevToolsProtocol::Response> PageCanScreencast(
@@ -97,11 +95,6 @@ class CONTENT_EXPORT RendererOverridesHandler
scoped_refptr<DevToolsProtocol::Response> PageSetColorPickerEnabled(
scoped_refptr<DevToolsProtocol::Command>);
- void ScreenshotCaptured(
- scoped_refptr<DevToolsProtocol::Command> command,
- const unsigned char* png_data,
- size_t png_size);
-
void ScreencastFrameCaptured(
const std::string& format,
int quality,
@@ -121,10 +114,6 @@ class CONTENT_EXPORT RendererOverridesHandler
bool HandleMouseEvent(const blink::WebMouseEvent& event);
void UpdateColorPickerCursor();
- // Input domain.
- scoped_refptr<DevToolsProtocol::Response> InputEmulateTouchFromMouseEvent(
- scoped_refptr<DevToolsProtocol::Command> command);
-
void UpdateTouchEventEmulationState();
RenderViewHostImpl* host_;
diff --git a/content/content_browser.gypi b/content/content_browser.gypi
index 49cfd02..153d7ad 100644
--- a/content/content_browser.gypi
+++ b/content/content_browser.gypi
@@ -457,6 +457,24 @@
'browser/devtools/embedded_worker_devtools_agent_host.h',
'browser/devtools/embedded_worker_devtools_manager.cc',
'browser/devtools/embedded_worker_devtools_manager.h',
+ 'browser/devtools/protocol/devtools_protocol_client.cc',
+ 'browser/devtools/protocol/devtools_protocol_client.h',
+ 'browser/devtools/protocol/dom_handler.cc',
+ 'browser/devtools/protocol/dom_handler.h',
+ 'browser/devtools/protocol/input_handler.cc',
+ 'browser/devtools/protocol/input_handler.h',
+ 'browser/devtools/protocol/inspector_handler.cc',
+ 'browser/devtools/protocol/inspector_handler.h',
+ 'browser/devtools/protocol/network_handler.cc',
+ 'browser/devtools/protocol/network_handler.h',
+ 'browser/devtools/protocol/page_handler.cc',
+ 'browser/devtools/protocol/page_handler.h',
+ 'browser/devtools/protocol/power_handler.cc',
+ 'browser/devtools/protocol/power_handler.h',
+ 'browser/devtools/protocol/tracing_handler.cc',
+ 'browser/devtools/protocol/tracing_handler.h',
+ 'browser/devtools/protocol/worker_handler.cc',
+ 'browser/devtools/protocol/worker_handler.h',
'browser/devtools/render_view_devtools_agent_host.cc',
'browser/devtools/render_view_devtools_agent_host.h',
'browser/devtools/renderer_overrides_handler.cc',
@@ -1375,6 +1393,9 @@
# These files are generated by devtools_protocol_constants_generator.py.
'<(SHARED_INTERMEDIATE_DIR)/content/browser/devtools/devtools_protocol_constants.cc',
'<(SHARED_INTERMEDIATE_DIR)/content/browser/devtools/devtools_protocol_constants.h',
+ # These files are generated by devtools_protocol_handler_generator.py.
+ '<(SHARED_INTERMEDIATE_DIR)/content/browser/devtools/protocol/devtools_protocol_handler_impl.cc',
+ '<(SHARED_INTERMEDIATE_DIR)/content/browser/devtools/protocol/devtools_protocol_handler_impl.h',
],
'android_browser_sources': [
'browser/android/java/gin_java_bound_object.cc',
@@ -1608,6 +1629,7 @@
'app/resources/content_resources.gyp:content_resources',
'app/strings/content_strings.gyp:content_strings',
'browser/devtools/devtools_resources.gyp:devtools_resources',
+ 'browser/devtools/devtools.gyp:devtools_protocol_handler',
'content_common_mojo_bindings',
'../cc/cc.gyp:cc',
'../cc/cc.gyp:cc_surfaces',