diff options
author | 2014-03-20 18:33:38 +0900 | |
---|---|---|
committer | 2014-03-27 16:47:27 +0900 | |
commit | 0de7a6d1a272d52a9544df1c693ae199ab5abc52 (patch) | |
tree | 2e4d05ffa874939d82039733ef889842495f2410 /java/src/com/android/inputmethod/latin/BinaryDictionary.java | |
parent | 3c38e1f269ad34a663db672e5cfb291fb1931987 (diff) | |
download | latinime-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.java | 14 |
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; + } } } |