2012-12-06 11:35:59 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2012 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package com.android.inputmethod.event;
|
|
|
|
|
2014-08-28 05:41:39 +00:00
|
|
|
import com.android.inputmethod.annotations.ExternallyReferenced;
|
2014-03-04 09:06:50 +00:00
|
|
|
import com.android.inputmethod.latin.SuggestedWords.SuggestedWordInfo;
|
2014-10-23 09:37:32 +00:00
|
|
|
import com.android.inputmethod.latin.common.Constants;
|
2014-10-28 12:31:09 +00:00
|
|
|
import com.android.inputmethod.latin.common.StringUtils;
|
2014-03-12 07:41:45 +00:00
|
|
|
|
2014-10-20 05:48:56 +00:00
|
|
|
import javax.annotation.Nonnull;
|
|
|
|
|
2012-12-06 11:35:59 +00:00
|
|
|
/**
|
|
|
|
* Class representing a generic input event as handled by Latin IME.
|
|
|
|
*
|
|
|
|
* This contains information about the origin of the event, but it is generalized and should
|
|
|
|
* represent a software keypress, hardware keypress, or d-pad move alike.
|
|
|
|
* Very importantly, this does not necessarily result in inputting one character, or even anything
|
|
|
|
* at all - it may be a dead key, it may be a partial input, it may be a special key on the
|
|
|
|
* keyboard, it may be a cancellation of a keypress (e.g. in a soft keyboard the finger of the
|
|
|
|
* user has slid out of the key), etc. It may also be a batch input from a gesture or handwriting
|
|
|
|
* for example.
|
|
|
|
* The combiner should figure out what to do with this.
|
|
|
|
*/
|
|
|
|
public class Event {
|
2012-12-21 10:01:19 +00:00
|
|
|
// Should the types below be represented by separate classes instead? It would be cleaner
|
|
|
|
// but probably a bit too much
|
|
|
|
// An event we don't handle in Latin IME, for example pressing Ctrl on a hardware keyboard.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_NOT_HANDLED = 0;
|
2014-03-12 07:08:21 +00:00
|
|
|
// A key press that is part of input, for example pressing an alphabetic character on a
|
|
|
|
// hardware qwerty keyboard. It may be part of a sequence that will be re-interpreted later
|
|
|
|
// through combination.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_INPUT_KEYPRESS = 1;
|
2012-12-21 10:01:19 +00:00
|
|
|
// A toggle event is triggered by a key that affects the previous character. An example would
|
|
|
|
// be a numeric key on a 10-key keyboard, which would toggle between 1 - a - b - c with
|
|
|
|
// repeated presses.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_TOGGLE = 2;
|
2012-12-21 10:01:19 +00:00
|
|
|
// A mode event instructs the combiner to change modes. The canonical example would be the
|
|
|
|
// hankaku/zenkaku key on a Japanese keyboard, or even the caps lock key on a qwerty keyboard
|
|
|
|
// if handled at the combiner level.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_MODE_KEY = 3;
|
2014-03-12 07:08:21 +00:00
|
|
|
// An event corresponding to a gesture.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_GESTURE = 4;
|
2014-03-04 09:06:50 +00:00
|
|
|
// An event corresponding to the manual pick of a suggestion.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_SUGGESTION_PICKED = 5;
|
2014-03-19 06:59:49 +00:00
|
|
|
// An event corresponding to a string generated by some software process.
|
2014-03-18 06:14:27 +00:00
|
|
|
final public static int EVENT_TYPE_SOFTWARE_GENERATED_STRING = 6;
|
2014-12-22 08:18:56 +00:00
|
|
|
// An event corresponding to a cursor move
|
|
|
|
final public static int EVENT_TYPE_CURSOR_MOVE = 7;
|
2012-12-21 10:01:19 +00:00
|
|
|
|
2014-03-12 07:08:21 +00:00
|
|
|
// 0 is a valid code point, so we use -1 here.
|
|
|
|
final public static int NOT_A_CODE_POINT = -1;
|
|
|
|
// -1 is a valid key code, so we use 0 here.
|
|
|
|
final public static int NOT_A_KEY_CODE = 0;
|
|
|
|
|
|
|
|
final private static int FLAG_NONE = 0;
|
|
|
|
// This event is a dead character, usually input by a dead key. Examples include dead-acute
|
|
|
|
// or dead-abovering.
|
|
|
|
final private static int FLAG_DEAD = 0x1;
|
2014-03-31 10:43:12 +00:00
|
|
|
// This event is coming from a key repeat, software or hardware.
|
|
|
|
final private static int FLAG_REPEAT = 0x2;
|
2014-07-01 04:07:47 +00:00
|
|
|
// This event has already been consumed.
|
|
|
|
final private static int FLAG_CONSUMED = 0x4;
|
2012-12-21 10:01:19 +00:00
|
|
|
|
2014-03-18 06:14:27 +00:00
|
|
|
final private int mEventType; // The type of event - one of the constants above
|
2012-12-21 10:01:19 +00:00
|
|
|
// The code point associated with the event, if relevant. This is a unicode code point, and
|
|
|
|
// has nothing to do with other representations of the key. It is only relevant if this event
|
2014-03-12 07:08:21 +00:00
|
|
|
// is of KEYPRESS type, but for a mode key like hankaku/zenkaku or ctrl, there is no code point
|
|
|
|
// associated so this should be NOT_A_CODE_POINT to avoid unintentional use of its value when
|
|
|
|
// it's not relevant.
|
2013-01-09 12:08:58 +00:00
|
|
|
final public int mCodePoint;
|
2014-03-12 07:08:21 +00:00
|
|
|
|
2014-03-19 06:59:49 +00:00
|
|
|
// If applicable, this contains the string that should be input.
|
|
|
|
final public CharSequence mText;
|
|
|
|
|
2014-03-12 07:08:21 +00:00
|
|
|
// The key code associated with the event, if relevant. This is relevant whenever this event
|
|
|
|
// has been triggered by a key press, but not for a gesture for example. This has conceptually
|
|
|
|
// no link to the code point, although keys that enter a straight code point may often set
|
|
|
|
// this to be equal to mCodePoint for convenience. If this is not a key, this must contain
|
|
|
|
// NOT_A_KEY_CODE.
|
|
|
|
final public int mKeyCode;
|
|
|
|
|
2014-03-12 07:41:45 +00:00
|
|
|
// Coordinates of the touch event, if relevant. If useful, we may want to replace this with
|
|
|
|
// a MotionEvent or something in the future. This is only relevant when the keypress is from
|
|
|
|
// a software keyboard obviously, unless there are touch-sensitive hardware keyboards in the
|
|
|
|
// future or some other awesome sauce.
|
|
|
|
final public int mX;
|
|
|
|
final public int mY;
|
|
|
|
|
2014-03-12 07:08:21 +00:00
|
|
|
// Some flags that can't go into the key code. It's a bit field of FLAG_*
|
|
|
|
final private int mFlags;
|
|
|
|
|
2014-03-18 06:14:27 +00:00
|
|
|
// If this is of type EVENT_TYPE_SUGGESTION_PICKED, this must not be null (and must be null in
|
2014-03-04 09:06:50 +00:00
|
|
|
// other cases).
|
|
|
|
final public SuggestedWordInfo mSuggestedWordInfo;
|
|
|
|
|
2013-01-08 06:09:04 +00:00
|
|
|
// The next event, if any. Null if there is no next event yet.
|
|
|
|
final public Event mNextEvent;
|
2012-12-21 10:01:19 +00:00
|
|
|
|
2013-01-09 12:08:58 +00:00
|
|
|
// This method is private - to create a new event, use one of the create* utility methods.
|
2014-03-19 06:59:49 +00:00
|
|
|
private Event(final int type, final CharSequence text, final int codePoint, final int keyCode,
|
|
|
|
final int x, final int y, final SuggestedWordInfo suggestedWordInfo, final int flags,
|
|
|
|
final Event next) {
|
2014-03-18 06:14:27 +00:00
|
|
|
mEventType = type;
|
2014-03-19 06:59:49 +00:00
|
|
|
mText = text;
|
2013-01-09 12:08:58 +00:00
|
|
|
mCodePoint = codePoint;
|
2014-03-12 07:08:21 +00:00
|
|
|
mKeyCode = keyCode;
|
2014-03-12 07:41:45 +00:00
|
|
|
mX = x;
|
|
|
|
mY = y;
|
2014-03-04 09:06:50 +00:00
|
|
|
mSuggestedWordInfo = suggestedWordInfo;
|
2014-03-12 07:08:21 +00:00
|
|
|
mFlags = flags;
|
2013-01-08 06:09:04 +00:00
|
|
|
mNextEvent = next;
|
2014-03-04 09:06:50 +00:00
|
|
|
// Sanity checks
|
|
|
|
// mSuggestedWordInfo is non-null if and only if the type is SUGGESTION_PICKED
|
2014-03-18 06:14:27 +00:00
|
|
|
if (EVENT_TYPE_SUGGESTION_PICKED == mEventType) {
|
2014-03-04 09:06:50 +00:00
|
|
|
if (null == mSuggestedWordInfo) {
|
|
|
|
throw new RuntimeException("Wrong event: SUGGESTION_PICKED event must have a "
|
|
|
|
+ "non-null SuggestedWordInfo");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (null != mSuggestedWordInfo) {
|
|
|
|
throw new RuntimeException("Wrong event: only SUGGESTION_PICKED events may have " +
|
|
|
|
"a non-null SuggestedWordInfo");
|
|
|
|
}
|
|
|
|
}
|
2012-12-06 11:35:59 +00:00
|
|
|
}
|
2012-12-21 10:01:19 +00:00
|
|
|
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-12 07:41:45 +00:00
|
|
|
public static Event createSoftwareKeypressEvent(final int codePoint, final int keyCode,
|
2014-03-31 10:43:12 +00:00
|
|
|
final int x, final int y, final boolean isKeyRepeat) {
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_INPUT_KEYPRESS, null /* text */, codePoint, keyCode, x, y,
|
2014-03-31 10:43:12 +00:00
|
|
|
null /* suggestedWordInfo */, isKeyRepeat ? FLAG_REPEAT : FLAG_NONE, null);
|
2014-03-12 07:41:45 +00:00
|
|
|
}
|
|
|
|
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-12 07:41:45 +00:00
|
|
|
public static Event createHardwareKeypressEvent(final int codePoint, final int keyCode,
|
2014-03-31 10:43:12 +00:00
|
|
|
final Event next, final boolean isKeyRepeat) {
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_INPUT_KEYPRESS, null /* text */, codePoint, keyCode,
|
2014-03-12 07:41:45 +00:00
|
|
|
Constants.EXTERNAL_KEYBOARD_COORDINATE, Constants.EXTERNAL_KEYBOARD_COORDINATE,
|
2014-03-31 10:43:12 +00:00
|
|
|
null /* suggestedWordInfo */, isKeyRepeat ? FLAG_REPEAT : FLAG_NONE, next);
|
2012-12-21 10:01:19 +00:00
|
|
|
}
|
|
|
|
|
2014-03-12 07:08:21 +00:00
|
|
|
// This creates an input event for a dead character. @see {@link #FLAG_DEAD}
|
2014-08-28 05:41:39 +00:00
|
|
|
@ExternallyReferenced
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-12 07:08:21 +00:00
|
|
|
public static Event createDeadEvent(final int codePoint, final int keyCode, final Event next) {
|
2014-03-12 07:41:45 +00:00
|
|
|
// TODO: add an argument or something if we ever create a software layout with dead keys.
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_INPUT_KEYPRESS, null /* text */, codePoint, keyCode,
|
2014-03-12 07:41:45 +00:00
|
|
|
Constants.EXTERNAL_KEYBOARD_COORDINATE, Constants.EXTERNAL_KEYBOARD_COORDINATE,
|
2014-03-04 09:06:50 +00:00
|
|
|
null /* suggestedWordInfo */, FLAG_DEAD, next);
|
2012-12-21 10:01:19 +00:00
|
|
|
}
|
|
|
|
|
2014-03-13 08:37:16 +00:00
|
|
|
/**
|
|
|
|
* Create an input event with nothing but a code point. This is the most basic possible input
|
|
|
|
* event; it contains no information on many things the IME requires to function correctly,
|
|
|
|
* so avoid using it unless really nothing is known about this input.
|
|
|
|
* @param codePoint the code point.
|
|
|
|
* @return an event for this code point.
|
|
|
|
*/
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-13 08:37:16 +00:00
|
|
|
public static Event createEventForCodePointFromUnknownSource(final int codePoint) {
|
|
|
|
// TODO: should we have a different type of event for this? After all, it's not a key press.
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_INPUT_KEYPRESS, null /* text */, codePoint, NOT_A_KEY_CODE,
|
2014-03-04 09:06:50 +00:00
|
|
|
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE,
|
|
|
|
null /* suggestedWordInfo */, FLAG_NONE, null /* next */);
|
2014-03-13 08:37:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an input event with a code point and x, y coordinates. This is typically used when
|
|
|
|
* resuming a previously-typed word, when the coordinates are still known.
|
|
|
|
* @param codePoint the code point to input.
|
|
|
|
* @param x the X coordinate.
|
|
|
|
* @param y the Y coordinate.
|
|
|
|
* @return an event for this code point and coordinates.
|
|
|
|
*/
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-13 08:37:16 +00:00
|
|
|
public static Event createEventForCodePointFromAlreadyTypedText(final int codePoint,
|
|
|
|
final int x, final int y) {
|
|
|
|
// TODO: should we have a different type of event for this? After all, it's not a key press.
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_INPUT_KEYPRESS, null /* text */, codePoint, NOT_A_KEY_CODE,
|
|
|
|
x, y, null /* suggestedWordInfo */, FLAG_NONE, null /* next */);
|
2014-03-04 09:06:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Creates an input event representing the manual pick of a suggestion.
|
|
|
|
* @return an event for this suggestion pick.
|
|
|
|
*/
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-04 09:06:50 +00:00
|
|
|
public static Event createSuggestionPickedEvent(final SuggestedWordInfo suggestedWordInfo) {
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_SUGGESTION_PICKED, suggestedWordInfo.mWord,
|
2014-03-19 06:59:49 +00:00
|
|
|
NOT_A_CODE_POINT, NOT_A_KEY_CODE,
|
2014-03-04 09:06:50 +00:00
|
|
|
Constants.SUGGESTION_STRIP_COORDINATE, Constants.SUGGESTION_STRIP_COORDINATE,
|
2014-03-18 06:14:27 +00:00
|
|
|
suggestedWordInfo, FLAG_NONE, null /* next */);
|
2014-03-13 08:37:16 +00:00
|
|
|
}
|
|
|
|
|
2014-03-19 06:59:49 +00:00
|
|
|
/**
|
|
|
|
* Creates an input event with a CharSequence. This is used by some software processes whose
|
|
|
|
* output is a string, possibly with styling. Examples include press on a multi-character key,
|
|
|
|
* or combination that outputs a string.
|
|
|
|
* @param text the CharSequence associated with this event.
|
|
|
|
* @param keyCode the key code, or NOT_A_KEYCODE if not applicable.
|
|
|
|
* @return an event for this text.
|
|
|
|
*/
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-03-19 06:59:49 +00:00
|
|
|
public static Event createSoftwareTextEvent(final CharSequence text, final int keyCode) {
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_SOFTWARE_GENERATED_STRING, text, NOT_A_CODE_POINT, keyCode,
|
2014-03-19 06:59:49 +00:00
|
|
|
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE,
|
|
|
|
null /* suggestedWordInfo */, FLAG_NONE, null /* next */);
|
|
|
|
}
|
|
|
|
|
2014-03-18 06:14:27 +00:00
|
|
|
/**
|
|
|
|
* Creates an input event representing the manual pick of a punctuation suggestion.
|
|
|
|
* @return an event for this suggestion pick.
|
|
|
|
*/
|
2014-10-22 05:04:07 +00:00
|
|
|
@Nonnull
|
2014-03-18 06:14:27 +00:00
|
|
|
public static Event createPunctuationSuggestionPickedEvent(
|
|
|
|
final SuggestedWordInfo suggestedWordInfo) {
|
|
|
|
final int primaryCode = suggestedWordInfo.mWord.charAt(0);
|
|
|
|
return new Event(EVENT_TYPE_SUGGESTION_PICKED, suggestedWordInfo.mWord, primaryCode,
|
|
|
|
NOT_A_KEY_CODE, Constants.SUGGESTION_STRIP_COORDINATE,
|
|
|
|
Constants.SUGGESTION_STRIP_COORDINATE, suggestedWordInfo, FLAG_NONE,
|
|
|
|
null /* next */);
|
|
|
|
}
|
|
|
|
|
2014-12-22 08:18:56 +00:00
|
|
|
/**
|
|
|
|
* Creates an input event representing moving the cursor. The relative move amount is stored
|
|
|
|
* in mX.
|
|
|
|
* @param moveAmount the relative move amount.
|
|
|
|
* @return an event for this cursor move.
|
|
|
|
*/
|
|
|
|
@Nonnull
|
|
|
|
public static Event createCursorMovedEvent(final int moveAmount) {
|
|
|
|
return new Event(EVENT_TYPE_CURSOR_MOVE, null, NOT_A_CODE_POINT, NOT_A_KEY_CODE,
|
|
|
|
moveAmount, Constants.NOT_A_COORDINATE, null, FLAG_NONE, null);
|
|
|
|
}
|
|
|
|
|
2014-07-01 04:07:47 +00:00
|
|
|
/**
|
|
|
|
* Creates an event identical to the passed event, but that has already been consumed.
|
|
|
|
* @param source the event to copy the properties of.
|
|
|
|
* @return an identical event marked as consumed.
|
|
|
|
*/
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2014-07-01 04:07:47 +00:00
|
|
|
public static Event createConsumedEvent(final Event source) {
|
2014-08-01 05:15:33 +00:00
|
|
|
// A consumed event should not input any text at all, so we pass the empty string as text.
|
2014-07-01 04:07:47 +00:00
|
|
|
return new Event(source.mEventType, source.mText, source.mCodePoint, source.mKeyCode,
|
|
|
|
source.mX, source.mY, source.mSuggestedWordInfo, source.mFlags | FLAG_CONSUMED,
|
|
|
|
source.mNextEvent);
|
|
|
|
}
|
|
|
|
|
2014-10-20 05:48:56 +00:00
|
|
|
@Nonnull
|
2013-01-09 12:08:58 +00:00
|
|
|
public static Event createNotHandledEvent() {
|
2014-03-18 06:14:27 +00:00
|
|
|
return new Event(EVENT_TYPE_NOT_HANDLED, null /* text */, NOT_A_CODE_POINT, NOT_A_KEY_CODE,
|
2014-03-04 09:06:50 +00:00
|
|
|
Constants.NOT_A_COORDINATE, Constants.NOT_A_COORDINATE,
|
|
|
|
null /* suggestedWordInfo */, FLAG_NONE, null);
|
2012-12-21 10:01:19 +00:00
|
|
|
}
|
2012-12-26 06:38:53 +00:00
|
|
|
|
2014-06-25 07:50:27 +00:00
|
|
|
// Returns whether this is a function key like backspace, ctrl, settings... as opposed to keys
|
|
|
|
// that result in input like letters or space.
|
|
|
|
public boolean isFunctionalKeyEvent() {
|
|
|
|
// This logic may need to be refined in the future
|
|
|
|
return NOT_A_CODE_POINT == mCodePoint;
|
|
|
|
}
|
|
|
|
|
2014-03-12 07:08:21 +00:00
|
|
|
// Returns whether this event is for a dead character. @see {@link #FLAG_DEAD}
|
|
|
|
public boolean isDead() {
|
|
|
|
return 0 != (FLAG_DEAD & mFlags);
|
2012-12-26 06:38:53 +00:00
|
|
|
}
|
2013-01-08 03:57:50 +00:00
|
|
|
|
2014-03-31 10:43:12 +00:00
|
|
|
public boolean isKeyRepeat() {
|
|
|
|
return 0 != (FLAG_REPEAT & mFlags);
|
|
|
|
}
|
|
|
|
|
2014-07-01 04:07:47 +00:00
|
|
|
public boolean isConsumed() { return 0 != (FLAG_CONSUMED & mFlags); }
|
|
|
|
|
2014-08-14 03:48:50 +00:00
|
|
|
public boolean isGesture() { return EVENT_TYPE_GESTURE == mEventType; }
|
|
|
|
|
2014-03-12 08:02:13 +00:00
|
|
|
// Returns whether this is a fake key press from the suggestion strip. This happens with
|
|
|
|
// punctuation signs selected from the suggestion strip.
|
|
|
|
public boolean isSuggestionStripPress() {
|
2014-03-18 06:14:27 +00:00
|
|
|
return EVENT_TYPE_SUGGESTION_PICKED == mEventType;
|
2014-03-12 08:02:13 +00:00
|
|
|
}
|
|
|
|
|
2014-03-14 11:11:01 +00:00
|
|
|
public boolean isHandled() {
|
2014-03-18 06:14:27 +00:00
|
|
|
return EVENT_TYPE_NOT_HANDLED != mEventType;
|
2014-03-14 11:11:01 +00:00
|
|
|
}
|
2014-03-19 08:16:09 +00:00
|
|
|
|
|
|
|
public CharSequence getTextToCommit() {
|
2014-08-01 05:15:33 +00:00
|
|
|
if (isConsumed()) {
|
|
|
|
return ""; // A consumed event should input no text.
|
|
|
|
}
|
2014-03-18 06:14:27 +00:00
|
|
|
switch (mEventType) {
|
|
|
|
case EVENT_TYPE_MODE_KEY:
|
|
|
|
case EVENT_TYPE_NOT_HANDLED:
|
|
|
|
case EVENT_TYPE_TOGGLE:
|
2014-12-22 08:18:56 +00:00
|
|
|
case EVENT_TYPE_CURSOR_MOVE:
|
2014-03-19 08:16:09 +00:00
|
|
|
return "";
|
2014-03-18 06:14:27 +00:00
|
|
|
case EVENT_TYPE_INPUT_KEYPRESS:
|
2014-03-19 08:16:09 +00:00
|
|
|
return StringUtils.newSingleCodePointString(mCodePoint);
|
2014-03-18 06:14:27 +00:00
|
|
|
case EVENT_TYPE_GESTURE:
|
|
|
|
case EVENT_TYPE_SOFTWARE_GENERATED_STRING:
|
|
|
|
case EVENT_TYPE_SUGGESTION_PICKED:
|
2014-03-19 08:16:09 +00:00
|
|
|
return mText;
|
|
|
|
}
|
2014-03-18 06:14:27 +00:00
|
|
|
throw new RuntimeException("Unknown event type: " + mEventType);
|
2014-03-19 08:16:09 +00:00
|
|
|
}
|
2012-12-06 11:35:59 +00:00
|
|
|
}
|