aboutsummaryrefslogtreecommitdiffstats
path: root/java/src/com/android/inputmethod/latin/Utils.java
diff options
context:
space:
mode:
authorTadashi G. Takaoka <takaoka@google.com>2012-03-21 04:26:39 -0700
committerAndroid (Google) Code Review <android-gerrit@google.com>2012-03-21 04:26:39 -0700
commit4cc44f9f773f6424557e0b938b6bcad638f56afc (patch)
tree3a2e758523272283260c2d45d1d34f1218babe0f /java/src/com/android/inputmethod/latin/Utils.java
parent26e7ce1fa862cf253a4159fa7ca188ff331fa787 (diff)
parent624f1bab39357eb716dfc7ec6b723da3f926f5a2 (diff)
downloadlatinime-4cc44f9f773f6424557e0b938b6bcad638f56afc.tar.gz
latinime-4cc44f9f773f6424557e0b938b6bcad638f56afc.tar.xz
latinime-4cc44f9f773f6424557e0b938b6bcad638f56afc.zip
Merge "Refactor to memorize device dependent override parameters"
Diffstat (limited to '')
-rw-r--r--java/src/com/android/inputmethod/latin/Utils.java22
1 files changed, 22 insertions, 0 deletions
diff --git a/java/src/com/android/inputmethod/latin/Utils.java b/java/src/com/android/inputmethod/latin/Utils.java
index 509bd368d..708634529 100644
--- a/java/src/com/android/inputmethod/latin/Utils.java
+++ b/java/src/com/android/inputmethod/latin/Utils.java
@@ -19,9 +19,11 @@ package com.android.inputmethod.latin;
import android.content.Context;
import android.content.Intent;
import android.content.pm.PackageManager;
+import android.content.res.Resources;
import android.inputmethodservice.InputMethodService;
import android.net.Uri;
import android.os.AsyncTask;
+import android.os.Build;
import android.os.Environment;
import android.os.Handler;
import android.os.HandlerThread;
@@ -43,6 +45,7 @@ import java.io.PrintWriter;
import java.nio.channels.FileChannel;
import java.text.SimpleDateFormat;
import java.util.Date;
+import java.util.HashMap;
public class Utils {
private Utils() {
@@ -465,4 +468,23 @@ public class Utils {
if (TextUtils.isEmpty(info)) return null;
return info;
}
+
+ private static final String HARDWARE_PREFIX = Build.HARDWARE + ",";
+ private static final HashMap<Integer, String> sDeviceOverrideValueMap =
+ new HashMap<Integer, String>();
+
+ public static String getDeviceOverrideValue(Resources res, int overrideResId, String defValue) {
+ final Integer key = overrideResId;
+ if (!sDeviceOverrideValueMap.containsKey(key)) {
+ String overrideValue = defValue;
+ for (final String element : res.getStringArray(overrideResId)) {
+ if (element.startsWith(HARDWARE_PREFIX)) {
+ overrideValue = element.substring(HARDWARE_PREFIX.length());
+ break;
+ }
+ }
+ sDeviceOverrideValueMap.put(key, overrideValue);
+ }
+ return sDeviceOverrideValueMap.get(key);
+ }
}