1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
// Copyright 2012 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_SPELLCHECK_COMMON_SPELLCHECK_COMMON_H_
#define COMPONENTS_SPELLCHECK_COMMON_SPELLCHECK_COMMON_H_
#include <stddef.h>
#include <string>
#include <string_view>
#include <vector>
#include "components/spellcheck/common/spellcheck_result.h"
namespace base {
class FilePath;
}
namespace spellcheck {
// Short type for holding word replacements per individual language.
using PerLanguageSuggestions = std::vector<std::vector<std::u16string>>;
// Max number of dictionary suggestions.
static const int kMaxSuggestions = 5;
// Maximum number of words in the custom spellcheck dictionary that can be
// synced.
static const size_t kMaxSyncableDictionaryWords = 1300;
// Maximum number of bytes in a word that can be added to the custom spellcheck
// dictionary. When changing this value, also change the corresponding value in
// chrome/browser/resources/settings/languages_page/edit_dictionary_page.js
static const size_t kMaxCustomDictionaryWordBytes = 99;
base::FilePath GetVersionedFileName(std::string_view input_language,
const base::FilePath& dict_dir);
// Returns the spellcheck language that should be used for |language|. For
// example, converts "hu-HU" into "hu", because we have only one variant of
// Hungarian. Converts "en-US" into "en-US", because we have several variants of
// English dictionaries.
//
// Returns an empty string if no spellcheck language found. For example, there's
// no single dictionary for English, so this function returns an empty string
// for "en".
std::string GetCorrespondingSpellCheckLanguage(std::string_view language);
// Get SpellChecker supported languages.
std::vector<std::string> SpellCheckLanguages();
// Gets the ISO codes for the language and country of this |locale|. The
// |locale| is an ISO locale ID that may not include a country ID, e.g., "fr" or
// "de". This method converts the UI locale to a full locale ID and converts the
// full locale ID to an ISO language code and an ISO3 country code.
void GetISOLanguageCountryCodeFromLocale(const std::string& locale,
std::string* language_code,
std::string* country_code);
// Evenly fill |optional_suggestions| with a maximum of |kMaxSuggestions|
// suggestions from |suggestions_list|. suggestions_list[i][j] is the j-th
// suggestion from the i-th language's suggestions. |optional_suggestions|
// cannot be null.
void FillSuggestions(
const std::vector<std::vector<std::u16string>>& suggestions_list,
std::vector<std::u16string>* optional_suggestions);
} // namespace spellcheck
#endif // COMPONENTS_SPELLCHECK_COMMON_SPELLCHECK_COMMON_H_
|