diff options
author | 2013-04-19 14:51:47 +0900 | |
---|---|---|
committer | 2013-04-19 15:44:20 +0900 | |
commit | 3bdf341ea001cef70da803749e17484d19a9726a (patch) | |
tree | 2d29cb3225640565de3ff39d8e05a753ecafbb96 /java/src | |
parent | 530fd15eff8bd8df1c4c87cfeab379b5328748c1 (diff) | |
download | latinime-3bdf341ea001cef70da803749e17484d19a9726a.tar.gz latinime-3bdf341ea001cef70da803749e17484d19a9726a.tar.xz latinime-3bdf341ea001cef70da803749e17484d19a9726a.zip |
Fix an NPE in recapitalize
Bug: 8657736
Change-Id: I459d1c200826c1c394f8207475ecf60a4f356793
Diffstat (limited to 'java/src')
-rw-r--r-- | java/src/com/android/inputmethod/latin/LatinIME.java | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/java/src/com/android/inputmethod/latin/LatinIME.java b/java/src/com/android/inputmethod/latin/LatinIME.java index 0e1c4dc31..b8203ff74 100644 --- a/java/src/com/android/inputmethod/latin/LatinIME.java +++ b/java/src/com/android/inputmethod/latin/LatinIME.java @@ -1970,9 +1970,12 @@ public final class LatinIME extends InputMethodService implements KeyboardAction // If we have a recapitalize in progress, use it; otherwise, create a new one. if (!mRecapitalizeStatus.isActive() || !mRecapitalizeStatus.isSetAt(mLastSelectionStart, mLastSelectionEnd)) { + final CharSequence selectedText = + mConnection.getSelectedText(0 /* flags, 0 for no styles */); + if (TextUtils.isEmpty(selectedText)) return; // Race condition with the input connection mRecapitalizeStatus.initialize(mLastSelectionStart, mLastSelectionEnd, - mConnection.getSelectedText(0 /* flags, 0 for no styles */).toString(), - mSettings.getCurrentLocale(), mSettings.getWordSeparators()); + selectedText.toString(), mSettings.getCurrentLocale(), + mSettings.getWordSeparators()); // We trim leading and trailing whitespace. mRecapitalizeStatus.trim(); // Trimming the object may have changed the length of the string, and we need to |