aboutsummaryrefslogtreecommitdiffstats
path: root/java/src
diff options
context:
space:
mode:
authorJean Chalard <jchalard@google.com>2012-08-03 07:17:37 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-08-03 07:17:37 -0700
commit3f80541844672a7625eb298adc6141ecf14bb883 (patch)
tree375f3e8a6ccbc955d9dba380d8e36af3ac12fcb6 /java/src
parenta777a86f4b311ccdf1443faf0d1759e445ef138e (diff)
parent4c976aceeef7238cabbbb29f5793b4e805d087e5 (diff)
downloadlatinime-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.java7
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));