Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 74198f96 authored by Dan Zivkovic's avatar Dan Zivkovic Committed by Android Git Automerger
Browse files

am c4977b5f: Merge "Removing code from RichInputConnection."

* commit 'c4977b5f':
  Removing code from RichInputConnection.
parents 7bb8e508 c4977b5f
Loading
Loading
Loading
Loading
+4 −49
Original line number Diff line number Diff line
@@ -94,12 +94,6 @@ public final class RichInputConnection implements PrivateCommandPerformer {
     * to avoid object creation.
     */
    private SpannableStringBuilder mTempObjectForCommitText = new SpannableStringBuilder();
    /**
     * This variable is used to track whether the last committed text had the background color or
     * not.
     * TODO: Omit this flag if possible.
     */
    private boolean mLastCommittedTextHasBackgroundColor = false;

    private final InputMethodService mParent;
    InputConnection mIC;
@@ -238,8 +232,6 @@ public final class RichInputConnection implements PrivateCommandPerformer {
        // it works, but it's wrong and should be fixed.
        mCommittedTextBeforeComposingText.append(mComposingText);
        mComposingText.setLength(0);
        // TODO: Clear this flag in setComposingRegion() and setComposingText() as well if needed.
        mLastCommittedTextHasBackgroundColor = false;
        if (null != mIC) {
            mIC.finishComposingText();
        }
@@ -261,7 +253,6 @@ public final class RichInputConnection implements PrivateCommandPerformer {
        mExpectedSelStart += text.length() - mComposingText.length();
        mExpectedSelEnd = mExpectedSelStart;
        mComposingText.setLength(0);
        mLastCommittedTextHasBackgroundColor = false;
        if (null != mIC) {
            mTempObjectForCommitText.clear();
            mTempObjectForCommitText.append(text);
@@ -288,27 +279,6 @@ public final class RichInputConnection implements PrivateCommandPerformer {
        }
    }

    /**
     * Removes the background color from the highlighted text if necessary. Should be called while
     * there is no on-going composing text.
     *
     * <p>CAVEAT: This method internally calls {@link InputConnection#finishComposingText()}.
     * Be careful of any unexpected side effects.</p>
     */
    public void removeBackgroundColorFromHighlightedTextIfNecessary() {
        // TODO: We haven't yet full tested if we really need to check this flag or not. Omit this
        // flag if everything works fine without this condition.
        if (!mLastCommittedTextHasBackgroundColor) {
            return;
        }
        if (mComposingText.length() > 0) {
            Log.e(TAG, "clearSpansWithComposingFlags should be called when composing text is " +
                    "empty. mComposingText=" + mComposingText);
            return;
        }
        finishComposingText();
    }

    public CharSequence getSelectedText(final int flags) {
        return (null == mIC) ? null : mIC.getSelectedText(flags);
    }
@@ -936,8 +906,6 @@ public final class RichInputConnection implements PrivateCommandPerformer {
        }
    }

    private boolean mCursorAnchorInfoMonitorEnabled = false;

    /**
     * Requests the editor to call back {@link InputMethodManager#updateCursorAnchorInfo}.
     * @param enableMonitor {@code true} to request the editor to call back the method whenever the
@@ -952,23 +920,10 @@ public final class RichInputConnection implements PrivateCommandPerformer {
    public boolean requestCursorUpdates(final boolean enableMonitor,
            final boolean requestImmediateCallback) {
        mIC = mParent.getCurrentInputConnection();
        final boolean scheduled;
        if (null != mIC) {
            scheduled = InputConnectionCompatUtils.requestCursorUpdates(mIC, enableMonitor,
                    requestImmediateCallback);
        } else {
            scheduled = false;
        }
        mCursorAnchorInfoMonitorEnabled = (scheduled && enableMonitor);
        return scheduled;
        if (mIC == null) {
            return false;
        }

    /**
     * @return {@code true} if the application reported that the monitor mode of
     * {@link InputMethodService#onUpdateCursorAnchorInfo(android.view.inputmethod.CursorAnchorInfo)}
     * is currently enabled.
     */
    public boolean isCursorAnchorInfoMonitorEnabled() {
        return mCursorAnchorInfoMonitorEnabled;
        return InputConnectionCompatUtils.requestCursorUpdates(
                mIC, enableMonitor, requestImmediateCallback);
    }
}
+0 −6
Original line number Diff line number Diff line
@@ -476,8 +476,6 @@ public final class InputLogic {
        ++mAutoCommitSequenceNumber;
        mConnection.beginBatchEdit();
        if (!mWordComposer.isComposingWord()) {
            mConnection.removeBackgroundColorFromHighlightedTextIfNecessary();
        } else {
            if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
                // If we are in the middle of a recorrection, we need to commit the recorrection
                // first so that we can insert the batch input at the current cursor position.
@@ -768,10 +766,6 @@ public final class InputLogic {
            final InputTransaction inputTransaction,
            // TODO: remove this argument
            final LatinIME.UIHandler handler) {
        if (!mWordComposer.isComposingWord()) {
            mConnection.removeBackgroundColorFromHighlightedTextIfNecessary();
        }

        final int codePoint = event.mCodePoint;
        mSpaceState = SpaceState.NONE;
        if (inputTransaction.mSettingsValues.isWordSeparator(codePoint)