buildSpellCheckerMapLocked(mContext, mSpellCheckerList, mSpellCheckerMap, mSettings);
SpellCheckerInfo sci = getCurrentSpellChecker(null);
if (sci == null) {
- sci = findAvailSystemSpellCheckerLocked(null);
+ sci = findAvailSpellCheckerLocked(null);
if (sci != null) {
// Set the current spell checker if there is one or more spell checkers
// available. In this case, "sci" is the first one in the available spell
change == PACKAGE_PERMANENT_CHANGE || change == PACKAGE_TEMPORARY_CHANGE
// Package modified
|| isPackageModified(packageName)) {
- sci = findAvailSystemSpellCheckerLocked(packageName);
+ sci = findAvailSpellCheckerLocked(packageName);
if (sci != null) {
setCurrentSpellCheckerLocked(sci.getId());
}
mSpellCheckerBindGroups.clear();
}
- private SpellCheckerInfo findAvailSystemSpellCheckerLocked(String prefPackage) {
- // Filter the spell checker list to remove spell checker services that are not pre-installed
- ArrayList<SpellCheckerInfo> spellCheckerList = new ArrayList<>();
- for (SpellCheckerInfo sci : mSpellCheckerList) {
- if ((sci.getServiceInfo().applicationInfo.flags & ApplicationInfo.FLAG_SYSTEM) != 0) {
- spellCheckerList.add(sci);
- }
- }
-
- final int spellCheckersCount = spellCheckerList.size();
+ private SpellCheckerInfo findAvailSpellCheckerLocked(String prefPackage) {
+ final int spellCheckersCount = mSpellCheckerList.size();
if (spellCheckersCount == 0) {
Slog.w(TAG, "no available spell checker services found");
return null;
final SpellCheckerInfo sci = mSpellCheckerList.get(i);
if (prefPackage.equals(sci.getPackageName())) {
if (DBG) {
- Slog.d(TAG, "findAvailSystemSpellCheckerLocked: " + sci.getPackageName());
+ Slog.d(TAG, "findAvailSpellCheckerLocked: " + sci.getPackageName());
}
return sci;
}
final ArrayList<Locale> suitableLocales =
InputMethodUtils.getSuitableLocalesForSpellChecker(systemLocal);
if (DBG) {
- Slog.w(TAG, "findAvailSystemSpellCheckerLocked suitableLocales="
+ Slog.w(TAG, "findAvailSpellCheckerLocked suitableLocales="
+ Arrays.toString(suitableLocales.toArray(new Locale[suitableLocales.size()])));
}
final int localeCount = suitableLocales.size();