1267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard/*
2267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard * Copyright (C) 2012 The Android Open Source Project
3267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard *
48aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * Licensed under the Apache License, Version 2.0 (the "License");
58aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * you may not use this file except in compliance with the License.
68aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * You may obtain a copy of the License at
7267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard *
88aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka *      http://www.apache.org/licenses/LICENSE-2.0
9267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard *
10267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard * Unless required by applicable law or agreed to in writing, software
118aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * distributed under the License is distributed on an "AS IS" BASIS,
128aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
138aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * See the License for the specific language governing permissions and
148aa9963a895f9dd5bb1bc92ab2e4f461e058f87aTadashi G. Takaoka * limitations under the License.
15267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard */
16267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard
17267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalardpackage com.android.inputmethod.latin;
18267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard
192692a8700737d8eed268039aa27b22a31669da08Jean Chalardimport android.text.TextUtils;
202692a8700737d8eed268039aa27b22a31669da08Jean Chalard
21f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalardimport com.android.inputmethod.event.Event;
2236799b2aa2982ec17341cd2c5ed81e608bcee8c6Jean Chalardimport com.android.inputmethod.latin.common.InputPointers;
230f7d881dc72132dfd75c8b4fe61a69fc5cdcd460Mohammadinamul Sheikimport com.android.inputmethod.latin.define.DecoderSpecificConstants;
24f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalard
25f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalardimport java.util.ArrayList;
26f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalard
27267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard/**
28267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard * This class encapsulates data about a word previously composed, but that has been
29267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard * committed already. This is used for resuming suggestion, and cancel auto-correction.
30267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard */
31a28a05e971cc242b338331a3b78276fa95188d19Tadashi G. Takaokapublic final class LastComposedWord {
32267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // COMMIT_TYPE_USER_TYPED_WORD is used when the word committed is the exact typed word, with
33267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // no hinting from the IME. It happens when some external event happens (rotating the device,
34267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // for example) or when auto-correction is off by settings or editor attributes.
35267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    public static final int COMMIT_TYPE_USER_TYPED_WORD = 0;
36267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // COMMIT_TYPE_MANUAL_PICK is used when the user pressed a field in the suggestion strip.
37267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    public static final int COMMIT_TYPE_MANUAL_PICK = 1;
38267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // COMMIT_TYPE_DECIDED_WORD is used when the IME commits the word it decided was best
39267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // for the current user input. It may be different from what the user typed (true auto-correct)
40267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // or it may be exactly what the user typed if it's in the dictionary or the IME does not have
41267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // enough confidence in any suggestion to auto-correct (auto-correct to typed word).
42267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    public static final int COMMIT_TYPE_DECIDED_WORD = 2;
43267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // COMMIT_TYPE_CANCEL_AUTO_CORRECT is used upon committing back the old word upon cancelling
44267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    // an auto-correction.
45267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    public static final int COMMIT_TYPE_CANCEL_AUTO_CORRECT = 3;
46267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard
47a05a0f20776b4c33f41f043f1bff245331937580Jean Chalard    public static final String NOT_A_SEPARATOR = "";
4866bb563535dbe3672f99f75bd71763a551444867Jean Chalard
49f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalard    public final ArrayList<Event> mEvents;
501f8fc62ccb5018716457dc309ab11ad3e1506ad1Jean Chalard    public final String mTypedWord;
514752b68f5a62ede099677bdea0514ba1d5082606Jean Chalard    public final CharSequence mCommittedWord;
52a05a0f20776b4c33f41f043f1bff245331937580Jean Chalard    public final String mSeparatorString;
53bb0eca57054758ef17b032d2654c1fc5f6b32101Keisuke Kuroyanagi    public final NgramContext mNgramContext;
54b6b7f5e39e9ea1bf9a05203c536327a6be7e7214Jean Chalard    public final int mCapitalizedMode;
5596b22200beb98fd1a6288f4cf53e38611a09cdd0Ken Wakasa    public final InputPointers mInputPointers =
560f7d881dc72132dfd75c8b4fe61a69fc5cdcd460Mohammadinamul Sheik            new InputPointers(DecoderSpecificConstants.DICTIONARY_MAX_WORD_LENGTH);
57267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard
58b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard    private boolean mActive;
59b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard
602692a8700737d8eed268039aa27b22a31669da08Jean Chalard    public static final LastComposedWord NOT_A_COMPOSED_WORD =
611ef9d5938e671ce7a9d5c29d95c1364d6d6249eaJean Chalard            new LastComposedWord(new ArrayList<Event>(), null, "", "",
6275715f7d9fb0b19c2ddaf73bf62148c7d19f0a99Jean Chalard            NOT_A_SEPARATOR, null, WordComposer.CAPS_MODE_OFF);
632692a8700737d8eed268039aa27b22a31669da08Jean Chalard
64a7f2500001c53dc5a6de9c2525a75229cc7c6645Jean Chalard    // Warning: this is using the passed objects as is and fully expects them to be
65a7f2500001c53dc5a6de9c2525a75229cc7c6645Jean Chalard    // immutable. Do not fiddle with their contents after you passed them to this constructor.
661ef9d5938e671ce7a9d5c29d95c1364d6d6249eaJean Chalard    public LastComposedWord(final ArrayList<Event> events,
67f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalard            final InputPointers inputPointers, final String typedWord,
68f8accd8839d291f10b218e64aa6b8eb154c92c4cJean Chalard            final CharSequence committedWord, final String separatorString,
69bb0eca57054758ef17b032d2654c1fc5f6b32101Keisuke Kuroyanagi            final NgramContext ngramContext, final int capitalizedMode) {
7071538b08e4e08d556f700ad344562ca2c7b74d82Satoshi Kataoka        if (inputPointers != null) {
7171538b08e4e08d556f700ad344562ca2c7b74d82Satoshi Kataoka            mInputPointers.copy(inputPointers);
7271538b08e4e08d556f700ad344562ca2c7b74d82Satoshi Kataoka        }
731f8fc62ccb5018716457dc309ab11ad3e1506ad1Jean Chalard        mTypedWord = typedWord;
74a91561aa58db1c43092c1caecc051a11fa5391c7Tadashi G. Takaoka        mEvents = new ArrayList<>(events);
75cf9d92629cae88273805eaf7984fcfdd8afd11f5Jean Chalard        mCommittedWord = committedWord;
76a05a0f20776b4c33f41f043f1bff245331937580Jean Chalard        mSeparatorString = separatorString;
77b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard        mActive = true;
78bb0eca57054758ef17b032d2654c1fc5f6b32101Keisuke Kuroyanagi        mNgramContext = ngramContext;
79b6b7f5e39e9ea1bf9a05203c536327a6be7e7214Jean Chalard        mCapitalizedMode = capitalizedMode;
80b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard    }
81b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard
82b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard    public void deactivate() {
83b6b8729374dc68b153f00730c79828532acf1ee5Jean Chalard        mActive = false;
84267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard    }
852692a8700737d8eed268039aa27b22a31669da08Jean Chalard
865935950d4431dd7eef18ebc370f2abeb614465d4Jean Chalard    public boolean canRevertCommit() {
870e9e7e337defe97d4ede8c59d0e925f5401f9292Jean Chalard        return mActive && !TextUtils.isEmpty(mCommittedWord) && !didCommitTypedWord();
882692a8700737d8eed268039aa27b22a31669da08Jean Chalard    }
89193d23f40e1556074f323b7bd9695759f4798efeJean Chalard
900e9e7e337defe97d4ede8c59d0e925f5401f9292Jean Chalard    private boolean didCommitTypedWord() {
91193d23f40e1556074f323b7bd9695759f4798efeJean Chalard        return TextUtils.equals(mTypedWord, mCommittedWord);
92193d23f40e1556074f323b7bd9695759f4798efeJean Chalard    }
93267563d1bb4d8091293fbd8774f0f95ef59f03c4Jean Chalard}
94