Make the typed word a SuggestedWordInfo
That allows to carry the language information in an accurate manner. Bug: 18063142 Change-Id: I0bca8981372ae10648274095b18b26a3686b762b
This commit is contained in:
parent
7cca01aa1d
commit
a2cb2f36a6
5 changed files with 59 additions and 51 deletions
|
@ -1638,7 +1638,7 @@ public class LatinIME extends InputMethodService implements KeyboardActionListen
|
||||||
// Cache the auto-correction in accessibility code so we can speak it if the user
|
// Cache the auto-correction in accessibility code so we can speak it if the user
|
||||||
// touches a key that will insert it.
|
// touches a key that will insert it.
|
||||||
AccessibilityUtils.getInstance().setAutoCorrection(suggestedWords,
|
AccessibilityUtils.getInstance().setAutoCorrection(suggestedWords,
|
||||||
suggestedWords.mTypedWord);
|
suggestedWords.mTypedWordInfo.mWord);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Called from {@link SuggestionStripView} through the {@link SuggestionStripView#Listener}
|
// Called from {@link SuggestionStripView} through the {@link SuggestionStripView#Listener}
|
||||||
|
|
|
@ -133,11 +133,12 @@ public final class Suggest {
|
||||||
final SettingsValuesForSuggestion settingsValuesForSuggestion,
|
final SettingsValuesForSuggestion settingsValuesForSuggestion,
|
||||||
final int inputStyleIfNotPrediction, final boolean isCorrectionEnabled,
|
final int inputStyleIfNotPrediction, final boolean isCorrectionEnabled,
|
||||||
final int sequenceNumber, final OnGetSuggestedWordsCallback callback) {
|
final int sequenceNumber, final OnGetSuggestedWordsCallback callback) {
|
||||||
final String typedWord = wordComposer.getTypedWord();
|
final String typedWordString = wordComposer.getTypedWord();
|
||||||
final int trailingSingleQuotesCount = StringUtils.getTrailingSingleQuotesCount(typedWord);
|
final int trailingSingleQuotesCount =
|
||||||
|
StringUtils.getTrailingSingleQuotesCount(typedWordString);
|
||||||
final String consideredWord = trailingSingleQuotesCount > 0
|
final String consideredWord = trailingSingleQuotesCount > 0
|
||||||
? typedWord.substring(0, typedWord.length() - trailingSingleQuotesCount)
|
? typedWordString.substring(0, typedWordString.length() - trailingSingleQuotesCount)
|
||||||
: typedWord;
|
: typedWordString;
|
||||||
|
|
||||||
final SuggestionResults suggestionResults = mDictionaryFacilitator.getSuggestionResults(
|
final SuggestionResults suggestionResults = mDictionaryFacilitator.getSuggestionResults(
|
||||||
wordComposer, ngramContext, proximityInfo.getNativeProximityInfo(),
|
wordComposer, ngramContext, proximityInfo.getNativeProximityInfo(),
|
||||||
|
@ -206,17 +207,19 @@ public final class Suggest {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!TextUtils.isEmpty(typedWord)) {
|
final SuggestedWordInfo typedWordInfo = new SuggestedWordInfo(typedWordString,
|
||||||
suggestionsContainer.add(0, new SuggestedWordInfo(typedWord,
|
SuggestedWordInfo.MAX_SCORE, SuggestedWordInfo.KIND_TYPED,
|
||||||
SuggestedWordInfo.MAX_SCORE, SuggestedWordInfo.KIND_TYPED,
|
Dictionary.DICTIONARY_USER_TYPED,
|
||||||
Dictionary.DICTIONARY_USER_TYPED,
|
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
||||||
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */);
|
||||||
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */));
|
if (!TextUtils.isEmpty(typedWordString)) {
|
||||||
|
suggestionsContainer.add(0, typedWordInfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
final ArrayList<SuggestedWordInfo> suggestionsList;
|
final ArrayList<SuggestedWordInfo> suggestionsList;
|
||||||
if (DBG && !suggestionsContainer.isEmpty()) {
|
if (DBG && !suggestionsContainer.isEmpty()) {
|
||||||
suggestionsList = getSuggestionsInfoListWithDebugInfo(typedWord, suggestionsContainer);
|
suggestionsList = getSuggestionsInfoListWithDebugInfo(typedWordString,
|
||||||
|
suggestionsContainer);
|
||||||
} else {
|
} else {
|
||||||
suggestionsList = suggestionsContainer;
|
suggestionsList = suggestionsContainer;
|
||||||
}
|
}
|
||||||
|
@ -230,7 +233,7 @@ public final class Suggest {
|
||||||
inputStyle = inputStyleIfNotPrediction;
|
inputStyle = inputStyleIfNotPrediction;
|
||||||
}
|
}
|
||||||
callback.onGetSuggestedWords(new SuggestedWords(suggestionsList,
|
callback.onGetSuggestedWords(new SuggestedWords(suggestionsList,
|
||||||
suggestionResults.mRawSuggestions, typedWord,
|
suggestionResults.mRawSuggestions, typedWordInfo,
|
||||||
// TODO: this first argument is lying. If this is a whitelisted word which is an
|
// TODO: this first argument is lying. If this is a whitelisted word which is an
|
||||||
// actual word, it says typedWordValid = false, which looks wrong. We should either
|
// actual word, it says typedWordValid = false, which looks wrong. We should either
|
||||||
// rename the attribute or change the value.
|
// rename the attribute or change the value.
|
||||||
|
@ -286,12 +289,12 @@ public final class Suggest {
|
||||||
// (typedWordValid=true), not as an "auto correct word" (willAutoCorrect=false).
|
// (typedWordValid=true), not as an "auto correct word" (willAutoCorrect=false).
|
||||||
// Note that because this method is never used to get predictions, there is no need to
|
// Note that because this method is never used to get predictions, there is no need to
|
||||||
// modify inputType such in getSuggestedWordsForNonBatchInput.
|
// modify inputType such in getSuggestedWordsForNonBatchInput.
|
||||||
final String pseudoTypedWord = suggestionsContainer.isEmpty() ? null
|
final SuggestedWordInfo pseudoTypedWordInfo = suggestionsContainer.isEmpty() ? null
|
||||||
: suggestionsContainer.get(0).mWord;
|
: suggestionsContainer.get(0);
|
||||||
|
|
||||||
callback.onGetSuggestedWords(new SuggestedWords(suggestionsContainer,
|
callback.onGetSuggestedWords(new SuggestedWords(suggestionsContainer,
|
||||||
suggestionResults.mRawSuggestions,
|
suggestionResults.mRawSuggestions,
|
||||||
pseudoTypedWord,
|
pseudoTypedWordInfo,
|
||||||
true /* typedWordValid */,
|
true /* typedWordValid */,
|
||||||
false /* willAutoCorrect */,
|
false /* willAutoCorrect */,
|
||||||
false /* isObsoleteSuggestions */,
|
false /* isObsoleteSuggestions */,
|
||||||
|
|
|
@ -29,6 +29,7 @@ import java.util.Arrays;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
import javax.annotation.Nonnull;
|
||||||
|
import javax.annotation.Nullable;
|
||||||
|
|
||||||
public class SuggestedWords {
|
public class SuggestedWords {
|
||||||
public static final int INDEX_OF_TYPED_WORD = 0;
|
public static final int INDEX_OF_TYPED_WORD = 0;
|
||||||
|
@ -54,7 +55,8 @@ public class SuggestedWords {
|
||||||
false /* typedWordValid */, false /* willAutoCorrect */,
|
false /* typedWordValid */, false /* willAutoCorrect */,
|
||||||
false /* isObsoleteSuggestions */, INPUT_STYLE_NONE, NOT_A_SEQUENCE_NUMBER);
|
false /* isObsoleteSuggestions */, INPUT_STYLE_NONE, NOT_A_SEQUENCE_NUMBER);
|
||||||
|
|
||||||
public final String mTypedWord;
|
@Nullable
|
||||||
|
public final SuggestedWordInfo mTypedWordInfo;
|
||||||
public final boolean mTypedWordValid;
|
public final boolean mTypedWordValid;
|
||||||
// Note: this INCLUDES cases where the word will auto-correct to itself. A good definition
|
// Note: this INCLUDES cases where the word will auto-correct to itself. A good definition
|
||||||
// of what this flag means would be "the top suggestion is strong enough to auto-correct",
|
// of what this flag means would be "the top suggestion is strong enough to auto-correct",
|
||||||
|
@ -65,12 +67,14 @@ public class SuggestedWords {
|
||||||
// INPUT_STYLE_* constants above.
|
// INPUT_STYLE_* constants above.
|
||||||
public final int mInputStyle;
|
public final int mInputStyle;
|
||||||
public final int mSequenceNumber; // Sequence number for auto-commit.
|
public final int mSequenceNumber; // Sequence number for auto-commit.
|
||||||
|
@Nonnull
|
||||||
protected final ArrayList<SuggestedWordInfo> mSuggestedWordInfoList;
|
protected final ArrayList<SuggestedWordInfo> mSuggestedWordInfoList;
|
||||||
|
@Nullable
|
||||||
public final ArrayList<SuggestedWordInfo> mRawSuggestions;
|
public final ArrayList<SuggestedWordInfo> mRawSuggestions;
|
||||||
|
|
||||||
public SuggestedWords(final ArrayList<SuggestedWordInfo> suggestedWordInfoList,
|
public SuggestedWords(@Nonnull final ArrayList<SuggestedWordInfo> suggestedWordInfoList,
|
||||||
final ArrayList<SuggestedWordInfo> rawSuggestions,
|
@Nullable final ArrayList<SuggestedWordInfo> rawSuggestions,
|
||||||
final String typedWord,
|
@Nullable final SuggestedWordInfo typedWordInfo,
|
||||||
final boolean typedWordValid,
|
final boolean typedWordValid,
|
||||||
final boolean willAutoCorrect,
|
final boolean willAutoCorrect,
|
||||||
final boolean isObsoleteSuggestions,
|
final boolean isObsoleteSuggestions,
|
||||||
|
@ -83,7 +87,7 @@ public class SuggestedWords {
|
||||||
mIsObsoleteSuggestions = isObsoleteSuggestions;
|
mIsObsoleteSuggestions = isObsoleteSuggestions;
|
||||||
mInputStyle = inputStyle;
|
mInputStyle = inputStyle;
|
||||||
mSequenceNumber = sequenceNumber;
|
mSequenceNumber = sequenceNumber;
|
||||||
mTypedWord = typedWord;
|
mTypedWordInfo = typedWordInfo;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isEmpty() {
|
public boolean isEmpty() {
|
||||||
|
@ -199,14 +203,12 @@ public class SuggestedWords {
|
||||||
// Should get rid of the first one (what the user typed previously) from suggestions
|
// Should get rid of the first one (what the user typed previously) from suggestions
|
||||||
// and replace it with what the user currently typed.
|
// and replace it with what the user currently typed.
|
||||||
public static ArrayList<SuggestedWordInfo> getTypedWordAndPreviousSuggestions(
|
public static ArrayList<SuggestedWordInfo> getTypedWordAndPreviousSuggestions(
|
||||||
final String typedWord, final SuggestedWords previousSuggestions) {
|
@Nonnull final SuggestedWordInfo typedWordInfo,
|
||||||
|
@Nonnull final SuggestedWords previousSuggestions) {
|
||||||
final ArrayList<SuggestedWordInfo> suggestionsList = new ArrayList<>();
|
final ArrayList<SuggestedWordInfo> suggestionsList = new ArrayList<>();
|
||||||
final HashSet<String> alreadySeen = new HashSet<>();
|
final HashSet<String> alreadySeen = new HashSet<>();
|
||||||
suggestionsList.add(new SuggestedWordInfo(typedWord, SuggestedWordInfo.MAX_SCORE,
|
suggestionsList.add(typedWordInfo);
|
||||||
SuggestedWordInfo.KIND_TYPED, Dictionary.DICTIONARY_USER_TYPED,
|
alreadySeen.add(typedWordInfo.mWord);
|
||||||
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
|
||||||
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */));
|
|
||||||
alreadySeen.add(typedWord.toString());
|
|
||||||
final int previousSize = previousSuggestions.size();
|
final int previousSize = previousSuggestions.size();
|
||||||
for (int index = 1; index < previousSize; index++) {
|
for (int index = 1; index < previousSize; index++) {
|
||||||
final SuggestedWordInfo prevWordInfo = previousSuggestions.getInfo(index);
|
final SuggestedWordInfo prevWordInfo = previousSuggestions.getInfo(index);
|
||||||
|
@ -412,7 +414,7 @@ public class SuggestedWords {
|
||||||
SuggestedWordInfo.NOT_A_CONFIDENCE));
|
SuggestedWordInfo.NOT_A_CONFIDENCE));
|
||||||
}
|
}
|
||||||
return new SuggestedWords(newSuggestions, null /* rawSuggestions */,
|
return new SuggestedWords(newSuggestions, null /* rawSuggestions */,
|
||||||
newSuggestions.isEmpty() ? null : newSuggestions.get(0).mWord /* typedWord */,
|
newSuggestions.isEmpty() ? null : newSuggestions.get(0) /* typedWordInfo */,
|
||||||
mTypedWordValid, mWillAutoCorrect, mIsObsoleteSuggestions, INPUT_STYLE_TAIL_BATCH,
|
mTypedWordValid, mWillAutoCorrect, mIsObsoleteSuggestions, INPUT_STYLE_TAIL_BATCH,
|
||||||
NOT_A_SEQUENCE_NUMBER);
|
NOT_A_SEQUENCE_NUMBER);
|
||||||
}
|
}
|
||||||
|
|
|
@ -623,11 +623,7 @@ public final class InputLogic {
|
||||||
} else {
|
} else {
|
||||||
// We can't use suggestedWords.getWord(SuggestedWords.INDEX_OF_TYPED_WORD)
|
// We can't use suggestedWords.getWord(SuggestedWords.INDEX_OF_TYPED_WORD)
|
||||||
// because it may differ from mWordComposer.mTypedWord.
|
// because it may differ from mWordComposer.mTypedWord.
|
||||||
suggestedWordInfo = new SuggestedWordInfo(suggestedWords.mTypedWord,
|
suggestedWordInfo = suggestedWords.mTypedWordInfo;
|
||||||
SuggestedWordInfo.MAX_SCORE,
|
|
||||||
SuggestedWordInfo.KIND_TYPED, Dictionary.DICTIONARY_USER_TYPED,
|
|
||||||
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
|
||||||
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */);
|
|
||||||
}
|
}
|
||||||
mWordComposer.setAutoCorrection(suggestedWordInfo);
|
mWordComposer.setAutoCorrection(suggestedWordInfo);
|
||||||
}
|
}
|
||||||
|
@ -1414,14 +1410,19 @@ public final class InputLogic {
|
||||||
new OnGetSuggestedWordsCallback() {
|
new OnGetSuggestedWordsCallback() {
|
||||||
@Override
|
@Override
|
||||||
public void onGetSuggestedWords(final SuggestedWords suggestedWords) {
|
public void onGetSuggestedWords(final SuggestedWords suggestedWords) {
|
||||||
final String typedWord = mWordComposer.getTypedWord();
|
final String typedWordString = mWordComposer.getTypedWord();
|
||||||
|
final SuggestedWordInfo typedWordInfo = new SuggestedWordInfo(
|
||||||
|
typedWordString, SuggestedWordInfo.MAX_SCORE,
|
||||||
|
SuggestedWordInfo.KIND_TYPED, Dictionary.DICTIONARY_USER_TYPED,
|
||||||
|
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
||||||
|
SuggestedWordInfo.NOT_A_CONFIDENCE);
|
||||||
// Show new suggestions if we have at least one. Otherwise keep the old
|
// Show new suggestions if we have at least one. Otherwise keep the old
|
||||||
// suggestions with the new typed word. Exception: if the length of the
|
// suggestions with the new typed word. Exception: if the length of the
|
||||||
// typed word is <= 1 (after a deletion typically) we clear old suggestions.
|
// typed word is <= 1 (after a deletion typically) we clear old suggestions.
|
||||||
if (suggestedWords.size() > 1 || typedWord.length() <= 1) {
|
if (suggestedWords.size() > 1 || typedWordString.length() <= 1) {
|
||||||
holder.set(suggestedWords);
|
holder.set(suggestedWords);
|
||||||
} else {
|
} else {
|
||||||
holder.set(retrieveOlderSuggestions(typedWord, mSuggestedWords));
|
holder.set(retrieveOlderSuggestions(typedWordInfo, mSuggestedWords));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1493,13 +1494,14 @@ public final class InputLogic {
|
||||||
final int numberOfCharsInWordBeforeCursor = range.getNumberOfCharsInWordBeforeCursor();
|
final int numberOfCharsInWordBeforeCursor = range.getNumberOfCharsInWordBeforeCursor();
|
||||||
if (numberOfCharsInWordBeforeCursor > expectedCursorPosition) return;
|
if (numberOfCharsInWordBeforeCursor > expectedCursorPosition) return;
|
||||||
final ArrayList<SuggestedWordInfo> suggestions = new ArrayList<>();
|
final ArrayList<SuggestedWordInfo> suggestions = new ArrayList<>();
|
||||||
final String typedWord = range.mWord.toString();
|
final String typedWordString = range.mWord.toString();
|
||||||
suggestions.add(new SuggestedWordInfo(typedWord,
|
final SuggestedWordInfo typedWordInfo = new SuggestedWordInfo(typedWordString,
|
||||||
SuggestedWords.MAX_SUGGESTIONS + 1,
|
SuggestedWords.MAX_SUGGESTIONS + 1,
|
||||||
SuggestedWordInfo.KIND_TYPED, Dictionary.DICTIONARY_USER_TYPED,
|
SuggestedWordInfo.KIND_TYPED, Dictionary.DICTIONARY_USER_TYPED,
|
||||||
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
SuggestedWordInfo.NOT_AN_INDEX /* indexOfTouchPointOfSecondWord */,
|
||||||
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */));
|
SuggestedWordInfo.NOT_A_CONFIDENCE /* autoCommitFirstWordConfidence */);
|
||||||
if (!isResumableWord(settingsValues, typedWord)) {
|
suggestions.add(typedWordInfo);
|
||||||
|
if (!isResumableWord(settingsValues, typedWordString)) {
|
||||||
mSuggestionStripViewAccessor.setNeutralSuggestionStrip();
|
mSuggestionStripViewAccessor.setNeutralSuggestionStrip();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1507,7 +1509,7 @@ public final class InputLogic {
|
||||||
for (final SuggestionSpan span : range.getSuggestionSpansAtWord()) {
|
for (final SuggestionSpan span : range.getSuggestionSpansAtWord()) {
|
||||||
for (final String s : span.getSuggestions()) {
|
for (final String s : span.getSuggestions()) {
|
||||||
++i;
|
++i;
|
||||||
if (!TextUtils.equals(s, typedWord)) {
|
if (!TextUtils.equals(s, typedWordString)) {
|
||||||
suggestions.add(new SuggestedWordInfo(s,
|
suggestions.add(new SuggestedWordInfo(s,
|
||||||
SuggestedWords.MAX_SUGGESTIONS - i,
|
SuggestedWords.MAX_SUGGESTIONS - i,
|
||||||
SuggestedWordInfo.KIND_RESUMED, Dictionary.DICTIONARY_RESUMED,
|
SuggestedWordInfo.KIND_RESUMED, Dictionary.DICTIONARY_RESUMED,
|
||||||
|
@ -1517,11 +1519,11 @@ public final class InputLogic {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final int[] codePoints = StringUtils.toCodePointArray(typedWord);
|
final int[] codePoints = StringUtils.toCodePointArray(typedWordString);
|
||||||
mWordComposer.setComposingWord(codePoints,
|
mWordComposer.setComposingWord(codePoints,
|
||||||
mLatinIME.getCoordinatesForCurrentKeyboard(codePoints));
|
mLatinIME.getCoordinatesForCurrentKeyboard(codePoints));
|
||||||
mWordComposer.setCursorPositionWithinWord(
|
mWordComposer.setCursorPositionWithinWord(
|
||||||
typedWord.codePointCount(0, numberOfCharsInWordBeforeCursor));
|
typedWordString.codePointCount(0, numberOfCharsInWordBeforeCursor));
|
||||||
if (forStartInput) {
|
if (forStartInput) {
|
||||||
mConnection.maybeMoveTheCursorAroundAndRestoreToWorkaroundABug();
|
mConnection.maybeMoveTheCursorAroundAndRestoreToWorkaroundABug();
|
||||||
}
|
}
|
||||||
|
@ -1543,7 +1545,7 @@ public final class InputLogic {
|
||||||
// color of the word in the suggestion strip changes according to this parameter,
|
// color of the word in the suggestion strip changes according to this parameter,
|
||||||
// and false gives the correct color.
|
// and false gives the correct color.
|
||||||
final SuggestedWords suggestedWords = new SuggestedWords(suggestions,
|
final SuggestedWords suggestedWords = new SuggestedWords(suggestions,
|
||||||
null /* rawSuggestions */, typedWord, false /* typedWordValid */,
|
null /* rawSuggestions */, typedWordInfo, false /* typedWordValid */,
|
||||||
false /* willAutoCorrect */, false /* isObsoleteSuggestions */,
|
false /* willAutoCorrect */, false /* isObsoleteSuggestions */,
|
||||||
SuggestedWords.INPUT_STYLE_RECORRECTION, SuggestedWords.NOT_A_SEQUENCE_NUMBER);
|
SuggestedWords.INPUT_STYLE_RECORRECTION, SuggestedWords.NOT_A_SEQUENCE_NUMBER);
|
||||||
doShowSuggestionsAndClearAutoCorrectionIndicator(suggestedWords);
|
doShowSuggestionsAndClearAutoCorrectionIndicator(suggestedWords);
|
||||||
|
@ -1876,19 +1878,19 @@ public final class InputLogic {
|
||||||
* Make a {@link com.android.inputmethod.latin.SuggestedWords} object containing a typed word
|
* Make a {@link com.android.inputmethod.latin.SuggestedWords} object containing a typed word
|
||||||
* and obsolete suggestions.
|
* and obsolete suggestions.
|
||||||
* See {@link com.android.inputmethod.latin.SuggestedWords#getTypedWordAndPreviousSuggestions(
|
* See {@link com.android.inputmethod.latin.SuggestedWords#getTypedWordAndPreviousSuggestions(
|
||||||
* String, com.android.inputmethod.latin.SuggestedWords)}.
|
* SuggestedWordInfo, com.android.inputmethod.latin.SuggestedWords)}.
|
||||||
* @param typedWord The typed word as a string.
|
* @param typedWordInfo The typed word as a SuggestedWordInfo.
|
||||||
* @param previousSuggestedWords The previously suggested words.
|
* @param previousSuggestedWords The previously suggested words.
|
||||||
* @return Obsolete suggestions with the newly typed word.
|
* @return Obsolete suggestions with the newly typed word.
|
||||||
*/
|
*/
|
||||||
static SuggestedWords retrieveOlderSuggestions(final String typedWord,
|
static SuggestedWords retrieveOlderSuggestions(final SuggestedWordInfo typedWordInfo,
|
||||||
final SuggestedWords previousSuggestedWords) {
|
final SuggestedWords previousSuggestedWords) {
|
||||||
final SuggestedWords oldSuggestedWords = previousSuggestedWords.isPunctuationSuggestions()
|
final SuggestedWords oldSuggestedWords = previousSuggestedWords.isPunctuationSuggestions()
|
||||||
? SuggestedWords.getEmptyInstance() : previousSuggestedWords;
|
? SuggestedWords.getEmptyInstance() : previousSuggestedWords;
|
||||||
final ArrayList<SuggestedWords.SuggestedWordInfo> typedWordAndPreviousSuggestions =
|
final ArrayList<SuggestedWords.SuggestedWordInfo> typedWordAndPreviousSuggestions =
|
||||||
SuggestedWords.getTypedWordAndPreviousSuggestions(typedWord, oldSuggestedWords);
|
SuggestedWords.getTypedWordAndPreviousSuggestions(typedWordInfo, oldSuggestedWords);
|
||||||
return new SuggestedWords(typedWordAndPreviousSuggestions, null /* rawSuggestions */,
|
return new SuggestedWords(typedWordAndPreviousSuggestions, null /* rawSuggestions */,
|
||||||
typedWord, false /* typedWordValid */, false /* hasAutoCorrectionCandidate */,
|
typedWordInfo, false /* typedWordValid */, false /* hasAutoCorrectionCandidate */,
|
||||||
true /* isObsoleteSuggestions */, oldSuggestedWords.mInputStyle,
|
true /* isObsoleteSuggestions */, oldSuggestedWords.mInputStyle,
|
||||||
SuggestedWords.NOT_A_SEQUENCE_NUMBER);
|
SuggestedWords.NOT_A_SEQUENCE_NUMBER);
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,9 +89,10 @@ public class SuggestedWordsTests extends AndroidTestCase {
|
||||||
|
|
||||||
public void testGetTypedWordInfoOrNull() {
|
public void testGetTypedWordInfoOrNull() {
|
||||||
final String TYPED_WORD = "typed";
|
final String TYPED_WORD = "typed";
|
||||||
|
final SuggestedWordInfo TYPED_WORD_INFO = createTypedWordInfo(TYPED_WORD);
|
||||||
final int NUMBER_OF_ADDED_SUGGESTIONS = 5;
|
final int NUMBER_OF_ADDED_SUGGESTIONS = 5;
|
||||||
final ArrayList<SuggestedWordInfo> list = new ArrayList<>();
|
final ArrayList<SuggestedWordInfo> list = new ArrayList<>();
|
||||||
list.add(createTypedWordInfo(TYPED_WORD));
|
list.add(TYPED_WORD_INFO);
|
||||||
for (int i = 0; i < NUMBER_OF_ADDED_SUGGESTIONS; ++i) {
|
for (int i = 0; i < NUMBER_OF_ADDED_SUGGESTIONS; ++i) {
|
||||||
list.add(createCorrectionWordInfo(Integer.toString(i)));
|
list.add(createCorrectionWordInfo(Integer.toString(i)));
|
||||||
}
|
}
|
||||||
|
@ -99,7 +100,7 @@ public class SuggestedWordsTests extends AndroidTestCase {
|
||||||
// Make sure getTypedWordInfoOrNull() returns non-null object.
|
// Make sure getTypedWordInfoOrNull() returns non-null object.
|
||||||
final SuggestedWords wordsWithTypedWord = new SuggestedWords(
|
final SuggestedWords wordsWithTypedWord = new SuggestedWords(
|
||||||
list, null /* rawSuggestions */,
|
list, null /* rawSuggestions */,
|
||||||
TYPED_WORD,
|
TYPED_WORD_INFO,
|
||||||
false /* typedWordValid */,
|
false /* typedWordValid */,
|
||||||
false /* willAutoCorrect */,
|
false /* willAutoCorrect */,
|
||||||
false /* isObsoleteSuggestions */,
|
false /* isObsoleteSuggestions */,
|
||||||
|
|
Loading…
Reference in a new issue