From 2ebaebb603620f18ba231bda684f9af392c76923 Mon Sep 17 00:00:00 2001 From: Charles Kerr Date: Fri, 2 Feb 2024 12:25:58 -0600 Subject: [PATCH] refactor: replace use of deprecated `base::JSONWriter::WriteJson()` (#41215) * refactor: use base::WriteJson() in ListValueToNSArray() refactor: use base::WriteJson() in DictionaryValueToNSDictionary() * refactor: use base::WriteJson() in Debugger::SendCommand() * refactor: use base::WriteJson() in ScriptingExecuteScriptFunction::Run() * refactor: use base::WriteJson() in HandleAccessibilityRequestCallback() --- shell/browser/api/electron_api_debugger.cc | 3 +-- .../extensions/api/scripting/scripting_api.cc | 7 ++++--- shell/browser/mac/dict_util.mm | 12 ++++++------ shell/browser/ui/webui/accessibility_ui.cc | 7 ++----- 4 files changed, 13 insertions(+), 16 deletions(-) diff --git a/shell/browser/api/electron_api_debugger.cc b/shell/browser/api/electron_api_debugger.cc index 1148b84aa222..fddd8dd36e06 100755 --- a/shell/browser/api/electron_api_debugger.cc +++ b/shell/browser/api/electron_api_debugger.cc @@ -159,8 +159,7 @@ v8::Local Debugger::SendCommand(gin::Arguments* args) { request.Set("sessionId", session_id); } - std::string json_args; - base::JSONWriter::Write(request, &json_args); + const auto json_args = base::WriteJson(request).value_or(""); agent_host_->DispatchProtocolMessage( this, base::as_bytes(base::make_span(json_args))); diff --git a/shell/browser/extensions/api/scripting/scripting_api.cc b/shell/browser/extensions/api/scripting/scripting_api.cc index 2024e3644306..069d70d98044 100644 --- a/shell/browser/extensions/api/scripting/scripting_api.cc +++ b/shell/browser/extensions/api/scripting/scripting_api.cc @@ -631,10 +631,11 @@ ExtensionFunction::ResponseAction ScriptingExecuteScriptFunction::Run() { std::vector string_args; string_args.reserve(injection_.args->size()); for (const auto& arg : *injection_.args) { - std::string json; - if (!base::JSONWriter::Write(arg, &json)) + if (auto json = base::WriteJson(arg)) { + string_args.push_back(std::move(*json)); + } else { return RespondNow(Error("Unserializable argument passed.")); - string_args.push_back(std::move(json)); + } } args_expression = base::JoinString(string_args, ","); } diff --git a/shell/browser/mac/dict_util.mm b/shell/browser/mac/dict_util.mm index dec0d95069e2..71230292784a 100644 --- a/shell/browser/mac/dict_util.mm +++ b/shell/browser/mac/dict_util.mm @@ -13,10 +13,10 @@ namespace electron { NSArray* ListValueToNSArray(const base::Value::List& value) { - std::string json; - if (!base::JSONWriter::Write(base::ValueView{value}, &json)) + const auto json = base::WriteJson(value); + if (!json.has_value()) return nil; - NSData* jsonData = [NSData dataWithBytes:json.c_str() length:json.length()]; + NSData* jsonData = [NSData dataWithBytes:json->data() length:json->size()]; id obj = [NSJSONSerialization JSONObjectWithData:jsonData options:0 error:nil]; @@ -56,10 +56,10 @@ base::Value::List NSArrayToValue(NSArray* arr) { } NSDictionary* DictionaryValueToNSDictionary(const base::Value::Dict& value) { - std::string json; - if (!base::JSONWriter::Write(base::ValueView{value}, &json)) + const auto json = base::WriteJson(value); + if (!json.has_value()) return nil; - NSData* jsonData = [NSData dataWithBytes:json.c_str() length:json.length()]; + NSData* jsonData = [NSData dataWithBytes:json->data() length:json->size()]; id obj = [NSJSONSerialization JSONObjectWithData:jsonData options:0 error:nil]; diff --git a/shell/browser/ui/webui/accessibility_ui.cc b/shell/browser/ui/webui/accessibility_ui.cc index ca82ec76b0ed..7d98de77cfae 100644 --- a/shell/browser/ui/webui/accessibility_ui.cc +++ b/shell/browser/ui/webui/accessibility_ui.cc @@ -295,11 +295,8 @@ void HandleAccessibilityRequestCallback( data.Set(kBrowsersField, std::move(window_list)); - std::string json_string; - base::JSONWriter::Write(data, &json_string); - - std::move(callback).Run( - base::MakeRefCounted(std::move(json_string))); + std::move(callback).Run(base::MakeRefCounted( + base::WriteJson(data).value_or(""))); } } // namespace