2010-12-10 11:50:30 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2010 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
|
|
|
|
* use this file except in compliance with the License. You may obtain a copy of
|
|
|
|
* the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
|
|
* License for the specific language governing permissions and limitations under
|
|
|
|
* the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package com.android.inputmethod.latin;
|
|
|
|
|
2012-03-14 10:23:15 +00:00
|
|
|
import android.text.TextUtils;
|
2010-12-10 11:50:30 +00:00
|
|
|
import android.view.inputmethod.CompletionInfo;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
2012-03-14 10:23:15 +00:00
|
|
|
import java.util.Arrays;
|
2011-01-21 06:03:09 +00:00
|
|
|
import java.util.HashSet;
|
2010-12-10 11:50:30 +00:00
|
|
|
|
2012-09-27 09:16:16 +00:00
|
|
|
public final class SuggestedWords {
|
2012-08-21 07:34:55 +00:00
|
|
|
private static final ArrayList<SuggestedWordInfo> EMPTY_WORD_INFO_LIST =
|
|
|
|
CollectionUtils.newArrayList(0);
|
2012-03-14 06:33:47 +00:00
|
|
|
public static final SuggestedWords EMPTY = new SuggestedWords(
|
2012-08-21 07:34:55 +00:00
|
|
|
EMPTY_WORD_INFO_LIST, false, false, false, false, false);
|
2010-12-10 11:50:30 +00:00
|
|
|
|
|
|
|
public final boolean mTypedWordValid;
|
2012-06-28 10:45:24 +00:00
|
|
|
// 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",
|
|
|
|
// whether this exactly matches the user entry or not.
|
2012-06-28 10:27:48 +00:00
|
|
|
public final boolean mWillAutoCorrect;
|
2011-06-30 01:09:21 +00:00
|
|
|
public final boolean mIsPunctuationSuggestions;
|
2012-03-15 04:12:08 +00:00
|
|
|
public final boolean mIsObsoleteSuggestions;
|
2012-05-14 05:42:40 +00:00
|
|
|
public final boolean mIsPrediction;
|
2012-03-16 15:50:51 +00:00
|
|
|
private final ArrayList<SuggestedWordInfo> mSuggestedWordInfoList;
|
2010-12-10 11:50:30 +00:00
|
|
|
|
2012-03-16 15:50:51 +00:00
|
|
|
public SuggestedWords(final ArrayList<SuggestedWordInfo> suggestedWordInfoList,
|
2012-03-14 06:33:47 +00:00
|
|
|
final boolean typedWordValid,
|
2012-06-28 10:45:24 +00:00
|
|
|
final boolean willAutoCorrect,
|
2012-03-15 04:12:08 +00:00
|
|
|
final boolean isPunctuationSuggestions,
|
2012-05-14 05:42:40 +00:00
|
|
|
final boolean isObsoleteSuggestions,
|
|
|
|
final boolean isPrediction) {
|
2012-03-14 06:33:47 +00:00
|
|
|
mSuggestedWordInfoList = suggestedWordInfoList;
|
2010-12-10 11:50:30 +00:00
|
|
|
mTypedWordValid = typedWordValid;
|
2012-06-28 10:45:24 +00:00
|
|
|
mWillAutoCorrect = willAutoCorrect;
|
2012-03-14 06:33:47 +00:00
|
|
|
mIsPunctuationSuggestions = isPunctuationSuggestions;
|
2012-03-15 04:12:08 +00:00
|
|
|
mIsObsoleteSuggestions = isObsoleteSuggestions;
|
2012-05-14 05:42:40 +00:00
|
|
|
mIsPrediction = isPrediction;
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|
|
|
|
|
2012-10-03 05:06:44 +00:00
|
|
|
public boolean isEmpty() {
|
|
|
|
return mSuggestedWordInfoList.isEmpty();
|
|
|
|
}
|
|
|
|
|
2010-12-10 11:50:30 +00:00
|
|
|
public int size() {
|
2012-03-12 09:56:02 +00:00
|
|
|
return mSuggestedWordInfoList.size();
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|
|
|
|
|
2012-07-04 07:01:00 +00:00
|
|
|
public String getWord(int pos) {
|
2012-03-12 09:56:02 +00:00
|
|
|
return mSuggestedWordInfoList.get(pos).mWord;
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|
|
|
|
|
2012-04-02 07:33:24 +00:00
|
|
|
public SuggestedWordInfo getWordInfo(int pos) {
|
|
|
|
return mSuggestedWordInfoList.get(pos);
|
|
|
|
}
|
|
|
|
|
2011-08-04 05:38:22 +00:00
|
|
|
public SuggestedWordInfo getInfo(int pos) {
|
2012-03-15 06:10:07 +00:00
|
|
|
return mSuggestedWordInfoList.get(pos);
|
2011-08-04 05:38:22 +00:00
|
|
|
}
|
|
|
|
|
2012-03-05 10:54:21 +00:00
|
|
|
public boolean willAutoCorrect() {
|
2012-06-28 10:27:48 +00:00
|
|
|
return mWillAutoCorrect;
|
2012-03-05 13:08:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String toString() {
|
|
|
|
// Pretty-print method to help debug
|
|
|
|
return "SuggestedWords:"
|
|
|
|
+ " mTypedWordValid=" + mTypedWordValid
|
2012-06-28 10:45:24 +00:00
|
|
|
+ " mWillAutoCorrect=" + mWillAutoCorrect
|
2012-03-14 10:23:15 +00:00
|
|
|
+ " mIsPunctuationSuggestions=" + mIsPunctuationSuggestions
|
|
|
|
+ " words=" + Arrays.toString(mSuggestedWordInfoList.toArray());
|
2012-03-05 05:19:35 +00:00
|
|
|
}
|
|
|
|
|
2012-03-16 15:50:51 +00:00
|
|
|
public static ArrayList<SuggestedWordInfo> getFromApplicationSpecifiedCompletions(
|
2012-03-13 11:39:21 +00:00
|
|
|
final CompletionInfo[] infos) {
|
2012-08-21 07:34:55 +00:00
|
|
|
final ArrayList<SuggestedWordInfo> result = CollectionUtils.newArrayList();
|
2012-03-13 11:39:21 +00:00
|
|
|
for (CompletionInfo info : infos) {
|
2012-04-04 02:09:13 +00:00
|
|
|
if (null != info && info.getText() != null) {
|
2012-06-12 16:10:18 +00:00
|
|
|
result.add(new SuggestedWordInfo(info.getText(), SuggestedWordInfo.MAX_SCORE,
|
2012-06-27 09:17:28 +00:00
|
|
|
SuggestedWordInfo.KIND_APP_DEFINED, Dictionary.TYPE_APPLICATION_DEFINED));
|
2012-04-04 02:09:13 +00:00
|
|
|
}
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|
2012-03-13 11:39:21 +00:00
|
|
|
return result;
|
|
|
|
}
|
2010-12-10 11:50:30 +00:00
|
|
|
|
2012-03-13 11:39:21 +00:00
|
|
|
// Should get rid of the first one (what the user typed previously) from suggestions
|
|
|
|
// and replace it with what the user currently typed.
|
|
|
|
public static ArrayList<SuggestedWordInfo> getTypedWordAndPreviousSuggestions(
|
|
|
|
final CharSequence typedWord, final SuggestedWords previousSuggestions) {
|
2012-08-21 07:34:55 +00:00
|
|
|
final ArrayList<SuggestedWordInfo> suggestionsList = CollectionUtils.newArrayList();
|
|
|
|
final HashSet<String> alreadySeen = CollectionUtils.newHashSet();
|
2012-06-12 16:10:18 +00:00
|
|
|
suggestionsList.add(new SuggestedWordInfo(typedWord, SuggestedWordInfo.MAX_SCORE,
|
2012-06-27 09:17:28 +00:00
|
|
|
SuggestedWordInfo.KIND_TYPED, Dictionary.TYPE_USER_TYPED));
|
2012-03-13 11:39:21 +00:00
|
|
|
alreadySeen.add(typedWord.toString());
|
|
|
|
final int previousSize = previousSuggestions.size();
|
|
|
|
for (int pos = 1; pos < previousSize; pos++) {
|
2012-04-02 07:33:24 +00:00
|
|
|
final SuggestedWordInfo prevWordInfo = previousSuggestions.getWordInfo(pos);
|
|
|
|
final String prevWord = prevWordInfo.mWord.toString();
|
2012-03-13 11:39:21 +00:00
|
|
|
// Filter out duplicate suggestion.
|
|
|
|
if (!alreadySeen.contains(prevWord)) {
|
2012-04-02 07:33:24 +00:00
|
|
|
suggestionsList.add(prevWordInfo);
|
2012-03-13 11:39:21 +00:00
|
|
|
alreadySeen.add(prevWord);
|
|
|
|
}
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|
2012-03-13 11:39:21 +00:00
|
|
|
return suggestionsList;
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|
2011-01-19 08:29:27 +00:00
|
|
|
|
2012-09-27 09:16:16 +00:00
|
|
|
public static final class SuggestedWordInfo {
|
2012-04-02 07:33:24 +00:00
|
|
|
public static final int MAX_SCORE = Integer.MAX_VALUE;
|
2012-06-12 16:10:18 +00:00
|
|
|
public static final int KIND_TYPED = 0; // What user typed
|
|
|
|
public static final int KIND_CORRECTION = 1; // Simple correction/suggestion
|
|
|
|
public static final int KIND_COMPLETION = 2; // Completion (suggestion with appended chars)
|
|
|
|
public static final int KIND_WHITELIST = 3; // Whitelisted word
|
|
|
|
public static final int KIND_BLACKLIST = 4; // Blacklisted word
|
|
|
|
public static final int KIND_HARDCODED = 5; // Hardcoded suggestion, e.g. punctuation
|
|
|
|
public static final int KIND_APP_DEFINED = 6; // Suggested by the application
|
2012-06-12 17:11:45 +00:00
|
|
|
public static final int KIND_SHORTCUT = 7; // A shortcut
|
2012-07-12 06:21:11 +00:00
|
|
|
public static final int KIND_PREDICTION = 8; // A prediction (== a suggestion with no input)
|
2012-07-04 07:01:00 +00:00
|
|
|
public final String mWord;
|
2012-04-02 07:33:24 +00:00
|
|
|
public final int mScore;
|
2012-06-12 17:11:45 +00:00
|
|
|
public final int mKind; // one of the KIND_* constants above
|
2012-04-02 07:33:24 +00:00
|
|
|
public final int mCodePointCount;
|
2012-06-27 09:17:28 +00:00
|
|
|
public final String mSourceDict;
|
2012-04-02 07:33:24 +00:00
|
|
|
private String mDebugString = "";
|
2011-01-19 08:29:27 +00:00
|
|
|
|
2012-06-27 09:17:28 +00:00
|
|
|
public SuggestedWordInfo(final CharSequence word, final int score, final int kind,
|
|
|
|
final String sourceDict) {
|
2012-07-04 07:01:00 +00:00
|
|
|
mWord = word.toString();
|
2012-04-02 07:33:24 +00:00
|
|
|
mScore = score;
|
2012-06-12 16:10:18 +00:00
|
|
|
mKind = kind;
|
2012-06-27 09:17:28 +00:00
|
|
|
mSourceDict = sourceDict;
|
2012-07-04 07:01:00 +00:00
|
|
|
mCodePointCount = StringUtils.codePointCount(mWord);
|
2011-01-19 08:29:27 +00:00
|
|
|
}
|
|
|
|
|
2012-04-02 07:33:24 +00:00
|
|
|
|
|
|
|
public void setDebugString(String str) {
|
|
|
|
if (null == str) throw new NullPointerException("Debug info is null");
|
|
|
|
mDebugString = str;
|
2011-01-19 08:29:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
public String getDebugString() {
|
2012-03-15 05:40:45 +00:00
|
|
|
return mDebugString;
|
2011-01-19 08:29:27 +00:00
|
|
|
}
|
|
|
|
|
2012-04-02 07:33:24 +00:00
|
|
|
public int codePointCount() {
|
|
|
|
return mCodePointCount;
|
|
|
|
}
|
|
|
|
|
|
|
|
public int codePointAt(int i) {
|
2012-07-04 07:01:00 +00:00
|
|
|
return mWord.codePointAt(i);
|
2012-04-02 07:33:24 +00:00
|
|
|
}
|
|
|
|
|
2012-03-14 10:23:15 +00:00
|
|
|
@Override
|
|
|
|
public String toString() {
|
|
|
|
if (TextUtils.isEmpty(mDebugString)) {
|
2012-07-04 07:01:00 +00:00
|
|
|
return mWord;
|
2012-03-14 10:23:15 +00:00
|
|
|
} else {
|
2012-07-04 07:01:00 +00:00
|
|
|
return mWord + " (" + mDebugString.toString() + ")";
|
2012-04-02 07:33:24 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: Consolidate this method and StringUtils.removeDupes() in the future.
|
|
|
|
public static void removeDups(ArrayList<SuggestedWordInfo> candidates) {
|
|
|
|
if (candidates.size() <= 1) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
int i = 1;
|
2012-09-04 03:49:46 +00:00
|
|
|
while (i < candidates.size()) {
|
2012-04-02 07:33:24 +00:00
|
|
|
final SuggestedWordInfo cur = candidates.get(i);
|
|
|
|
for (int j = 0; j < i; ++j) {
|
|
|
|
final SuggestedWordInfo previous = candidates.get(j);
|
2012-07-04 07:01:00 +00:00
|
|
|
if (cur.mWord.equals(previous.mWord)) {
|
2012-04-02 07:33:24 +00:00
|
|
|
candidates.remove(cur.mScore < previous.mScore ? i : j);
|
|
|
|
--i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
++i;
|
2012-03-14 10:23:15 +00:00
|
|
|
}
|
|
|
|
}
|
2011-01-19 08:29:27 +00:00
|
|
|
}
|
2010-12-10 11:50:30 +00:00
|
|
|
}
|