diff options
author | 2013-12-25 21:03:24 +0900 | |
---|---|---|
committer | 2013-12-27 20:06:39 +0900 | |
commit | 81e0ca5fd395fd67c7b93e7d87e7d90fa136f065 (patch) | |
tree | 74b169b4634272c24381b7db00585e6e08c7a7a5 /java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java | |
parent | 4970eda28628e044f90fb8425edcd0aa01f7c3dd (diff) | |
download | latinime-81e0ca5fd395fd67c7b93e7d87e7d90fa136f065.tar.gz latinime-81e0ca5fd395fd67c7b93e7d87e7d90fa136f065.tar.xz latinime-81e0ca5fd395fd67c7b93e7d87e7d90fa136f065.zip |
[IL49] Move InputLogic-related init code to InputLogic.
Bug: 8636060
Change-Id: Ie5027512f066d9c530a686ac559e4649a39bf439
Diffstat (limited to 'java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java')
-rw-r--r-- | java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java | 21 |
1 files changed, 19 insertions, 2 deletions
diff --git a/java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java b/java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java index 34377e955..5fe482bda 100644 --- a/java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java +++ b/java/src/com/android/inputmethod/latin/inputlogic/InputLogic.java @@ -116,9 +116,22 @@ public final class InputLogic { * some things must not be done (for example, the keyboard should not be reset to the * alphabetic layout), so do not send false to this just in case. * - * @param restarting whether input is starting in the same field as before. + * @param restarting whether input is starting in the same field as before. Unused for now. + * @param editorInfo the editorInfo associated with the editor. */ - public void startInput(final boolean restarting) { + public void startInput(final boolean restarting, final EditorInfo editorInfo) { + mEnteredText = null; + resetComposingState(true /* alsoResetLastComposedWord */); + mDeleteCount = 0; + mSpaceState = SpaceState.NONE; + mRecapitalizeStatus.deactivate(); + mCurrentlyPressedHardwareKeys.clear(); + mSuggestedWords = SuggestedWords.EMPTY; + mLastSelectionStart = editorInfo.initialSelStart; + mLastSelectionEnd = editorInfo.initialSelEnd; + // In some cases (namely, after rotation of the device) editorInfo.initialSelStart is lying + // so we try using some heuristics to find out about these and fix them. + tryFixLyingCursorPosition(); mInputLogicHandler = new InputLogicHandler(); } @@ -126,6 +139,10 @@ public final class InputLogic { * Clean up the input logic after input is finished. */ public void finishInput() { + if (mWordComposer.isComposingWord()) { + mConnection.finishComposingText(); + } + resetComposingState(true /* alsoResetLastComposedWord */); mInputLogicHandler.destroy(); mInputLogicHandler = null; } |