aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/latin/utils/StringUtils.java
diff options
context:
space:
mode:
authorTadashi G. Takaoka <takaoka@google.com>2014-01-30 22:18:49 -0800
committerAndroid Git Automerger <android-git-automerger@android.com>2014-01-30 22:18:49 -0800
commitee36b665ffd7a30fdf857cadc7bb7d9788aee516 (patch)
tree38bdcf0961a9493d1dd46626b509d52a019e3dd8 /java/src/com/android/inputmethod/latin/utils/StringUtils.java
parent2fe4cdf4ebd4c0cf1fed726694d5cb7cd2c45a0a (diff)
parentde76e62b698b5573d2de88f88205dfe7170e2321 (diff)
downloadlatinime-ee36b665ffd7a30fdf857cadc7bb7d9788aee516.tar.gz
latinime-ee36b665ffd7a30fdf857cadc7bb7d9788aee516.tar.xz
latinime-ee36b665ffd7a30fdf857cadc7bb7d9788aee516.zip
am de76e62b: Merge "Move some methods to StringUtils"
* commit 'de76e62b698b5573d2de88f88205dfe7170e2321': Move some methods to StringUtils
Diffstat (limited to 'java/src/com/android/inputmethod/latin/utils/StringUtils.java')
-rw-r--r--java/src/com/android/inputmethod/latin/utils/StringUtils.java18
1 files changed, 18 insertions, 0 deletions
diff --git a/java/src/com/android/inputmethod/latin/utils/StringUtils.java b/java/src/com/android/inputmethod/latin/utils/StringUtils.java
index b154623ae..c632a71a9 100644
--- a/java/src/com/android/inputmethod/latin/utils/StringUtils.java
+++ b/java/src/com/android/inputmethod/latin/utils/StringUtils.java
@@ -16,6 +16,8 @@
package com.android.inputmethod.latin.utils;
+import static com.android.inputmethod.latin.Constants.CODE_UNSPECIFIED;
+
import android.text.TextUtils;
import com.android.inputmethod.annotations.UsedForTesting;
@@ -471,4 +473,20 @@ public final class StringUtils {
}
return bytes;
}
+
+ public static String toUpperCaseOfStringForLocale(final String text,
+ final boolean needsToUpperCase, final Locale locale) {
+ if (text == null || !needsToUpperCase) return text;
+ return text.toUpperCase(locale);
+ }
+
+ public static int toUpperCaseOfCodeForLocale(final int code, final boolean needsToUpperCase,
+ final Locale locale) {
+ if (!Constants.isLetterCode(code) || !needsToUpperCase) return code;
+ final String text = newSingleCodePointString(code);
+ final String casedText = toUpperCaseOfStringForLocale(
+ text, needsToUpperCase, locale);
+ return codePointCount(casedText) == 1
+ ? casedText.codePointAt(0) : CODE_UNSPECIFIED;
+ }
}