diff options
-rw-r--r-- | chrome/browser/spellchecker.cc | 44 | ||||
-rw-r--r-- | chrome/browser/spellchecker.h | 5 |
2 files changed, 46 insertions, 3 deletions
diff --git a/chrome/browser/spellchecker.cc b/chrome/browser/spellchecker.cc index 186791a..d5a8a6c 100644 --- a/chrome/browser/spellchecker.cc +++ b/chrome/browser/spellchecker.cc @@ -194,12 +194,50 @@ void SpellChecker::RegisterUserPrefs(PrefService* prefs) { IDS_SPELLCHECK_DICTIONARY); } +std::wstring SpellChecker::GetVersionedFileName(const std::wstring& language, + const std::wstring& dict_dir) { + // The default version string currently in use. + static const wchar_t kDefaultVersionString[] = L"-1-1"; + + // Use this struct to insert version strings for dictionary files which have + // special version strings, other than the default version string. + // For de-DE, we are currently using de-DE-1-1-1 for versioning, because + // de-DE-1-1.bdic, in the download server, corresponds to a less used + // dictionary. This version, i.e., de-DE-1-1-1.bdic, is actually renamed + // from de-DE-neu-1-1.bic. + static const struct { + // The language input. + const char* language; + + // The corresponding version. + const char* version; + } special_version_string[] = { + "de-DE", "-1-1-1", + }; + + // Generate the bdict file name using default version string or special + // version string, depending on the language. + std::wstring versioned_bdict_file_name(language + kDefaultVersionString + + L".bdic"); + std::string language_string(WideToUTF8(language)); + for (int i = 0; i < arraysize(special_version_string); i++ ) { + if (language_string.compare(special_version_string[i].language) == 0) { + versioned_bdict_file_name = + language + UTF8ToWide(special_version_string[i].version) + L".bdic"; + break; + } + } + + std::wstring bdict_file_name(dict_dir); + file_util::AppendToPath(&bdict_file_name, versioned_bdict_file_name); + return bdict_file_name; +} + SpellChecker::SpellChecker(const std::wstring& dict_dir, const std::wstring& language, URLRequestContext* request_context, const std::wstring& custom_dictionary_file_name) - : bdict_file_name_(dict_dir), - custom_dictionary_file_name_(custom_dictionary_file_name), + : custom_dictionary_file_name_(custom_dictionary_file_name), bdict_file_(NULL), bdict_mapping_(NULL), bdict_mapped_data_(NULL), @@ -223,7 +261,7 @@ SpellChecker::SpellChecker(const std::wstring& dict_dir, file_loop_ = file_thread->message_loop(); // Get the path to the spellcheck file. - file_util::AppendToPath(&bdict_file_name_, language + L".bdic"); + bdict_file_name_ = GetVersionedFileName(language, dict_dir); // Get the path to the custom dictionary file. if (custom_dictionary_file_name_.empty()) { diff --git a/chrome/browser/spellchecker.h b/chrome/browser/spellchecker.h index 932d3c9..526f38a 100644 --- a/chrome/browser/spellchecker.h +++ b/chrome/browser/spellchecker.h @@ -90,6 +90,11 @@ class SpellChecker : public base::RefCountedThreadSafe<SpellChecker> { // (e.g. "word:word"). bool IsValidContraction(const std::wstring& word); + // Return the file name of the dictionary, including the path and the version + // numbers. + std::wstring GetVersionedFileName(const std::wstring& language, + const std::wstring& dict_dir); + // Path to the spellchecker file. std::wstring bdict_file_name_; |