* commit 'ea3a2f28ab602d1e2b7d1540c1863638832ec83a': Don't auto-correct to non-whitelist shortcuts
This commit is contained in:
commit
e1e95fd2e4
2 changed files with 5 additions and 3 deletions
|
@ -286,14 +286,16 @@ public final class Suggest {
|
||||||
// the word *would* have been auto-corrected.
|
// the word *would* have been auto-corrected.
|
||||||
if (!isCorrectionEnabled || !allowsToBeAutoCorrected || !wordComposer.isComposingWord()
|
if (!isCorrectionEnabled || !allowsToBeAutoCorrected || !wordComposer.isComposingWord()
|
||||||
|| suggestionsSet.isEmpty() || wordComposer.hasDigits()
|
|| suggestionsSet.isEmpty() || wordComposer.hasDigits()
|
||||||
|| wordComposer.isMostlyCaps() || wordComposer.isResumed()
|
|| wordComposer.isMostlyCaps() || wordComposer.isResumed() || !hasMainDictionary()
|
||||||
|| !hasMainDictionary()) {
|
|| SuggestedWordInfo.KIND_SHORTCUT == suggestionsSet.first().mKind) {
|
||||||
// If we don't have a main dictionary, we never want to auto-correct. The reason for
|
// If we don't have a main dictionary, we never want to auto-correct. The reason for
|
||||||
// this is, the user may have a contact whose name happens to match a valid word in
|
// this is, the user may have a contact whose name happens to match a valid word in
|
||||||
// their language, and it will unexpectedly auto-correct. For example, if the user
|
// their language, and it will unexpectedly auto-correct. For example, if the user
|
||||||
// types in English with no dictionary and has a "Will" in their contact list, "will"
|
// types in English with no dictionary and has a "Will" in their contact list, "will"
|
||||||
// would always auto-correct to "Will" which is unwanted. Hence, no main dict => no
|
// would always auto-correct to "Will" which is unwanted. Hence, no main dict => no
|
||||||
// auto-correct.
|
// auto-correct.
|
||||||
|
// Also, shortcuts should never auto-correct unless they are whitelist entries.
|
||||||
|
// TODO: we may want to have shortcut-only entries auto-correct in the future.
|
||||||
hasAutoCorrection = false;
|
hasAutoCorrection = false;
|
||||||
} else {
|
} else {
|
||||||
hasAutoCorrection = AutoCorrectionUtils.suggestionExceedsAutoCorrectionThreshold(
|
hasAutoCorrection = AutoCorrectionUtils.suggestionExceedsAutoCorrectionThreshold(
|
||||||
|
|
|
@ -44,7 +44,7 @@ class ShortcutUtils {
|
||||||
shortcutScore = finalScore;
|
shortcutScore = finalScore;
|
||||||
// Protection against int underflow
|
// Protection against int underflow
|
||||||
shortcutScore = max(S_INT_MIN + 1, shortcutScore) - 1;
|
shortcutScore = max(S_INT_MIN + 1, shortcutScore) - 1;
|
||||||
kind = Dictionary::KIND_CORRECTION;
|
kind = Dictionary::KIND_SHORTCUT;
|
||||||
}
|
}
|
||||||
outputTypes[outputWordIndex] = kind;
|
outputTypes[outputWordIndex] = kind;
|
||||||
frequencies[outputWordIndex] = shortcutScore;
|
frequencies[outputWordIndex] = shortcutScore;
|
||||||
|
|
Loading…
Reference in a new issue