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

Side by Side Diff: chrome/browser/ui/webui/translate_internals/translate_internals_handler.cc

Issue 2812953002: Stop passing raw pointers to base::Value API in c/b/ui (Closed)
Patch Set: Rebased Created 3 years, 8 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/ui/webui/translate_internals/translate_internals_handle r.h" 5 #include "chrome/browser/ui/webui/translate_internals/translate_internals_handle r.h"
6 6
7 #include <map> 7 #include <map>
8 #include <utility>
8 #include <vector> 9 #include <vector>
9 10
10 #include "base/bind.h" 11 #include "base/bind.h"
11 #include "base/bind_helpers.h" 12 #include "base/bind_helpers.h"
13 #include "base/memory/ptr_util.h"
12 #include "base/values.h" 14 #include "base/values.h"
13 #include "chrome/browser/browser_process.h" 15 #include "chrome/browser/browser_process.h"
14 #include "chrome/browser/chrome_notification_types.h" 16 #include "chrome/browser/chrome_notification_types.h"
15 #include "chrome/browser/profiles/profile.h" 17 #include "chrome/browser/profiles/profile.h"
16 #include "chrome/browser/translate/chrome_translate_client.h" 18 #include "chrome/browser/translate/chrome_translate_client.h"
17 #include "chrome/browser/translate/translate_service.h" 19 #include "chrome/browser/translate/translate_service.h"
18 #include "chrome/common/pref_names.h" 20 #include "chrome/common/pref_names.h"
19 #include "components/prefs/pref_service.h" 21 #include "components/prefs/pref_service.h"
20 #include "components/translate/core/browser/translate_download_manager.h" 22 #include "components/translate/core/browser/translate_download_manager.h"
21 #include "components/translate/core/browser/translate_error_details.h" 23 #include "components/translate/core/browser/translate_error_details.h"
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
80 .ptr(); 82 .ptr();
81 content::WebContents* web_contents = 83 content::WebContents* web_contents =
82 content::Source<content::WebContents>(source).ptr(); 84 content::Source<content::WebContents>(source).ptr();
83 85
84 if (web_contents->GetBrowserContext()->IsOffTheRecord() || 86 if (web_contents->GetBrowserContext()->IsOffTheRecord() ||
85 !TranslateService::IsTranslatableURL(language_detection_details->url)) { 87 !TranslateService::IsTranslatableURL(language_detection_details->url)) {
86 return; 88 return;
87 } 89 }
88 90
89 base::DictionaryValue dict; 91 base::DictionaryValue dict;
90 dict.Set("time", 92 dict.Set("time", base::MakeUnique<base::Value>(
jdoerrie 2017/04/13 09:08:52 SetDouble
vabr (Chromium) 2017/04/13 12:03:15 Done.
91 new base::Value(language_detection_details->time.ToJsTime())); 93 language_detection_details->time.ToJsTime()));
92 dict.Set("url", new base::Value(language_detection_details->url.spec())); 94 dict.Set("url", base::MakeUnique<base::Value>(
jdoerrie 2017/04/13 09:08:52 SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
95 language_detection_details->url.spec()));
93 dict.Set("content_language", 96 dict.Set("content_language",
jdoerrie 2017/04/13 09:08:53 SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
94 new base::Value(language_detection_details->content_language)); 97 base::MakeUnique<base::Value>(
95 dict.Set("cld_language", 98 language_detection_details->content_language));
96 new base::Value(language_detection_details->cld_language)); 99 dict.Set("cld_language", base::MakeUnique<base::Value>(
jdoerrie 2017/04/13 09:08:52 SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
97 dict.Set("is_cld_reliable", 100 language_detection_details->cld_language));
98 new base::Value(language_detection_details->is_cld_reliable)); 101 dict.Set("is_cld_reliable", base::MakeUnique<base::Value>(
jdoerrie 2017/04/13 09:08:53 SetBoolean
vabr (Chromium) 2017/04/13 12:03:15 Done.
99 dict.Set("has_notranslate", 102 language_detection_details->is_cld_reliable));
100 new base::Value(language_detection_details->has_notranslate)); 103 dict.Set("has_notranslate", base::MakeUnique<base::Value>(
jdoerrie 2017/04/13 09:08:52 SetBoolean
vabr (Chromium) 2017/04/13 12:03:15 Done.
104 language_detection_details->has_notranslate));
101 dict.Set("html_root_language", 105 dict.Set("html_root_language",
jdoerrie 2017/04/13 09:08:53 SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
102 new base::Value(language_detection_details->html_root_language)); 106 base::MakeUnique<base::Value>(
107 language_detection_details->html_root_language));
103 dict.Set("adopted_language", 108 dict.Set("adopted_language",
jdoerrie 2017/04/13 09:08:52 SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
104 new base::Value(language_detection_details->adopted_language)); 109 base::MakeUnique<base::Value>(
105 dict.Set("content", new base::Value(language_detection_details->contents)); 110 language_detection_details->adopted_language));
111 dict.Set("content",
jdoerrie 2017/04/13 09:08:53 SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
112 base::MakeUnique<base::Value>(language_detection_details->contents));
106 SendMessageToJs("languageDetectionInfoAdded", dict); 113 SendMessageToJs("languageDetectionInfoAdded", dict);
107 } 114 }
108 115
109 void TranslateInternalsHandler::OnTranslateError( 116 void TranslateInternalsHandler::OnTranslateError(
110 const translate::TranslateErrorDetails& details) { 117 const translate::TranslateErrorDetails& details) {
111 base::DictionaryValue dict; 118 base::DictionaryValue dict;
112 dict.Set("time", new base::Value(details.time.ToJsTime())); 119 dict.Set("time", base::MakeUnique<base::Value>(details.time.ToJsTime()));
113 dict.Set("url", new base::Value(details.url.spec())); 120 dict.Set("url", base::MakeUnique<base::Value>(details.url.spec()));
114 dict.Set("error", new base::Value(details.error)); 121 dict.Set("error", base::MakeUnique<base::Value>(details.error));
jdoerrie 2017/04/13 09:08:52 SetDouble SetString SetInteger
vabr (Chromium) 2017/04/13 12:03:15 Done.
115 SendMessageToJs("translateErrorDetailsAdded", dict); 122 SendMessageToJs("translateErrorDetailsAdded", dict);
116 } 123 }
117 124
118 void TranslateInternalsHandler::OnTranslateEvent( 125 void TranslateInternalsHandler::OnTranslateEvent(
119 const translate::TranslateEventDetails& details) { 126 const translate::TranslateEventDetails& details) {
120 base::DictionaryValue dict; 127 base::DictionaryValue dict;
121 dict.Set("time", new base::Value(details.time.ToJsTime())); 128 dict.Set("time", base::MakeUnique<base::Value>(details.time.ToJsTime()));
122 dict.Set("filename", new base::Value(details.filename)); 129 dict.Set("filename", base::MakeUnique<base::Value>(details.filename));
123 dict.Set("line", new base::Value(details.line)); 130 dict.Set("line", base::MakeUnique<base::Value>(details.line));
124 dict.Set("message", new base::Value(details.message)); 131 dict.Set("message", base::MakeUnique<base::Value>(details.message));
jdoerrie 2017/04/13 09:08:52 SetDouble SetString SetInteger SetString
vabr (Chromium) 2017/04/13 12:03:15 Done.
125 SendMessageToJs("translateEventDetailsAdded", dict); 132 SendMessageToJs("translateEventDetailsAdded", dict);
126 } 133 }
127 134
128 void TranslateInternalsHandler::OnRemovePrefItem(const base::ListValue* args) { 135 void TranslateInternalsHandler::OnRemovePrefItem(const base::ListValue* args) {
129 content::WebContents* web_contents = web_ui()->GetWebContents(); 136 content::WebContents* web_contents = web_ui()->GetWebContents();
130 Profile* profile = 137 Profile* profile =
131 Profile::FromBrowserContext(web_contents->GetBrowserContext()); 138 Profile::FromBrowserContext(web_contents->GetBrowserContext());
132 PrefService* prefs = profile->GetOriginalProfile()->GetPrefs(); 139 PrefService* prefs = profile->GetOriginalProfile()->GetPrefs();
133 std::unique_ptr<translate::TranslatePrefs> translate_prefs( 140 std::unique_ptr<translate::TranslatePrefs> translate_prefs(
134 ChromeTranslateClient::CreateTranslatePrefs(prefs)); 141 ChromeTranslateClient::CreateTranslatePrefs(prefs));
(...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after
203 translate::TranslatePrefs::kPrefTranslateWhitelists, 210 translate::TranslatePrefs::kPrefTranslateWhitelists,
204 translate::TranslatePrefs::kPrefTranslateDeniedCount, 211 translate::TranslatePrefs::kPrefTranslateDeniedCount,
205 translate::TranslatePrefs::kPrefTranslateIgnoredCount, 212 translate::TranslatePrefs::kPrefTranslateIgnoredCount,
206 translate::TranslatePrefs::kPrefTranslateAcceptedCount, 213 translate::TranslatePrefs::kPrefTranslateAcceptedCount,
207 translate::TranslatePrefs::kPrefTranslateLastDeniedTimeForLanguage, 214 translate::TranslatePrefs::kPrefTranslateLastDeniedTimeForLanguage,
208 translate::TranslatePrefs::kPrefTranslateTooOftenDeniedForLanguage, 215 translate::TranslatePrefs::kPrefTranslateTooOftenDeniedForLanguage,
209 }; 216 };
210 for (const char* key : keys) { 217 for (const char* key : keys) {
211 const PrefService::Preference* pref = prefs->FindPreference(key); 218 const PrefService::Preference* pref = prefs->FindPreference(key);
212 if (pref) 219 if (pref)
213 dict.Set(key, pref->GetValue()->DeepCopy()); 220 dict.Set(key, base::MakeUnique<base::Value>(*pref->GetValue()));
214 } 221 }
215 222
216 SendMessageToJs("prefsUpdated", dict); 223 SendMessageToJs("prefsUpdated", dict);
217 } 224 }
218 225
219 void TranslateInternalsHandler::SendSupportedLanguagesToJs() { 226 void TranslateInternalsHandler::SendSupportedLanguagesToJs() {
220 base::DictionaryValue dict; 227 base::DictionaryValue dict;
221 228
222 std::vector<std::string> languages; 229 std::vector<std::string> languages;
223 translate::TranslateDownloadManager::GetSupportedLanguages(&languages); 230 translate::TranslateDownloadManager::GetSupportedLanguages(&languages);
224 base::Time last_updated = 231 base::Time last_updated =
225 translate::TranslateDownloadManager::GetSupportedLanguagesLastUpdated(); 232 translate::TranslateDownloadManager::GetSupportedLanguagesLastUpdated();
226 233
227 base::ListValue* languages_list = new base::ListValue(); 234 auto languages_list = base::MakeUnique<base::ListValue>();
228 base::ListValue* alpha_languages_list = new base::ListValue(); 235 auto alpha_languages_list = base::MakeUnique<base::ListValue>();
229 for (std::vector<std::string>::iterator it = languages.begin(); 236 for (std::vector<std::string>::iterator it = languages.begin();
230 it != languages.end(); ++it) { 237 it != languages.end(); ++it) {
231 const std::string& lang = *it; 238 const std::string& lang = *it;
232 languages_list->AppendString(lang); 239 languages_list->AppendString(lang);
233 if (translate::TranslateDownloadManager::IsAlphaLanguage(lang)) 240 if (translate::TranslateDownloadManager::IsAlphaLanguage(lang))
234 alpha_languages_list->AppendString(lang); 241 alpha_languages_list->AppendString(lang);
235 } 242 }
236 243
237 dict.Set("languages", languages_list); 244 dict.Set("languages", std::move(languages_list));
238 dict.Set("alpha_languages", alpha_languages_list); 245 dict.Set("alpha_languages", std::move(alpha_languages_list));
239 dict.Set("last_updated", new base::Value(last_updated.ToJsTime())); 246 dict.Set("last_updated",
jdoerrie 2017/04/13 09:08:52 SetDouble
vabr (Chromium) 2017/04/13 12:03:15 Done.
247 base::MakeUnique<base::Value>(last_updated.ToJsTime()));
240 SendMessageToJs("supportedLanguagesUpdated", dict); 248 SendMessageToJs("supportedLanguagesUpdated", dict);
241 } 249 }
242 250
243 void TranslateInternalsHandler::SendCountryToJs(bool was_updated) { 251 void TranslateInternalsHandler::SendCountryToJs(bool was_updated) {
244 std::string country; 252 std::string country;
245 variations::VariationsService* variations_service = 253 variations::VariationsService* variations_service =
246 g_browser_process->variations_service(); 254 g_browser_process->variations_service();
247 if (variations_service) 255 if (variations_service)
248 country = variations_service->GetStoredPermanentCountry(); 256 country = variations_service->GetStoredPermanentCountry();
249 257
250 base::DictionaryValue dict; 258 base::DictionaryValue dict;
251 if (!country.empty()) { 259 if (!country.empty()) {
252 dict.Set("country", new base::Value(country)); 260 dict.Set("country", base::MakeUnique<base::Value>(country));
253 dict.Set("update", new base::Value(was_updated)); 261 dict.Set("update", base::MakeUnique<base::Value>(was_updated));
jdoerrie 2017/04/13 09:08:53 SetString SetBoolean
vabr (Chromium) 2017/04/13 12:03:14 Done.
254 } 262 }
255 SendMessageToJs("countryUpdated", dict); 263 SendMessageToJs("countryUpdated", dict);
256 } 264 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698