OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/spellchecker/spellcheck_service.h" | 5 #include "chrome/browser/spellchecker/spellcheck_service.h" |
6 | 6 |
7 #include "base/command_line.h" | |
7 #include "base/prefs/pref_member.h" | 8 #include "base/prefs/pref_member.h" |
8 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
9 #include "base/strings/string_split.h" | 10 #include "base/strings/string_split.h" |
10 #include "base/synchronization/waitable_event.h" | 11 #include "base/synchronization/waitable_event.h" |
11 #include "chrome/browser/spellchecker/spellcheck_factory.h" | 12 #include "chrome/browser/spellchecker/spellcheck_factory.h" |
12 #include "chrome/browser/spellchecker/spellcheck_host_metrics.h" | 13 #include "chrome/browser/spellchecker/spellcheck_host_metrics.h" |
13 #include "chrome/browser/spellchecker/spellcheck_hunspell_dictionary.h" | 14 #include "chrome/browser/spellchecker/spellcheck_hunspell_dictionary.h" |
14 #include "chrome/browser/spellchecker/spellcheck_platform_mac.h" | 15 #include "chrome/browser/spellchecker/spellcheck_platform_mac.h" |
15 #include "chrome/browser/spellchecker/spelling_service_client.h" | 16 #include "chrome/browser/spellchecker/spelling_service_client.h" |
17 #include "chrome/common/chrome_switches.h" | |
16 #include "chrome/common/pref_names.h" | 18 #include "chrome/common/pref_names.h" |
17 #include "chrome/common/spellcheck_messages.h" | 19 #include "chrome/common/spellcheck_messages.h" |
18 #include "components/user_prefs/user_prefs.h" | 20 #include "components/user_prefs/user_prefs.h" |
19 #include "content/public/browser/browser_context.h" | 21 #include "content/public/browser/browser_context.h" |
20 #include "content/public/browser/browser_thread.h" | 22 #include "content/public/browser/browser_thread.h" |
21 #include "content/public/browser/notification_service.h" | 23 #include "content/public/browser/notification_service.h" |
22 #include "content/public/browser/notification_types.h" | 24 #include "content/public/browser/notification_types.h" |
23 #include "content/public/browser/render_process_host.h" | 25 #include "content/public/browser/render_process_host.h" |
24 #include "ipc/ipc_platform_file.h" | 26 #include "ipc/ipc_platform_file.h" |
25 | 27 |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
68 content::NOTIFICATION_RENDERER_PROCESS_CREATED, | 70 content::NOTIFICATION_RENDERER_PROCESS_CREATED, |
69 content::NotificationService::AllSources()); | 71 content::NotificationService::AllSources()); |
70 } | 72 } |
71 | 73 |
72 SpellcheckService::~SpellcheckService() { | 74 SpellcheckService::~SpellcheckService() { |
73 // Remove pref observers | 75 // Remove pref observers |
74 pref_change_registrar_.RemoveAll(); | 76 pref_change_registrar_.RemoveAll(); |
75 } | 77 } |
76 | 78 |
77 // static | 79 // static |
78 int SpellcheckService::GetSpellCheckLanguages( | 80 std::set<int> SpellcheckService::GetSpellCheckLanguages( |
79 content::BrowserContext* context, | 81 content::BrowserContext* context, |
80 std::vector<std::string>* languages) { | 82 std::vector<std::string>* languages) { |
81 PrefService* prefs = user_prefs::UserPrefs::Get(context); | 83 PrefService* prefs = user_prefs::UserPrefs::Get(context); |
84 std::vector<std::string> dictionary_languages; | |
85 | |
86 const base::CommandLine* command_line = | |
87 base::CommandLine::ForCurrentProcess(); | |
88 if (command_line->HasSwitch(switches::kEnableMultilingualSpellChecker)) { | |
89 StringPrefMember dictionary_languages_pref; | |
please use gerrit instead
2015/02/23 18:51:48
You can use "dictionary_languages_pref" for both c
Klemen Forstnerič
2015/02/24 21:57:45
Done.
| |
90 dictionary_languages_pref.Init(prefs::kSpellCheckDictionaries, prefs); | |
91 | |
please use gerrit instead
2015/02/23 18:51:47
No need for this newline.
Klemen Forstnerič
2015/02/24 21:57:45
Done.
| |
92 base::SplitString( | |
93 dictionary_languages_pref.GetValue(), ',', &dictionary_languages); | |
please use gerrit instead
2015/02/23 18:51:47
You may want to put "static const char kDictionary
Klemen Forstnerič
2015/02/24 21:57:45
Done.
| |
94 } else { | |
95 StringPrefMember dictionary_language_pref; | |
96 dictionary_language_pref.Init(prefs::kSpellCheckDictionary, prefs); | |
97 | |
please use gerrit instead
2015/02/23 18:51:47
No need for this newline.
Klemen Forstnerič
2015/02/24 21:57:46
Done.
| |
98 dictionary_languages.push_back(dictionary_language_pref.GetValue()); | |
99 } | |
100 | |
101 std::vector<std::string> accept_languages; | |
102 | |
please use gerrit instead
2015/02/23 18:51:48
No need for this newline.
Klemen Forstnerič
2015/02/24 21:57:45
Done.
| |
82 StringPrefMember accept_languages_pref; | 103 StringPrefMember accept_languages_pref; |
83 StringPrefMember dictionary_language_pref; | |
84 accept_languages_pref.Init(prefs::kAcceptLanguages, prefs); | 104 accept_languages_pref.Init(prefs::kAcceptLanguages, prefs); |
85 dictionary_language_pref.Init(prefs::kSpellCheckDictionary, prefs); | |
86 std::string dictionary_language = dictionary_language_pref.GetValue(); | |
87 | |
88 // Now scan through the list of accept languages, and find possible mappings | |
89 // from this list to the existing list of spell check languages. | |
90 std::vector<std::string> accept_languages; | |
91 | 105 |
92 #if defined(OS_MACOSX) | 106 #if defined(OS_MACOSX) |
93 if (spellcheck_mac::SpellCheckerAvailable()) | 107 if (spellcheck_mac::SpellCheckerAvailable()) |
94 spellcheck_mac::GetAvailableLanguages(&accept_languages); | 108 spellcheck_mac::GetAvailableLanguages(&accept_languages); |
95 else | 109 else |
96 base::SplitString(accept_languages_pref.GetValue(), ',', &accept_languages); | 110 base::SplitString(accept_languages_pref.GetValue(), ',', &accept_languages); |
97 #else | 111 #else |
98 base::SplitString(accept_languages_pref.GetValue(), ',', &accept_languages); | 112 base::SplitString(accept_languages_pref.GetValue(), ',', &accept_languages); |
99 #endif // !OS_MACOSX | 113 #endif // !OS_MACOSX |
100 | 114 |
101 GetSpellCheckLanguagesFromAcceptLanguages( | 115 *languages = dictionary_languages; |
102 accept_languages, dictionary_language, languages); | 116 GetSpellCheckLanguagesFromAcceptLanguages(accept_languages, languages); |
103 | 117 |
104 for (size_t i = 0; i < languages->size(); ++i) { | 118 // Fill the set with the currently selected languages' indices. |
105 if ((*languages)[i] == dictionary_language) | 119 std::set<int> selected_language_indices; |
106 return i; | 120 for (std::size_t i = 0; i < dictionary_languages.size(); ++i) |
please use gerrit instead
2015/02/23 18:51:48
No need for "std::" before "size_t". If I missed a
Klemen Forstnerič
2015/02/24 21:57:46
Done.
| |
107 } | 121 selected_language_indices.insert(i); |
please use gerrit instead
2015/02/23 18:51:48
Add a comment that the the first |dictionary_langu
Klemen Forstnerič
2015/02/24 21:57:45
Done.
| |
108 return -1; | 122 |
123 return selected_language_indices; | |
109 } | 124 } |
110 | 125 |
111 // static | 126 // static |
112 void SpellcheckService::GetSpellCheckLanguagesFromAcceptLanguages( | 127 void SpellcheckService::GetSpellCheckLanguagesFromAcceptLanguages( |
113 const std::vector<std::string>& accept_languages, | 128 const std::vector<std::string>& accept_languages, |
114 const std::string& dictionary_language, | |
115 std::vector<std::string>* languages) { | 129 std::vector<std::string>* languages) { |
116 // The current dictionary language should be there. | |
117 languages->push_back(dictionary_language); | |
118 | 130 |
119 for (std::vector<std::string>::const_iterator i = accept_languages.begin(); | 131 for (const std::string& accept_language : accept_languages) { |
please use gerrit instead
2015/02/23 18:51:48
No need to refactor this. It's not directly relate
Klemen Forstnerič
2015/02/24 21:57:45
Done.
| |
120 i != accept_languages.end(); ++i) { | |
121 std::string language = | 132 std::string language = |
122 chrome::spellcheck_common::GetCorrespondingSpellCheckLanguage(*i); | 133 chrome::spellcheck_common::GetCorrespondingSpellCheckLanguage( |
134 accept_language); | |
123 if (!language.empty() && | 135 if (!language.empty() && |
124 std::find(languages->begin(), languages->end(), language) == | 136 std::find(languages->begin(), languages->end(), language) == |
125 languages->end()) { | 137 languages->end()) { |
126 languages->push_back(language); | 138 languages->push_back(language); |
127 } | 139 } |
128 } | 140 } |
129 } | 141 } |
130 | 142 |
131 // static | 143 // static |
132 bool SpellcheckService::SignalStatusEvent( | 144 bool SpellcheckService::SignalStatusEvent( |
(...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
279 hunspell_dictionary_->AddObserver(this); | 291 hunspell_dictionary_->AddObserver(this); |
280 hunspell_dictionary_->Load(); | 292 hunspell_dictionary_->Load(); |
281 } | 293 } |
282 | 294 |
283 void SpellcheckService::OnUseSpellingServiceChanged() { | 295 void SpellcheckService::OnUseSpellingServiceChanged() { |
284 bool enabled = pref_change_registrar_.prefs()->GetBoolean( | 296 bool enabled = pref_change_registrar_.prefs()->GetBoolean( |
285 prefs::kSpellCheckUseSpellingService); | 297 prefs::kSpellCheckUseSpellingService); |
286 if (metrics_) | 298 if (metrics_) |
287 metrics_->RecordSpellingServiceStats(enabled); | 299 metrics_->RecordSpellingServiceStats(enabled); |
288 } | 300 } |
OLD | NEW |