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

Unified Diff: chrome/browser/extensions/api/debugger/debugger_api.cc

Issue 11827026: Overhaul JSON Schema Compiler to support a number of features required to (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/debugger/debugger_api.cc
diff --git a/chrome/browser/extensions/api/debugger/debugger_api.cc b/chrome/browser/extensions/api/debugger/debugger_api.cc
index 23426917cb77b888d18df25c4e7a73e40ae33e9a..85549bb40c711b52e1da2ab3c4fc0da3a8c487ce 100644
--- a/chrome/browser/extensions/api/debugger/debugger_api.cc
+++ b/chrome/browser/extensions/api/debugger/debugger_api.cc
@@ -176,6 +176,25 @@ class AttachedClientHosts {
std::set<DevToolsClientHost*> client_hosts_;
};
+scoped_ptr<base::DictionaryValue> ValueMapToDictionary(
+ const std::map<std::string, linked_ptr<base::Value> >& values) {
+ scoped_ptr<base::DictionaryValue> dict(new base::DictionaryValue());
+ for (std::map<std::string, linked_ptr<base::Value> >::const_iterator it =
+ values.begin();
+ it != values.end(); ++it) {
+ dict->SetWithoutPathExpansion(it->first, it->second->DeepCopy());
+ }
+ return dict.Pass();
+}
+
+std::map<std::string, linked_ptr<base::Value> > DictionaryToValueMap(
+ const base::DictionaryValue& dict) {
+ std::map<std::string, linked_ptr<base::Value> > values;
+ for (DictionaryValue::Iterator it(dict); it.HasNext(); it.Advance())
+ values[it.key()] = make_linked_ptr(it.value().DeepCopy());
+ return values;
+}
+
} // namespace
ExtensionDevToolsClientHost::ExtensionDevToolsClientHost(
@@ -259,8 +278,9 @@ void ExtensionDevToolsClientHost::SendMessageToBackend(
protocol_request.SetInteger("id", request_id);
protocol_request.SetString("method", method);
if (command_params) {
- protocol_request.Set("params",
- command_params->additional_properties.DeepCopy());
+ protocol_request.Set(
+ "params",
+ ValueMapToDictionary(command_params->additional_properties).release());
}
std::string json_args;
@@ -335,7 +355,7 @@ void ExtensionDevToolsClientHost::DispatchOnInspectorFrontend(
OnEvent::Params params;
DictionaryValue* params_value;
if (dictionary->GetDictionary("params", &params_value))
- params.additional_properties.Swap(params_value);
+ params.additional_properties = DictionaryToValueMap(*params_value);
scoped_ptr<ListValue> args(OnEvent::Create(debuggee, method_name, params));
scoped_ptr<extensions::Event> event(new extensions::Event(
@@ -543,7 +563,7 @@ void SendCommandDebuggerFunction::SendResponseBody(
DictionaryValue* result_body;
SendCommand::Results::Result result;
if (response->GetDictionary("result", &result_body))
- result.additional_properties.Swap(result_body);
+ result.additional_properties = DictionaryToValueMap(*result_body);
results_ = SendCommand::Results::Create(result);
SendResponse(true);

Powered by Google App Engine
This is Rietveld 408576698