2011-03-04 07:56:10 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2011 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;
|
|
|
|
|
|
|
|
import android.content.Context;
|
2011-10-06 06:57:43 +00:00
|
|
|
import android.content.res.Resources;
|
2011-03-04 07:56:10 +00:00
|
|
|
import android.text.TextUtils;
|
|
|
|
import android.util.Log;
|
|
|
|
import android.util.Pair;
|
|
|
|
|
2012-04-03 05:28:56 +00:00
|
|
|
import com.android.inputmethod.latin.LocaleUtils.RunInLocale;
|
|
|
|
|
2011-03-04 07:56:10 +00:00
|
|
|
import java.util.HashMap;
|
2011-10-06 06:57:43 +00:00
|
|
|
import java.util.Locale;
|
2011-03-04 07:56:10 +00:00
|
|
|
|
2011-10-06 06:57:43 +00:00
|
|
|
public class WhitelistDictionary extends ExpandableDictionary {
|
2011-03-04 07:56:10 +00:00
|
|
|
|
|
|
|
private static final boolean DBG = LatinImeLogger.sDBG;
|
|
|
|
private static final String TAG = WhitelistDictionary.class.getSimpleName();
|
|
|
|
|
|
|
|
private final HashMap<String, Pair<Integer, String>> mWhitelistWords =
|
|
|
|
new HashMap<String, Pair<Integer, String>>();
|
|
|
|
|
2011-10-06 06:57:43 +00:00
|
|
|
// TODO: Conform to the async load contact of ExpandableDictionary
|
2011-10-06 06:57:43 +00:00
|
|
|
public WhitelistDictionary(final Context context, final Locale locale) {
|
2011-10-06 06:57:43 +00:00
|
|
|
super(context, Suggest.DIC_WHITELIST);
|
2012-04-11 05:58:02 +00:00
|
|
|
// TODO: Move whitelist dictionary into main dictionary.
|
2012-04-03 05:28:56 +00:00
|
|
|
final RunInLocale<Void> job = new RunInLocale<Void>() {
|
|
|
|
@Override
|
|
|
|
protected Void job(Resources res) {
|
|
|
|
initWordlist(res.getStringArray(R.array.wordlist_whitelist));
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
job.runInLocale(context.getResources(), locale);
|
2011-03-04 07:56:10 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private void initWordlist(String[] wordlist) {
|
|
|
|
mWhitelistWords.clear();
|
|
|
|
final int N = wordlist.length;
|
|
|
|
if (N % 3 != 0) {
|
|
|
|
if (DBG) {
|
|
|
|
Log.d(TAG, "The number of the whitelist is invalid.");
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
try {
|
|
|
|
for (int i = 0; i < N; i += 3) {
|
|
|
|
final int score = Integer.valueOf(wordlist[i]);
|
|
|
|
final String before = wordlist[i + 1];
|
|
|
|
final String after = wordlist[i + 2];
|
|
|
|
if (before != null && after != null) {
|
|
|
|
mWhitelistWords.put(
|
|
|
|
before.toLowerCase(), new Pair<Integer, String>(score, after));
|
2012-05-11 07:33:01 +00:00
|
|
|
addWord(after, null /* shortcut */, score);
|
2011-03-04 07:56:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
} catch (NumberFormatException e) {
|
|
|
|
if (DBG) {
|
|
|
|
Log.d(TAG, "The score of the word is invalid.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-10-06 06:57:43 +00:00
|
|
|
public String getWhitelistedWord(String before) {
|
2011-03-04 07:56:10 +00:00
|
|
|
if (before == null) return null;
|
|
|
|
final String lowerCaseBefore = before.toLowerCase();
|
|
|
|
if(mWhitelistWords.containsKey(lowerCaseBefore)) {
|
|
|
|
if (DBG) {
|
2011-10-06 06:57:43 +00:00
|
|
|
Log.d(TAG, "--- found whitelistedWord: " + lowerCaseBefore);
|
2011-03-04 07:56:10 +00:00
|
|
|
}
|
|
|
|
return mWhitelistWords.get(lowerCaseBefore).second;
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2011-10-07 07:34:19 +00:00
|
|
|
// See LatinIME#updateSuggestions. This breaks in the (queer) case that the whitelist
|
|
|
|
// lists that word a should autocorrect to word b, and word c would autocorrect to
|
|
|
|
// an upper-cased version of a. In this case, the way this return value is used would
|
|
|
|
// remove the first candidate when the user typed the upper-cased version of A.
|
|
|
|
// Example : abc -> def and xyz -> Abc
|
|
|
|
// A user typing Abc would experience it being autocorrected to something else (not
|
|
|
|
// necessarily def).
|
|
|
|
// There is no such combination in the whitelist at the time and there probably won't
|
|
|
|
// ever be - it doesn't make sense. But still.
|
|
|
|
public boolean shouldForciblyAutoCorrectFrom(CharSequence word) {
|
|
|
|
if (TextUtils.isEmpty(word)) return false;
|
2011-10-06 06:57:43 +00:00
|
|
|
final String correction = getWhitelistedWord(word.toString());
|
2011-10-07 07:34:19 +00:00
|
|
|
if (TextUtils.isEmpty(correction)) return false;
|
|
|
|
return !correction.equals(word);
|
|
|
|
}
|
2011-10-06 06:57:43 +00:00
|
|
|
|
|
|
|
// Leave implementation of getWords and isValidWord to the superclass.
|
|
|
|
// The words have been added to the ExpandableDictionary with addWord() inside initWordlist.
|
2011-03-04 07:56:10 +00:00
|
|
|
}
|