mirror of
https://gitlab.futo.org/keyboard/latinime.git
synced 2024-09-28 14:54:30 +01:00
This CL simplifies the wrapper method for TextInfo#getCharSequence() because in the almost all cases we want to use the result of TextInfo#getText() as the default value. BUG: 16029304 Change-Id: I62f987aed8ca42b093255e6c0703d6120fa01299
68 lines
2.8 KiB
Java
68 lines
2.8 KiB
Java
/*
|
|
* Copyright (C) 2014 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.compat;
|
|
|
|
import android.view.textservice.TextInfo;
|
|
|
|
import com.android.inputmethod.annotations.UsedForTesting;
|
|
|
|
import java.lang.reflect.Constructor;
|
|
import java.lang.reflect.Method;
|
|
|
|
@UsedForTesting
|
|
public final class TextInfoCompatUtils {
|
|
// Note that TextInfo.getCharSequence() is supposed to be available in API level 21 and later.
|
|
private static final Method TEXT_INFO_GET_CHAR_SEQUENCE =
|
|
CompatUtils.getMethod(TextInfo.class, "getCharSequence");
|
|
private static final Constructor<?> TEXT_INFO_CONSTRUCTOR_FOR_CHAR_SEQUENCE =
|
|
CompatUtils.getConstructor(TextInfo.class, CharSequence.class, int.class, int.class,
|
|
int.class, int.class);
|
|
|
|
@UsedForTesting
|
|
public static boolean isCharSequenceSupported() {
|
|
return TEXT_INFO_GET_CHAR_SEQUENCE != null &&
|
|
TEXT_INFO_CONSTRUCTOR_FOR_CHAR_SEQUENCE != null;
|
|
}
|
|
|
|
@UsedForTesting
|
|
public static TextInfo newInstance(CharSequence charSequence, int start, int end, int cookie,
|
|
int sequenceNumber) {
|
|
if (TEXT_INFO_CONSTRUCTOR_FOR_CHAR_SEQUENCE != null) {
|
|
return (TextInfo) CompatUtils.newInstance(TEXT_INFO_CONSTRUCTOR_FOR_CHAR_SEQUENCE,
|
|
charSequence, start, end, cookie, sequenceNumber);
|
|
}
|
|
return new TextInfo(charSequence.subSequence(start, end).toString(), cookie,
|
|
sequenceNumber);
|
|
}
|
|
|
|
/**
|
|
* Returns the result of {@link TextInfo#getCharSequence()} when available. Otherwise returns
|
|
* the result of {@link TextInfo#getText()} as fall back.
|
|
* @param textInfo the instance for which {@link TextInfo#getCharSequence()} or
|
|
* {@link TextInfo#getText()} is called.
|
|
* @return the result of {@link TextInfo#getCharSequence()} when available. Otherwise returns
|
|
* the result of {@link TextInfo#getText()} as fall back. If {@code textInfo} is {@code null},
|
|
* returns {@code null}.
|
|
*/
|
|
@UsedForTesting
|
|
public static CharSequence getCharSequenceOrString(final TextInfo textInfo) {
|
|
final CharSequence defaultValue = (textInfo == null ? null : textInfo.getText());
|
|
return (CharSequence) CompatUtils.invoke(textInfo, defaultValue,
|
|
TEXT_INFO_GET_CHAR_SEQUENCE);
|
|
}
|
|
}
|