aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/compat
diff options
context:
space:
mode:
authorYohei Yukaw <yukawa@google.com>2015-04-17 16:48:10 -0700
committerYohei Yukaw <yukawa@google.com>2015-04-20 20:29:44 -0700
commit490fa47a46015f2c8bd8f9010d236bfe5aecd4bb (patch)
tree55599c8c109d3959fdc8f616b144ed43ffb755b7 /java/src/com/android/inputmethod/compat
parent54e891e2bdce2d3d1f8a319c1f596fd6590314f3 (diff)
downloadlatinime-490fa47a46015f2c8bd8f9010d236bfe5aecd4bb.tar.gz
latinime-490fa47a46015f2c8bd8f9010d236bfe5aecd4bb.tar.xz
latinime-490fa47a46015f2c8bd8f9010d236bfe5aecd4bb.zip
Always specify non-null Locale object to SuggestionSpan
Confusingly, specifying a null Locale object to the constructor of SuggestionSpan does not necessarily mean that SuggestionSpan#getLocale() returns null. The constructor in question also receives Context object, and Context's locale can be used as a fallback locale to initialize locale of SuggestionSpan. With this CL, LatinIME always specify non-null Locale object when instantiating SuggestionSpan object. It basically corresponds to the active main dictionary, but can be Locale#ROOT when one locale is not determined for some reasons. BUG: 20435013 Change-Id: I2c152466410327300e7dba4d7ed9a22f57c17c4f
Diffstat (limited to 'java/src/com/android/inputmethod/compat')
-rw-r--r--java/src/com/android/inputmethod/compat/SuggestionSpanUtils.java11
1 files changed, 5 insertions, 6 deletions
diff --git a/java/src/com/android/inputmethod/compat/SuggestionSpanUtils.java b/java/src/com/android/inputmethod/compat/SuggestionSpanUtils.java
index 4d2925d30..3f621913c 100644
--- a/java/src/com/android/inputmethod/compat/SuggestionSpanUtils.java
+++ b/java/src/com/android/inputmethod/compat/SuggestionSpanUtils.java
@@ -33,6 +33,7 @@ import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Locale;
+import javax.annotation.Nonnull;
import javax.annotation.Nullable;
public final class SuggestionSpanUtils {
@@ -57,13 +58,12 @@ public final class SuggestionSpanUtils {
@UsedForTesting
public static CharSequence getTextWithAutoCorrectionIndicatorUnderline(
- final Context context, final String text) {
+ final Context context, final String text, @Nonnull final Locale locale) {
if (TextUtils.isEmpty(text) || OBJ_FLAG_AUTO_CORRECTION == null) {
return text;
}
final Spannable spannable = new SpannableString(text);
- // TODO: Set locale if it is feasible.
- final SuggestionSpan suggestionSpan = new SuggestionSpan(context, null /* locale */,
+ final SuggestionSpan suggestionSpan = new SuggestionSpan(context, locale,
new String[] {} /* suggestions */, OBJ_FLAG_AUTO_CORRECTION, null);
spannable.setSpan(suggestionSpan, 0, text.length(),
Spanned.SPAN_EXCLUSIVE_EXCLUSIVE | Spanned.SPAN_COMPOSING);
@@ -72,7 +72,7 @@ public final class SuggestionSpanUtils {
@UsedForTesting
public static CharSequence getTextWithSuggestionSpan(final Context context,
- final String pickedWord, final SuggestedWords suggestedWords) {
+ final String pickedWord, final SuggestedWords suggestedWords, final Locale locale) {
if (TextUtils.isEmpty(pickedWord) || suggestedWords.isEmpty()
|| suggestedWords.isPrediction() || suggestedWords.isPunctuationSuggestions()) {
return pickedWord;
@@ -92,8 +92,7 @@ public final class SuggestionSpanUtils {
suggestionsList.add(word.toString());
}
}
- // TODO: Set locale if it is feasible.
- final SuggestionSpan suggestionSpan = new SuggestionSpan(context, null /* locale */,
+ final SuggestionSpan suggestionSpan = new SuggestionSpan(context, locale,
suggestionsList.toArray(new String[suggestionsList.size()]), 0 /* flags */, null);
final Spannable spannable = new SpannableString(pickedWord);
spannable.setSpan(suggestionSpan, 0, pickedWord.length(), Spanned.SPAN_EXCLUSIVE_EXCLUSIVE);