diff options
author | 2012-08-03 07:17:37 -0700 | |
---|---|---|
committer | 2012-08-03 07:17:37 -0700 | |
commit | 3f80541844672a7625eb298adc6141ecf14bb883 (patch) | |
tree | 375f3e8a6ccbc955d9dba380d8e36af3ac12fcb6 /java/src | |
parent | a777a86f4b311ccdf1443faf0d1759e445ef138e (diff) | |
parent | 4c976aceeef7238cabbbb29f5793b4e805d087e5 (diff) | |
download | latinime-3f80541844672a7625eb298adc6141ecf14bb883.tar.gz latinime-3f80541844672a7625eb298adc6141ecf14bb883.tar.xz latinime-3f80541844672a7625eb298adc6141ecf14bb883.zip |
Merge "Fix an OOB exception" into jb-mr1-dev
Diffstat (limited to 'java/src')
-rw-r--r-- | java/src/com/android/inputmethod/latin/ExpandableDictionary.java | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/java/src/com/android/inputmethod/latin/ExpandableDictionary.java b/java/src/com/android/inputmethod/latin/ExpandableDictionary.java index 5d7995dc2..d101aaf15 100644 --- a/java/src/com/android/inputmethod/latin/ExpandableDictionary.java +++ b/java/src/com/android/inputmethod/latin/ExpandableDictionary.java @@ -654,9 +654,12 @@ public class ExpandableDictionary extends Dictionary { --index; mLookedUpString[index] = node.mCode; node = node.mParent; - } while (node != null); + } while (node != null && index > 0); - if (freq >= 0) { + // If node is null, we have a word longer than MAX_WORD_LENGTH in the dictionary. + // It's a little unclear how this can happen, but just in case it does it's safer + // to ignore the word in this case. + if (freq >= 0 && node == null) { suggestions.add(new SuggestedWordInfo(new String(mLookedUpString, index, BinaryDictionary.MAX_WORD_LENGTH - index), freq, SuggestedWordInfo.KIND_CORRECTION, mDictType)); |