aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/latin/BinaryDictionary.java
diff options
context:
space:
mode:
authorJean Chalard <jchalard@google.com>2014-03-20 18:33:38 +0900
committerJean Chalard <jchalard@google.com>2014-03-27 16:47:27 +0900
commit0de7a6d1a272d52a9544df1c693ae199ab5abc52 (patch)
tree2e4d05ffa874939d82039733ef889842495f2410 /java/src/com/android/inputmethod/latin/BinaryDictionary.java
parent3c38e1f269ad34a663db672e5cfb291fb1931987 (diff)
downloadlatinime-0de7a6d1a272d52a9544df1c693ae199ab5abc52.tar.gz
latinime-0de7a6d1a272d52a9544df1c693ae199ab5abc52.tar.xz
latinime-0de7a6d1a272d52a9544df1c693ae199ab5abc52.zip
[CB15] Remove a redundant variable.
This is a tiny bit slower, but probably unnoticeable. Still, it gains some performance in other places, saves memory, and more importantly makes for simpler code, so it's certainly better. Change-Id: Id1ab4f73f71acd73f5920bc729817abd22cf0d07
Diffstat (limited to 'java/src/com/android/inputmethod/latin/BinaryDictionary.java')
-rw-r--r--java/src/com/android/inputmethod/latin/BinaryDictionary.java14
1 files changed, 12 insertions, 2 deletions
diff --git a/java/src/com/android/inputmethod/latin/BinaryDictionary.java b/java/src/com/android/inputmethod/latin/BinaryDictionary.java
index 0aa34e82e..323d0c8a3 100644
--- a/java/src/com/android/inputmethod/latin/BinaryDictionary.java
+++ b/java/src/com/android/inputmethod/latin/BinaryDictionary.java
@@ -249,8 +249,18 @@ public final class BinaryDictionary extends Dictionary {
final boolean isGesture = composer.isBatchMode();
if (composerSize <= 1 || !isGesture) {
if (composerSize > MAX_WORD_LENGTH - 1) return null;
- for (int i = 0; i < composerSize; i++) {
- mInputCodePoints[i] = composer.getCodeAt(i);
+ final CharSequence typedWord = composer.getTypedWord();
+ final int charCount = typedWord.length();
+ int typedWordCharIndex = 0;
+ int inputCodePointIndex = 0;
+ while (typedWordCharIndex < charCount) {
+ final int codePoint = Character.codePointAt(typedWord, typedWordCharIndex);
+ mInputCodePoints[inputCodePointIndex] = codePoint;
+ typedWordCharIndex += Character.charCount(codePoint);
+ inputCodePointIndex += 1;
+ if (inputCodePointIndex >= MAX_WORD_LENGTH) {
+ break;
+ }
}
}