mirror of
https://gitlab.futo.org/keyboard/latinime.git
synced 2024-09-28 14:54:30 +01:00
Unlearn word when the user moves the cursor in to correct it.
Change-Id: I36358e551d6c51e786b6e09b1a1368ebf3c48f69
This commit is contained in:
parent
b6105d2087
commit
1a58c47ebe
@ -476,6 +476,9 @@ public final class InputLogic {
|
|||||||
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
||||||
// If we are in the middle of a recorrection, we need to commit the recorrection
|
// 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.
|
// first so that we can insert the batch input at the current cursor position.
|
||||||
|
// We also need to unlearn the original word that is now being corrected.
|
||||||
|
unlearnWord(mWordComposer.getTypedWord(), settingsValues,
|
||||||
|
Constants.EVENT_BACKSPACE);
|
||||||
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
||||||
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
||||||
} else if (mWordComposer.isSingleLetter()) {
|
} else if (mWordComposer.isSingleLetter()) {
|
||||||
@ -742,6 +745,9 @@ public final class InputLogic {
|
|||||||
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
||||||
// If we are in the middle of a recorrection, we need to commit the recorrection
|
// If we are in the middle of a recorrection, we need to commit the recorrection
|
||||||
// first so that we can insert the character at the current cursor position.
|
// first so that we can insert the character at the current cursor position.
|
||||||
|
// We also need to unlearn the original word that is now being corrected.
|
||||||
|
unlearnWord(mWordComposer.getTypedWord(), inputTransaction.mSettingsValues,
|
||||||
|
Constants.EVENT_BACKSPACE);
|
||||||
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
||||||
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
||||||
} else {
|
} else {
|
||||||
@ -781,6 +787,9 @@ public final class InputLogic {
|
|||||||
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
||||||
// If we are in the middle of a recorrection, we need to commit the recorrection
|
// If we are in the middle of a recorrection, we need to commit the recorrection
|
||||||
// first so that we can insert the character at the current cursor position.
|
// first so that we can insert the character at the current cursor position.
|
||||||
|
// We also need to unlearn the original word that is now being corrected.
|
||||||
|
unlearnWord(mWordComposer.getTypedWord(), inputTransaction.mSettingsValues,
|
||||||
|
Constants.EVENT_BACKSPACE);
|
||||||
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
||||||
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
||||||
isComposingWord = false;
|
isComposingWord = false;
|
||||||
@ -847,6 +856,9 @@ public final class InputLogic {
|
|||||||
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
||||||
// If we are in the middle of a recorrection, we need to commit the recorrection
|
// If we are in the middle of a recorrection, we need to commit the recorrection
|
||||||
// first so that we can insert the separator at the current cursor position.
|
// first so that we can insert the separator at the current cursor position.
|
||||||
|
// We also need to unlearn the original word that is now being corrected.
|
||||||
|
unlearnWord(mWordComposer.getTypedWord(), inputTransaction.mSettingsValues,
|
||||||
|
Constants.EVENT_BACKSPACE);
|
||||||
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
||||||
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
||||||
}
|
}
|
||||||
@ -962,6 +974,9 @@ public final class InputLogic {
|
|||||||
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
if (mWordComposer.isCursorFrontOrMiddleOfComposingWord()) {
|
||||||
// If we are in the middle of a recorrection, we need to commit the recorrection
|
// If we are in the middle of a recorrection, we need to commit the recorrection
|
||||||
// first so that we can remove the character at the current cursor position.
|
// first so that we can remove the character at the current cursor position.
|
||||||
|
// We also need to unlearn the original word that is now being corrected.
|
||||||
|
unlearnWord(mWordComposer.getTypedWord(), inputTransaction.mSettingsValues,
|
||||||
|
Constants.EVENT_BACKSPACE);
|
||||||
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
resetEntireInputState(mConnection.getExpectedSelectionStart(),
|
||||||
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
mConnection.getExpectedSelectionEnd(), true /* clearSuggestionStrip */);
|
||||||
// When we exit this if-clause, mWordComposer.isComposingWord() will return false.
|
// When we exit this if-clause, mWordComposer.isComposingWord() will return false.
|
||||||
@ -1046,6 +1061,10 @@ public final class InputLogic {
|
|||||||
// We should backspace one char and restart suggestion if at the end of a word.
|
// We should backspace one char and restart suggestion if at the end of a word.
|
||||||
if (mConnection.hasSelection()) {
|
if (mConnection.hasSelection()) {
|
||||||
// If there is a selection, remove it.
|
// If there is a selection, remove it.
|
||||||
|
// We also need to unlearn the selected text.
|
||||||
|
final CharSequence selection = mConnection.getSelectedText(0 /* 0 for no styles */);
|
||||||
|
unlearnWord(selection.toString(), inputTransaction.mSettingsValues,
|
||||||
|
Constants.EVENT_BACKSPACE);
|
||||||
final int numCharsDeleted = mConnection.getExpectedSelectionEnd()
|
final int numCharsDeleted = mConnection.getExpectedSelectionEnd()
|
||||||
- mConnection.getExpectedSelectionStart();
|
- mConnection.getExpectedSelectionStart();
|
||||||
mConnection.setSelection(mConnection.getExpectedSelectionEnd(),
|
mConnection.setSelection(mConnection.getExpectedSelectionEnd(),
|
||||||
|
Loading…
Reference in New Issue
Block a user