summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--services/core/java/com/android/server/inputmethod/InputMethodSubtypeSwitchingController.java31
-rw-r--r--services/tests/servicestests/src/com/android/server/inputmethod/InputMethodSubtypeSwitchingControllerTest.java18
2 files changed, 21 insertions, 28 deletions
diff --git a/services/core/java/com/android/server/inputmethod/InputMethodSubtypeSwitchingController.java b/services/core/java/com/android/server/inputmethod/InputMethodSubtypeSwitchingController.java
index 77b2fee82dc8..27c59d462b8e 100644
--- a/services/core/java/com/android/server/inputmethod/InputMethodSubtypeSwitchingController.java
+++ b/services/core/java/com/android/server/inputmethod/InputMethodSubtypeSwitchingController.java
@@ -31,13 +31,11 @@ import com.android.server.inputmethod.InputMethodUtils.InputMethodSettings;
import java.util.ArrayList;
import java.util.Collections;
-import java.util.Comparator;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Locale;
import java.util.Objects;
-import java.util.TreeMap;
/**
* InputMethodSubtypeSwitchingController controls the switching behavior of the subtypes.
@@ -113,6 +111,7 @@ final class InputMethodSubtypeSwitchingController {
* <li>{@link #mIsSystemLocale}</li>
* <li>{@link #mIsSystemLanguage}</li>
* <li>{@link #mSubtypeName}</li>
+ * <li>{@link #mImi} with {@link InputMethodInfo#getId()}</li>
* </ol>
* Note: this class has a natural ordering that is inconsistent with {@link #equals(Object).
* This method doesn't compare {@link #mSubtypeId} but {@link #equals(Object)} does.
@@ -137,7 +136,11 @@ final class InputMethodSubtypeSwitchingController {
if (result != 0) {
return result;
}
- return compareNullableCharSequences(mSubtypeName, other.mSubtypeName);
+ result = compareNullableCharSequences(mSubtypeName, other.mSubtypeName);
+ if (result != 0) {
+ return result;
+ }
+ return mImi.getId().compareTo(other.mImi.getId());
}
@Override
@@ -179,24 +182,6 @@ final class InputMethodSubtypeSwitchingController {
mSystemLocaleStr = locale != null ? locale.toString() : "";
}
- private final TreeMap<InputMethodInfo, List<InputMethodSubtype>> mSortedImmis =
- new TreeMap<>(
- new Comparator<InputMethodInfo>() {
- @Override
- public int compare(InputMethodInfo imi1, InputMethodInfo imi2) {
- if (imi2 == null)
- return 0;
- if (imi1 == null)
- return 1;
- if (mPm == null) {
- return imi1.getId().compareTo(imi2.getId());
- }
- CharSequence imiId1 = imi1.loadLabel(mPm) + "/" + imi1.getId();
- CharSequence imiId2 = imi2.loadLabel(mPm) + "/" + imi2.getId();
- return imiId1.toString().compareTo(imiId2.toString());
- }
- });
-
public List<ImeSubtypeListItem> getSortedInputMethodAndSubtypeList(
boolean includeAuxiliarySubtypes, boolean isScreenLocked) {
final ArrayList<ImeSubtypeListItem> imList = new ArrayList<>();
@@ -212,9 +197,7 @@ final class InputMethodSubtypeSwitchingController {
}
includeAuxiliarySubtypes = false;
}
- mSortedImmis.clear();
- mSortedImmis.putAll(immis);
- for (InputMethodInfo imi : mSortedImmis.keySet()) {
+ for (InputMethodInfo imi : immis.keySet()) {
if (imi == null) {
continue;
}
diff --git a/services/tests/servicestests/src/com/android/server/inputmethod/InputMethodSubtypeSwitchingControllerTest.java b/services/tests/servicestests/src/com/android/server/inputmethod/InputMethodSubtypeSwitchingControllerTest.java
index 942446184918..6ab48e53648c 100644
--- a/services/tests/servicestests/src/com/android/server/inputmethod/InputMethodSubtypeSwitchingControllerTest.java
+++ b/services/tests/servicestests/src/com/android/server/inputmethod/InputMethodSubtypeSwitchingControllerTest.java
@@ -375,20 +375,30 @@ public class InputMethodSubtypeSwitchingControllerTest {
final ComponentName imeZ1 = new ComponentName("com.example.imeZ", "Ime1");
{
final List<ImeSubtypeListItem> items = Arrays.asList(
- // Subtypes of IME "X".
+ // Subtypes of two IMEs that have the same display name "X".
// Subtypes that has the same locale of the system's.
createDummyItem(imeX1, "X", "E", "en_US", 0, "en_US"),
+ createDummyItem(imeX2, "X", "E", "en_US", 0, "en_US"),
createDummyItem(imeX1, "X", "Z", "en_US", 3, "en_US"),
+ createDummyItem(imeX2, "X", "Z", "en_US", 3, "en_US"),
createDummyItem(imeX1, "X", "", "en_US", 6, "en_US"),
+ createDummyItem(imeX2, "X", "", "en_US", 6, "en_US"),
// Subtypes that has the same language of the system's.
createDummyItem(imeX1, "X", "E", "en", 1, "en_US"),
+ createDummyItem(imeX2, "X", "E", "en", 1, "en_US"),
createDummyItem(imeX1, "X", "Z", "en", 4, "en_US"),
+ createDummyItem(imeX2, "X", "Z", "en", 4, "en_US"),
createDummyItem(imeX1, "X", "", "en", 7, "en_US"),
+ createDummyItem(imeX2, "X", "", "en", 7, "en_US"),
// Subtypes that has different language than the system's.
createDummyItem(imeX1, "X", "A", "hi_IN", 27, "en_US"),
+ createDummyItem(imeX2, "X", "A", "hi_IN", 27, "en_US"),
createDummyItem(imeX1, "X", "E", "ja", 2, "en_US"),
+ createDummyItem(imeX2, "X", "E", "ja", 2, "en_US"),
createDummyItem(imeX1, "X", "Z", "ja", 5, "en_US"),
+ createDummyItem(imeX2, "X", "Z", "ja", 5, "en_US"),
createDummyItem(imeX1, "X", "", "ja", 8, "en_US"),
+ createDummyItem(imeX2, "X", "", "ja", 8, "en_US"),
// Subtypes of IME "Y".
// Subtypes that has the same locale of the system's.
@@ -449,11 +459,11 @@ public class InputMethodSubtypeSwitchingControllerTest {
}
{
- // Currently ComponentName is not used for sorting.
+ // Check if ComponentName is also taken into account when comparing two items.
final ImeSubtypeListItem ime1 = createDummyItem(imeX1, "X", "A", "ja_JP", 0, "en_US");
final ImeSubtypeListItem ime2 = createDummyItem(imeX2, "X", "A", "ja_JP", 0, "en_US");
- assertTrue(ime1.compareTo(ime2) == 0);
- assertTrue(ime2.compareTo(ime1) == 0);
+ assertTrue(ime1.compareTo(ime2) < 0);
+ assertTrue(ime2.compareTo(ime1) > 0);
// But those aren't equal to each other.
assertFalse(ime1.equals(ime2));
assertFalse(ime2.equals(ime1));