summaryrefslogtreecommitdiff
path: root/core/java/android/webkit/L10nUtils.java
diff options
context:
space:
mode:
authorBen Murdoch <benm@google.com>2011-02-25 17:11:02 +0000
committerBen Murdoch <benm@google.com>2011-02-28 14:19:05 +0000
commitd2e91d1dc7c9fcbf792cbc21d283a5915b32cb54 (patch)
tree349696a6dc618ff7b83a51c14fa65f12ccb54647 /core/java/android/webkit/L10nUtils.java
parentb8460ba428e9114aedd9249e187dea6bf3104d78 (diff)
Improve caching of localised strings for Chromium
We read localised strings for Chromium (e.g. for Autofill) from Java. Now we've added more large strings, keep them in WeakReferences and load them lazily rather than on startup. Change-Id: Ibedcaab5ee781699b41b5c03aae866d1d82bb570
Diffstat (limited to 'core/java/android/webkit/L10nUtils.java')
-rw-r--r--core/java/android/webkit/L10nUtils.java35
1 files changed, 24 insertions, 11 deletions
diff --git a/core/java/android/webkit/L10nUtils.java b/core/java/android/webkit/L10nUtils.java
index 43a747ad6642..f59d7d0d6a08 100644
--- a/core/java/android/webkit/L10nUtils.java
+++ b/core/java/android/webkit/L10nUtils.java
@@ -18,8 +18,9 @@ package android.webkit;
import android.content.Context;
-import java.util.List;
-import java.util.Vector;
+import java.lang.ref.SoftReference;
+import java.util.Map;
+import java.util.HashMap;
/**
* @hide
@@ -71,20 +72,32 @@ public class L10nUtils {
com.android.internal.R.string.autofill_card_ignored_re // IDS_AUTOFILL_CARD_IGNORED_RE
};
- private static List<String> mStrings;
+ private static Context mApplicationContext;
+ private static Map<Integer, SoftReference<String> > mStrings;
- public static void loadStrings(Context context) {
- if (mStrings != null) {
- return;
- }
+ public static void setApplicationContext(Context applicationContext) {
+ mApplicationContext = applicationContext.getApplicationContext();
+ }
- mStrings = new Vector<String>(mIdsArray.length);
- for (int i = 0; i < mIdsArray.length; i++) {
- mStrings.add(context.getResources().getString(mIdsArray[i]));
+ private static String loadString(int id) {
+ if (mStrings == null) {
+ mStrings = new HashMap<Integer, SoftReference<String> >(mIdsArray.length);
}
+
+ String localisedString = mApplicationContext.getResources().getString(mIdsArray[id]);
+ mStrings.put(id, new SoftReference<String>(localisedString));
+ return localisedString;
}
public static String getLocalisedString(int id) {
- return mStrings.get(id);
+ if (mStrings == null) {
+ // This is the first time we need a localised string.
+ // loadString will create the Map.
+ return loadString(id);
+ }
+
+ SoftReference<String> ref = mStrings.get(id);
+ boolean needToLoad = ref == null || ref.get() == null;
+ return needToLoad ? loadString(id) : ref.get();
}
}