Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(37)

Unified Diff: ui/android/java/src/org/chromium/ui/base/ResourceBundle.java

Issue 2345143002: Move language pak files to assets. (Closed)
Patch Set: Move language pak files back to assets rather than res. Created 4 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ui/android/java/src/org/chromium/ui/base/ResourceBundle.java
diff --git a/ui/android/java/src/org/chromium/ui/base/ResourceBundle.java b/ui/android/java/src/org/chromium/ui/base/ResourceBundle.java
index adbf8afac277330364f11daeafffa525c5224d7e..c181affe757eec234ee2f5341aab5938ae7e820f 100644
--- a/ui/android/java/src/org/chromium/ui/base/ResourceBundle.java
+++ b/ui/android/java/src/org/chromium/ui/base/ResourceBundle.java
@@ -5,9 +5,8 @@
package org.chromium.ui.base;
import android.content.Context;
-import android.content.res.Resources;
-import android.content.res.TypedArray;
+import org.chromium.base.LocalePakFiles;
import org.chromium.base.ResourceExtractor;
import org.chromium.base.ThreadUtils;
import org.chromium.base.annotations.CalledByNative;
@@ -23,49 +22,27 @@ import java.util.Locale;
*/
@JNINamespace("ui")
public class ResourceBundle {
- private static ResourceExtractor.ResourceEntry[] sActiveLocaleResources;
- /**
- * Applies the reverse mapping done by locale_pak_resources.py.
- */
- private static String toChromeLocaleName(String srcFileName) {
- srcFileName = srcFileName.replace(".lpak", ".pak");
- String[] parts = srcFileName.split("_");
- if (parts.length > 1) {
- int dotIdx = parts[1].indexOf('.');
- return parts[0] + "-" + parts[1].substring(0, dotIdx).toUpperCase(Locale.ENGLISH)
- + parts[1].substring(dotIdx);
- }
- return srcFileName;
- }
+ private static ResourceExtractor.ResourceEntry[] sActiveLocaleResources;
/**
- * Initializes the list of locale packs for the active locale that are
- * present within the apk.
+ * Initializes the list of locale packs for the active locale that are present within the apk.
*
* @param context Any context
- * @param localePaksResId Resource ID locale_paks (generated by
- * locale_pak_resources.py)
+ * @param localePakFiles LocalePakFiles relevant to caller
*/
@SuppressFBWarnings("LI_LAZY_INIT_UPDATE_STATIC") // Not thread-safe.
- public static void initializeLocalePaks(Context context, int localePaksResId) {
+ public static void initializeLocalePaks(Context context, LocalePakFiles localePakFiles) {
ThreadUtils.assertOnUiThread();
assert sActiveLocaleResources == null;
- Resources resources = context.getResources();
- TypedArray resIds = resources.obtainTypedArray(localePaksResId);
- try {
- int len = resIds.length();
- sActiveLocaleResources = new ResourceExtractor.ResourceEntry[len];
- for (int i = 0; i < len; ++i) {
- int resId = resIds.getResourceId(i, 0);
- String resPath = resources.getString(resId);
- String srcBaseName = new File(resPath).getName();
- String dstBaseName = toChromeLocaleName(srcBaseName);
- sActiveLocaleResources[i] = new ResourceExtractor.ResourceEntry(resId, resPath,
- dstBaseName);
- }
- } finally {
- resIds.recycle();
+ String[] pakFiles = localePakFiles.getPakFilesForLocale(Locale.getDefault().getLanguage());
agrieve 2016/09/21 01:06:42 I think this could be simplified quite a bit if we
estevenson 2016/09/21 19:50:56 Done.
+ int len = pakFiles.length;
+ sActiveLocaleResources = new ResourceExtractor.ResourceEntry[len];
+ for (int i = 0; i < len; ++i) {
+ String assetPath = pakFiles[i];
+ String fileName = new File(assetPath).getName();
+ sActiveLocaleResources[i] = new ResourceExtractor.ResourceEntry(fileName,
+ assetPath);
}
}
@@ -81,7 +58,7 @@ public class ResourceBundle {
}
String fileName = locale + ".pak";
for (ResourceExtractor.ResourceEntry entry : sActiveLocaleResources) {
- if (fileName.equals(entry.extractedFileName)) {
+ if (fileName.equals(entry.fileName)) {
return entry.pathWithinApk;
}
}

Powered by Google App Engine
This is Rietveld 408576698