| Index: components/search_engines/default_search_manager.cc
|
| diff --git a/components/search_engines/default_search_manager.cc b/components/search_engines/default_search_manager.cc
|
| index f30c0ff880289730afc1372c0b1e840943bb2527..b7fd42847b3d9878eb9238e496c5a446e2cda48a 100644
|
| --- a/components/search_engines/default_search_manager.cc
|
| +++ b/components/search_engines/default_search_manager.cc
|
| @@ -25,6 +25,7 @@
|
| #include "components/prefs/pref_value_map.h"
|
| #include "components/search_engines/search_engines_pref_names.h"
|
| #include "components/search_engines/template_url_data.h"
|
| +#include "components/search_engines/template_url_data_util.h"
|
| #include "components/search_engines/template_url_prepopulate_data.h"
|
|
|
| namespace {
|
| @@ -50,6 +51,8 @@ const char DefaultSearchManager::kSuggestionsURL[] = "suggestions_url";
|
| const char DefaultSearchManager::kInstantURL[] = "instant_url";
|
| const char DefaultSearchManager::kImageURL[] = "image_url";
|
| const char DefaultSearchManager::kNewTabURL[] = "new_tab_url";
|
| +const char DefaultSearchManager::kContextualSearchURL[] =
|
| + "contextual_search_url";
|
| const char DefaultSearchManager::kFaviconURL[] = "favicon_url";
|
| const char DefaultSearchManager::kOriginatingURL[] = "originating_url";
|
|
|
| @@ -158,58 +161,8 @@ void DefaultSearchManager::SetUserSelectedDefaultSearchEngine(
|
| NotifyObserver();
|
| return;
|
| }
|
| -
|
| - base::DictionaryValue url_dict;
|
| - url_dict.SetString(kID, base::Int64ToString(data.id));
|
| - url_dict.SetString(kShortName, data.short_name());
|
| - url_dict.SetString(kKeyword, data.keyword());
|
| - url_dict.SetInteger(kPrepopulateID, data.prepopulate_id);
|
| - url_dict.SetString(kSyncGUID, data.sync_guid);
|
| -
|
| - url_dict.SetString(kURL, data.url());
|
| - url_dict.SetString(kSuggestionsURL, data.suggestions_url);
|
| - url_dict.SetString(kInstantURL, data.instant_url);
|
| - url_dict.SetString(kImageURL, data.image_url);
|
| - url_dict.SetString(kNewTabURL, data.new_tab_url);
|
| - url_dict.SetString(kFaviconURL, data.favicon_url.spec());
|
| - url_dict.SetString(kOriginatingURL, data.originating_url.spec());
|
| -
|
| - url_dict.SetString(kSearchURLPostParams, data.search_url_post_params);
|
| - url_dict.SetString(kSuggestionsURLPostParams,
|
| - data.suggestions_url_post_params);
|
| - url_dict.SetString(kInstantURLPostParams, data.instant_url_post_params);
|
| - url_dict.SetString(kImageURLPostParams, data.image_url_post_params);
|
| -
|
| - url_dict.SetBoolean(kSafeForAutoReplace, data.safe_for_autoreplace);
|
| -
|
| - url_dict.SetString(kDateCreated,
|
| - base::Int64ToString(data.date_created.ToInternalValue()));
|
| - url_dict.SetString(kLastModified,
|
| - base::Int64ToString(data.last_modified.ToInternalValue()));
|
| - url_dict.SetInteger(kUsageCount, data.usage_count);
|
| -
|
| - std::unique_ptr<base::ListValue> alternate_urls(new base::ListValue);
|
| - for (std::vector<std::string>::const_iterator it =
|
| - data.alternate_urls.begin();
|
| - it != data.alternate_urls.end(); ++it) {
|
| - alternate_urls->AppendString(*it);
|
| - }
|
| - url_dict.Set(kAlternateURLs, alternate_urls.release());
|
| -
|
| - std::unique_ptr<base::ListValue> encodings(new base::ListValue);
|
| - for (std::vector<std::string>::const_iterator it =
|
| - data.input_encodings.begin();
|
| - it != data.input_encodings.end(); ++it) {
|
| - encodings->AppendString(*it);
|
| - }
|
| - url_dict.Set(kInputEncodings, encodings.release());
|
| -
|
| - url_dict.SetString(kSearchTermsReplacementKey,
|
| - data.search_terms_replacement_key);
|
| -
|
| - url_dict.SetBoolean(kCreatedByPolicy, data.created_by_policy);
|
| -
|
| - pref_service_->Set(kDefaultSearchProviderDataPrefName, url_dict);
|
| + pref_service_->Set(kDefaultSearchProviderDataPrefName,
|
| + *TemplateURLDataToDictionary(data));
|
| }
|
|
|
| void DefaultSearchManager::SetExtensionControlledDefaultSearchEngine(
|
| @@ -307,97 +260,11 @@ void DefaultSearchManager::LoadDefaultSearchEngineFromPrefs() {
|
| return;
|
| }
|
|
|
| - std::string search_url;
|
| - base::string16 keyword;
|
| - url_dict->GetString(kURL, &search_url);
|
| - url_dict->GetString(kKeyword, &keyword);
|
| - if (search_url.empty() || keyword.empty())
|
| + auto turl_data = TemplateURLDataFromDictionary(*url_dict);
|
| + if (!turl_data)
|
| return;
|
|
|
| - prefs_default_search_.reset(new TemplateURLData);
|
| - prefs_default_search_->SetKeyword(keyword);
|
| - prefs_default_search_->SetURL(search_url);
|
| -
|
| - std::string id;
|
| - url_dict->GetString(kID, &id);
|
| - base::StringToInt64(id, &prefs_default_search_->id);
|
| - base::string16 short_name;
|
| - url_dict->GetString(kShortName, &short_name);
|
| - prefs_default_search_->SetShortName(short_name);
|
| - url_dict->GetInteger(kPrepopulateID, &prefs_default_search_->prepopulate_id);
|
| - url_dict->GetString(kSyncGUID, &prefs_default_search_->sync_guid);
|
| -
|
| - url_dict->GetString(kSuggestionsURL, &prefs_default_search_->suggestions_url);
|
| - url_dict->GetString(kInstantURL, &prefs_default_search_->instant_url);
|
| - url_dict->GetString(kImageURL, &prefs_default_search_->image_url);
|
| - url_dict->GetString(kNewTabURL, &prefs_default_search_->new_tab_url);
|
| -
|
| - std::string favicon_url;
|
| - std::string originating_url;
|
| - url_dict->GetString(kFaviconURL, &favicon_url);
|
| - url_dict->GetString(kOriginatingURL, &originating_url);
|
| - prefs_default_search_->favicon_url = GURL(favicon_url);
|
| - prefs_default_search_->originating_url = GURL(originating_url);
|
| -
|
| - url_dict->GetString(kSearchURLPostParams,
|
| - &prefs_default_search_->search_url_post_params);
|
| - url_dict->GetString(kSuggestionsURLPostParams,
|
| - &prefs_default_search_->suggestions_url_post_params);
|
| - url_dict->GetString(kInstantURLPostParams,
|
| - &prefs_default_search_->instant_url_post_params);
|
| - url_dict->GetString(kImageURLPostParams,
|
| - &prefs_default_search_->image_url_post_params);
|
| -
|
| - url_dict->GetBoolean(kSafeForAutoReplace,
|
| - &prefs_default_search_->safe_for_autoreplace);
|
| -
|
| - std::string date_created_str;
|
| - std::string last_modified_str;
|
| - url_dict->GetString(kDateCreated, &date_created_str);
|
| - url_dict->GetString(kLastModified, &last_modified_str);
|
| -
|
| - int64_t date_created = 0;
|
| - if (base::StringToInt64(date_created_str, &date_created)) {
|
| - prefs_default_search_->date_created =
|
| - base::Time::FromInternalValue(date_created);
|
| - }
|
| -
|
| - int64_t last_modified = 0;
|
| - if (base::StringToInt64(date_created_str, &last_modified)) {
|
| - prefs_default_search_->last_modified =
|
| - base::Time::FromInternalValue(last_modified);
|
| - }
|
| -
|
| - url_dict->GetInteger(kUsageCount, &prefs_default_search_->usage_count);
|
| -
|
| - const base::ListValue* alternate_urls = NULL;
|
| - if (url_dict->GetList(kAlternateURLs, &alternate_urls)) {
|
| - for (base::ListValue::const_iterator it = alternate_urls->begin();
|
| - it != alternate_urls->end();
|
| - ++it) {
|
| - std::string alternate_url;
|
| - if ((*it)->GetAsString(&alternate_url))
|
| - prefs_default_search_->alternate_urls.push_back(alternate_url);
|
| - }
|
| - }
|
| -
|
| - const base::ListValue* encodings = NULL;
|
| - if (url_dict->GetList(kInputEncodings, &encodings)) {
|
| - for (base::ListValue::const_iterator it = encodings->begin();
|
| - it != encodings->end();
|
| - ++it) {
|
| - std::string encoding;
|
| - if ((*it)->GetAsString(&encoding))
|
| - prefs_default_search_->input_encodings.push_back(encoding);
|
| - }
|
| - }
|
| -
|
| - url_dict->GetString(kSearchTermsReplacementKey,
|
| - &prefs_default_search_->search_terms_replacement_key);
|
| -
|
| - url_dict->GetBoolean(kCreatedByPolicy,
|
| - &prefs_default_search_->created_by_policy);
|
| -
|
| + prefs_default_search_ = std::move(turl_data);
|
| MergePrefsDataWithPrepopulated();
|
| }
|
|
|
|
|