summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlex Mineer <amineer@google.com>2015-06-22 08:43:53 -0700
committerAlex Mineer <amineer@google.com>2015-06-22 15:44:40 +0000
commit69e3ae50f872374fe6bf5d1a20295385ee094abc (patch)
treeb6ff734c84158d8aff4939b4233e501d0c52a6cd
parente87f07b19ff269a4126492dd6e08259532ce3ba1 (diff)
downloadchromium_src-69e3ae50f872374fe6bf5d1a20295385ee094abc.zip
chromium_src-69e3ae50f872374fe6bf5d1a20295385ee094abc.tar.gz
chromium_src-69e3ae50f872374fe6bf5d1a20295385ee094abc.tar.bz2
Revert "Android: Store language .pak files in res/raw rather than assets"
This reverts commit f30e04470453ccd7e6a9abf586185b991d174902. This change breaks android TOT bot TBR=yfriedman@chromium.org,torne@chromium.org,cjhopman@chromium.org,jaekyun@chromium.org,jhawkins@chromium.org,gunsch@chromium.org,newt@chromium.org,agrieve@chromium.org BUG=371610 Review URL: https://codereview.chromium.org/1200583002 (cherry picked from commit bd0057ca4ca5990173e099f5cdd5219c6ed72fd5) Cr-Original-Commit-Position: refs/heads/master@{#335432} Cr-Commit-Position: refs/branch-heads/2438@{#6} Cr-Branched-From: 674a266831501f840425eb864141feb600aeb5ee-refs/heads/master@{#335429}
-rw-r--r--android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java2
-rw-r--r--android_webview/test/shell/src/org/chromium/android_webview/shell/AwShellApplication.java3
-rw-r--r--base/android/java/src/org/chromium/base/ResourceExtractor.java215
-rwxr-xr-xbuild/android/gyp/locale_pak_resources.py97
-rw-r--r--build/android/locale_pak_resources.gypi52
-rw-r--r--build/config/android/rules.gni63
-rw-r--r--chrome/android/BUILD.gn29
-rw-r--r--chrome/android/java_staging/src/org/chromium/chrome/browser/ChromeMobileApplication.java6
-rw-r--r--chrome/android/shell/java/src/org/chromium/chrome/shell/ChromeShellApplication.java4
-rw-r--r--chrome/chrome.gyp13
-rw-r--r--chrome/chrome_android_paks.gypi46
-rw-r--r--chromecast/browser/android/apk/src/org/chromium/chromecast/shell/CastApplication.java2
-rw-r--r--components/test/android/browsertests_apk/src/org/chromium/components_browsertests_apk/ComponentsBrowserTestsApplication.java2
-rw-r--r--content/shell/android/browsertests_apk/src/org/chromium/content_browsertests_apk/ContentBrowserTestsApplication.java2
-rw-r--r--content/shell/android/linker_test_apk/src/org/chromium/chromium_linker_test_apk/ChromiumLinkerTestApplication.java2
-rw-r--r--content/shell/android/shell_apk/src/org/chromium/content_shell_apk/ContentShellApplication.java2
16 files changed, 188 insertions, 352 deletions
diff --git a/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java b/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
index 96ca680..5ef433e 100644
--- a/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
+++ b/android_webview/glue/java/src/com/android/webview/chromium/WebViewChromiumFactoryProvider.java
@@ -232,7 +232,7 @@ public class WebViewChromiumFactoryProvider implements WebViewFactoryProvider {
// We don't need to extract any paks because for WebView, they are
// in the system image.
- ResourceExtractor.setMandatoryPaksToExtract(0);
+ ResourceExtractor.setMandatoryPaksToExtract("");
try {
LibraryLoader.get(LibraryProcessType.PROCESS_WEBVIEW).ensureInitialized();
diff --git a/android_webview/test/shell/src/org/chromium/android_webview/shell/AwShellApplication.java b/android_webview/test/shell/src/org/chromium/android_webview/shell/AwShellApplication.java
index f6dc9a5..986785e 100644
--- a/android_webview/test/shell/src/org/chromium/android_webview/shell/AwShellApplication.java
+++ b/android_webview/test/shell/src/org/chromium/android_webview/shell/AwShellApplication.java
@@ -46,7 +46,8 @@ public class AwShellApplication extends ContentApplication {
@Override
protected void initializeLibraryDependencies() {
- ResourceExtractor.setMandatoryPaksToExtract(0);
+ ResourceExtractor.setMandatoryPaksToExtract("");
+ ResourceExtractor.setExtractImplicitLocaleForTesting(false);
}
@Override
diff --git a/base/android/java/src/org/chromium/base/ResourceExtractor.java b/base/android/java/src/org/chromium/base/ResourceExtractor.java
index 584dfae..dd654ff 100644
--- a/base/android/java/src/org/chromium/base/ResourceExtractor.java
+++ b/base/android/java/src/org/chromium/base/ResourceExtractor.java
@@ -6,16 +6,16 @@ package org.chromium.base;
import android.annotation.TargetApi;
import android.content.Context;
+import android.content.SharedPreferences;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.res.AssetManager;
-import android.content.res.Resources;
-import android.content.res.TypedArray;
import android.os.AsyncTask;
import android.os.Build;
import android.os.Handler;
import android.os.Looper;
import android.os.Trace;
+import android.preference.PreferenceManager;
import android.util.Log;
import java.io.File;
@@ -26,9 +26,9 @@ import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.List;
-import java.util.Locale;
import java.util.concurrent.CancellationException;
import java.util.concurrent.ExecutionException;
+import java.util.regex.Pattern;
/**
* Handles extracting the necessary resources bundled in an APK and moving them to a location on
@@ -37,24 +37,23 @@ import java.util.concurrent.ExecutionException;
public class ResourceExtractor {
private static final String LOGTAG = "ResourceExtractor";
+ private static final String LAST_LANGUAGE = "Last language";
+ private static final String PAK_FILENAMES_LEGACY_NOREUSE = "Pak filenames";
private static final String ICU_DATA_FILENAME = "icudtl.dat";
private static final String V8_NATIVES_DATA_FILENAME = "natives_blob.bin";
private static final String V8_SNAPSHOT_DATA_FILENAME = "snapshot_blob.bin";
private static String[] sMandatoryPaks = null;
- private static int sLocalePaksResId = -1;
- /**
- * Applies the reverse mapping done by locale_pak_resources.py.
- */
- private static String toChromeLocaleName(String srcFileName) {
- 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;
+ // By default, we attempt to extract a pak file for the users
+ // current device locale. Use setExtractImplicitLocale() to
+ // change this behavior.
+ private static boolean sExtractImplicitLocalePak = true;
+
+ private static boolean isAppDataFile(String file) {
+ return ICU_DATA_FILENAME.equals(file)
+ || V8_NATIVES_DATA_FILENAME.equals(file)
+ || V8_SNAPSHOT_DATA_FILENAME.equals(file);
}
private class ExtractTask extends AsyncTask<Void, Void, Void> {
@@ -62,38 +61,12 @@ public class ResourceExtractor {
private final List<Runnable> mCompletionCallbacks = new ArrayList<Runnable>();
- private void extractResourceHelper(InputStream is, File outFile, byte[] buffer)
- throws IOException {
- OutputStream os = null;
- try {
- os = new FileOutputStream(outFile);
- Log.i(LOGTAG, "Extracting resource " + outFile);
-
- int count = 0;
- while ((count = is.read(buffer, 0, BUFFER_SIZE)) != -1) {
- os.write(buffer, 0, count);
- }
- os.flush();
-
- // Ensure something reasonable was written.
- if (outFile.length() == 0) {
- throw new IOException(outFile + " extracted with 0 length!");
- }
- } finally {
- try {
- if (is != null) {
- is.close();
- }
- } finally {
- if (os != null) {
- os.close();
- }
- }
- }
+ public ExtractTask() {
}
private void doInBackgroundImpl() {
final File outputDir = getOutputDir();
+ final File appDataDir = getAppDataDir();
if (!outputDir.exists() && !outputDir.mkdirs()) {
Log.e(LOGTAG, "Unable to create pak resources directory!");
return;
@@ -110,50 +83,97 @@ public class ResourceExtractor {
deleteFiles();
}
+ SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(mContext);
+ String currentLocale = LocaleUtils.getDefaultLocale();
+ String currentLanguage = currentLocale.split("-", 2)[0];
+ // If everything we need is already there (and the locale hasn't
+ // changed), quick exit.
+ if (prefs.getString(LAST_LANGUAGE, "").equals(currentLanguage)) {
+ boolean filesPresent = true;
+ for (String file : sMandatoryPaks) {
+ File directory = isAppDataFile(file) ? appDataDir : outputDir;
+ if (!new File(directory, file).exists()) {
+ filesPresent = false;
+ break;
+ }
+ }
+ if (filesPresent) return;
+ } else {
+ prefs.edit().putString(LAST_LANGUAGE, currentLanguage).apply();
+ }
+
+ StringBuilder p = new StringBuilder();
+ for (String mandatoryPak : sMandatoryPaks) {
+ if (p.length() > 0) p.append('|');
+ p.append("\\Q" + mandatoryPak + "\\E");
+ }
+
+ if (sExtractImplicitLocalePak) {
+ if (p.length() > 0) p.append('|');
+ // As well as the minimum required set of .paks above, we'll
+ // also add all .paks that we have for the user's currently
+ // selected language.
+ p.append(currentLanguage);
+ p.append("(-\\w+)?\\.pak");
+ }
+
+ Pattern paksToInstall = Pattern.compile(p.toString());
+
+ AssetManager manager = mContext.getResources().getAssets();
beginTraceSection("WalkAssets");
- AssetManager assetManager = mContext.getAssets();
- byte[] buffer = new byte[BUFFER_SIZE];
try {
- // Extract all files that don't already exist.
- for (String fileName : sMandatoryPaks) {
- File output = new File(outputDir, fileName);
+ // Loop through every asset file that we have in the APK, and look for the
+ // ones that we need to extract by trying to match the Patterns that we
+ // created above.
+ byte[] buffer = null;
+ String[] files = manager.list("");
+ for (String file : files) {
+ if (!paksToInstall.matcher(file).matches()) {
+ continue;
+ }
+ File output = new File(isAppDataFile(file) ? appDataDir : outputDir, file);
if (output.exists()) {
continue;
}
+
+ InputStream is = null;
+ OutputStream os = null;
beginTraceSection("ExtractResource");
- InputStream inputStream = assetManager.open(fileName);
try {
- extractResourceHelper(inputStream, output, buffer);
- } finally {
- endTraceSection(); // ExtractResource
- }
- }
+ is = manager.open(file);
+ os = new FileOutputStream(output);
+ Log.i(LOGTAG, "Extracting resource " + file);
+ if (buffer == null) {
+ buffer = new byte[BUFFER_SIZE];
+ }
- if (sLocalePaksResId != 0) {
- // locale_paks yields the current language's pak file paths.
- Resources resources = mContext.getResources();
- TypedArray resIds = resources.obtainTypedArray(sLocalePaksResId);
- try {
- int len = resIds.length();
- 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);
- File output = new File(outputDir, dstBaseName);
- if (output.exists()) {
- continue;
+ int count = 0;
+ while ((count = is.read(buffer, 0, BUFFER_SIZE)) != -1) {
+ os.write(buffer, 0, count);
+ }
+ os.flush();
+
+ // Ensure something reasonable was written.
+ if (output.length() == 0) {
+ throw new IOException(file + " extracted with 0 length!");
+ }
+
+ if (isAppDataFile(file)) {
+ // icu and V8 data need to be accessed by a renderer
+ // process.
+ output.setReadable(true, false);
+ }
+ } finally {
+ try {
+ if (is != null) {
+ is.close();
}
- beginTraceSection("ExtractResource");
- InputStream inputStream = resources.openRawResource(resId);
- try {
- extractResourceHelper(inputStream, output, buffer);
- } finally {
- endTraceSection(); // ExtractResource
+ } finally {
+ if (os != null) {
+ os.close();
}
+ endTraceSection(); // ExtractResource
}
- } finally {
- resIds.recycle();
}
}
} catch (IOException e) {
@@ -283,18 +303,32 @@ public class ResourceExtractor {
}
/**
- * Specifies the files that should be extracted from the APK.
+ * Specifies the .pak files that should be extracted from the APK's asset resources directory
* and moved to {@link #getOutputDirFromContext(Context)}.
- * @param localePaksResId Resource ID for the locale_paks string array. Pass
- * in 0 to disable locale pak extraction.
- * @param paths The list of paths to be extracted.
+ * @param mandatoryPaks The list of pak files to be loaded. If no pak files are
+ * required, pass a single empty string.
*/
- public static void setMandatoryPaksToExtract(int localePaksResId, String... paths) {
+ public static void setMandatoryPaksToExtract(String... mandatoryPaks) {
// TODO(agrieve): Remove the need to call this once all files are loaded from the apk.
assert (sInstance == null || sInstance.mExtractTask == null)
: "Must be called before startExtractingResources is called";
- sLocalePaksResId = localePaksResId;
- sMandatoryPaks = paths;
+ sMandatoryPaks = mandatoryPaks;
+
+ }
+
+ /**
+ * By default the ResourceExtractor will attempt to extract a pak resource for the users
+ * currently specified locale. This behavior can be changed with this function and is
+ * only needed by tests.
+ * @param extract False if we should not attempt to extract a pak file for
+ * the users currently selected locale and try to extract only the
+ * pak files specified in sMandatoryPaks.
+ */
+ @VisibleForTesting
+ public static void setExtractImplicitLocaleForTesting(boolean extract) {
+ assert (sInstance == null || sInstance.mExtractTask == null)
+ : "Must be called before startExtractingResources is called";
+ sExtractImplicitLocalePak = extract;
}
/**
@@ -313,7 +347,7 @@ public class ResourceExtractor {
} catch (IOException e) {
Log.w(LOGTAG, "Exception while accessing assets: " + e.getMessage(), e);
}
- setMandatoryPaksToExtract(0, pakAndSnapshotFileAssets.toArray(
+ setMandatoryPaksToExtract(pakAndSnapshotFileAssets.toArray(
new String[pakAndSnapshotFileAssets.size()]));
}
@@ -386,10 +420,6 @@ public class ResourceExtractor {
return;
}
- // If a previous release extracted resources, and the current release does not,
- // deleteFiles() will not run and some files will be left. This currently
- // can happen for ContentShell, but not for Chrome proper, since we always extract
- // locale pak files.
if (shouldSkipPakExtraction()) {
return;
}
@@ -442,11 +472,12 @@ public class ResourceExtractor {
}
/**
- * Pak extraction not necessarily required by the embedder.
+ * Pak extraction not necessarily required by the embedder; we allow them to skip
+ * this process if they call setMandatoryPaksToExtract with a single empty String.
*/
private static boolean shouldSkipPakExtraction() {
- assert (sLocalePaksResId != -1 && sMandatoryPaks != null)
- : "setMandatoryPaksToExtract() must be called before startExtractingResources()";
- return sMandatoryPaks.length == 0 && sLocalePaksResId == 0;
+ // Must call setMandatoryPaksToExtract before beginning resource extraction.
+ assert sMandatoryPaks != null;
+ return sMandatoryPaks.length == 1 && "".equals(sMandatoryPaks[0]);
}
}
diff --git a/build/android/gyp/locale_pak_resources.py b/build/android/gyp/locale_pak_resources.py
deleted file mode 100755
index 8bf9218..0000000
--- a/build/android/gyp/locale_pak_resources.py
+++ /dev/null
@@ -1,97 +0,0 @@
-#!/usr/bin/env python
-#
-# Copyright 2015 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-"""Creates a resources.zip for locale .pak files.
-
-Places the locale.pak files into appropriate resource configs
-(e.g. en-GB.pak -> res/raw-en/en_gb.pak). Also generates a locale_paks
-TypedArray so that resource files can be enumerated at runtime.
-"""
-
-import collections
-import optparse
-import os
-import sys
-import zipfile
-
-from util import build_utils
-
-
-# This should stay in sync with:
-# base/android/java/src/org/chromium/base/LocaleUtils.java
-_CHROME_TO_ANDROID_LOCALE_MAP = {
- 'he': 'iw',
- 'id': 'in',
- 'fil': 'tl',
-}
-
-
-def CreateLocalePaksXml(names):
- """Creates the contents for the locale-paks.xml files."""
- VALUES_FILE_TEMPLATE = '''<?xml version="1.0" encoding="utf-8"?>
-<resources>
- <array name="locale_paks">%s
- </array>
-</resources>
-'''
- VALUES_ITEM_TEMPLATE = '''
- <item>@raw/%s</item>'''
-
- res_names = (os.path.splitext(name)[0] for name in names)
- items = ''.join((VALUES_ITEM_TEMPLATE % name for name in res_names))
- return VALUES_FILE_TEMPLATE % items
-
-
-def main():
- parser = optparse.OptionParser()
- build_utils.AddDepfileOption(parser)
- parser.add_option('--locale-paks', help='List of files for res/raw-LOCALE')
- parser.add_option('--resources-zip', help='Path to output resources.zip')
-
- options, _ = parser.parse_args()
- build_utils.CheckOptions(options, parser,
- required=['locale_paks', 'resources_zip'])
-
- sources = build_utils.ParseGypList(options.locale_paks)
-
- if options.depfile:
- deps = sources + build_utils.GetPythonDependencies()
- build_utils.WriteDepfile(options.depfile, deps)
-
- with zipfile.ZipFile(options.resources_zip, 'w', zipfile.ZIP_STORED) as out:
- # e.g. "en" -> ["en_gb.pak"]
- lang_to_locale_map = collections.defaultdict(list)
- for src_path in sources:
- basename = os.path.basename(src_path)
- name = os.path.splitext(basename)[0]
- # Resources file names must consist of [a-z0-9_.].
- res_compatible_name = basename.replace('-', '_').lower()
- if name == 'en-US':
- dest_dir = 'raw'
- else:
- # Chrome uses different region mapping logic from Android, so include
- # all regions for each language.
- android_locale = _CHROME_TO_ANDROID_LOCALE_MAP.get(name, name)
- lang = android_locale[0:2]
- dest_dir = 'raw-' + lang
- lang_to_locale_map[lang].append(res_compatible_name)
- out.write(src_path, os.path.join(dest_dir, res_compatible_name))
-
- # Create a String Arrays resource so ResourceExtractor can enumerate files.
- def WriteValuesFile(lang, names):
- dest_dir = 'values'
- if lang:
- dest_dir += '-' + lang
- # Always extract en-US.pak since it's the fallback.
- xml = CreateLocalePaksXml(names + ['en_us.pak'])
- out.writestr(os.path.join(dest_dir, 'locale-paks.xml'), xml)
-
- for lang, names in lang_to_locale_map.iteritems():
- WriteValuesFile(lang, names)
- WriteValuesFile(None, [])
-
-
-if __name__ == '__main__':
- sys.exit(main())
diff --git a/build/android/locale_pak_resources.gypi b/build/android/locale_pak_resources.gypi
deleted file mode 100644
index 6f8e56f8..0000000
--- a/build/android/locale_pak_resources.gypi
+++ /dev/null
@@ -1,52 +0,0 @@
-# Copyright 2015 The Chromium Authors. All rights reserved.
-# Use of this source code is governed by a BSD-style license that can be
-# found in the LICENSE file.
-
-# Creates a resources.zip with locale.pak files placed into appropriate
-# resource configs (e.g. en-GB.pak -> res/raw-en/en_gb.pak). Also generates
-# a locale_paks TypedArray so that resource files can be enumerated at runtime.
-#
-# If this target is included in the deps of an android resources/library/apk,
-# the resources will be included with that target.
-#
-# Variables:
-# locale_pak_files - List of .pak files to process.
-# Names must be of the form "en.pak" or "en-US.pak".
-#
-# Example
-# {
-# 'target_name': 'my_locale_resources',
-# 'type': 'none',
-# 'variables': {
-# 'locale_paks_files': ['path1/fr.pak'],
-# },
-# 'includes': [ '../build/android/locale_pak_resources.gypi' ],
-# },
-#
-{
- 'variables': {
- 'resources_zip_path': '<(PRODUCT_DIR)/res.java/<(_target_name).zip',
- },
- 'all_dependent_settings': {
- 'variables': {
- 'additional_input_paths': ['<(resources_zip_path)'],
- 'dependencies_res_zip_paths': ['<(resources_zip_path)'],
- },
- },
- 'actions': [{
- 'action_name': '<(_target_name)_locale_pak_resources',
- 'inputs': [
- '<(DEPTH)/build/android/gyp/util/build_utils.py',
- '<(DEPTH)/build/android/gyp/locale_pak_resources.py',
- '<@(locale_pak_files)',
- ],
- 'outputs': [
- '<(resources_zip_path)',
- ],
- 'action': [
- 'python', '<(DEPTH)/build/android/gyp/locale_pak_resources.py',
- '--locale-paks', '<(locale_pak_files)',
- '--resources-zip', '<(resources_zip_path)',
- ],
- }],
-}
diff --git a/build/config/android/rules.gni b/build/config/android/rules.gni
index 57af185..4c22fac 100644
--- a/build/config/android/rules.gni
+++ b/build/config/android/rules.gni
@@ -544,69 +544,6 @@ template("jinja_template_resources") {
}
}
-# Creates a resources.zip with locale.pak files placed into appropriate
-# resource configs (e.g. en-GB.pak -> res/raw-en/en_gb.pak). Also generates
-# a locale_paks TypedArray so that resource files can be enumerated at runtime.
-#
-# If this target is included in the deps of an android resources/library/apk,
-# the resources will be included with that target.
-#
-# Variables:
-# sources: List of .pak files. Names must be of the form "en.pak" or
-# "en-US.pak".
-# deps: (optional) List of dependencies that might be needed to generate
-# the .pak files.
-#
-# Example
-# locale_pak_resources("locale_paks") {
-# sources = [ "path/en-US.pak", "path/fr.pak", ... ]
-# }
-template("locale_pak_resources") {
- set_sources_assignment_filter([])
- assert(defined(invoker.sources))
-
- _base_path = "$target_gen_dir/$target_name"
- _resources_zip = _base_path + ".resources.zip"
- _build_config = _base_path + ".build_config"
-
- write_build_config("${target_name}__build_config") {
- build_config = _build_config
- resources_zip = _resources_zip
- type = "android_resources"
- }
-
- action("${target_name}__create_resources_zip") {
- sources = invoker.sources
- script = "//build/android/gyp/locale_pak_resources.py"
- depfile = "$target_gen_dir/$target_name.d"
-
- outputs = [
- depfile,
- _resources_zip,
- ]
-
- _rebased_sources = rebase_path(invoker.sources, root_build_dir)
- args = [
- "--locale-paks=${_rebased_sources}",
- "--resources-zip",
- rebase_path(_resources_zip, root_build_dir),
- "--depfile",
- rebase_path(depfile, root_build_dir),
- ]
-
- if (defined(invoker.deps)) {
- deps = invoker.deps
- }
- }
-
- group(target_name) {
- deps = [
- ":${target_name}__build_config",
- ":${target_name}__create_resources_zip",
- ]
- }
-}
-
# Declare an Android resources target
#
# This creates a resources zip file that will be used when building an Android
diff --git a/chrome/android/BUILD.gn b/chrome/android/BUILD.gn
index 8e00007..52e65d5 100644
--- a/chrome/android/BUILD.gn
+++ b/chrome/android/BUILD.gn
@@ -24,23 +24,6 @@ jinja_variables = [
"configuration_policy=$configuration_policy",
]
-chrome_android_paks_gypi =
- exec_script("//build/gypi_to_gn.py",
- [
- rebase_path("//chrome/chrome_android_paks.gypi"),
- "--replace=<(PRODUCT_DIR)=$root_out_dir",
- ],
- "scope",
- [ "//chrome/chrome_android_paks.gypi" ])
-
-locale_pak_resources("chrome_locale_paks") {
- sources = chrome_android_paks_gypi.chrome_android_pak_locale_resources
-
- deps = [
- "//chrome:packed_resources",
- ]
-}
-
# GYP: //chrome/chrome.gyp:chrome_java (resources part)
android_resources("chrome_java_resources") {
resource_dirs = [
@@ -48,7 +31,6 @@ android_resources("chrome_java_resources") {
"java/res_default",
]
deps = [
- ":chrome_locale_paks",
":chrome_strings_grd",
"//content/public/android:content_java_resources",
"//chrome/app:java_strings_grd",
@@ -260,7 +242,6 @@ android_library("chrome_shell_java") {
deps = [
":chrome_shell_resources",
":chrome_java",
- ":chrome_java_resources",
"//base:base_java",
"//content/public/android:content_java",
"//components/dom_distiller/android:dom_distiller_content_java",
@@ -736,10 +717,18 @@ static_library("chrome_staging") {
chrome_public_apk_assets_dir = "$root_build_dir/chrome_public_apk_assets"
+chrome_android_paks_gypi =
+ exec_script("//build/gypi_to_gn.py",
+ [ rebase_path("//chrome/chrome_android_paks.gypi") ],
+ "scope",
+ [ "//chrome/chrome_android_paks.gypi" ])
+
copy_ex("chrome_public_apk_assets") {
clear_dir = true
dest = chrome_public_apk_assets_dir
- sources = chrome_android_paks_gypi.chrome_android_pak_input_resources
+ gypi_sources = chrome_android_paks_gypi.chrome_android_pak_input_resources
+ cleaned_sources = rebase_path(gypi_sources, "<(PRODUCT_DIR)")
+ sources = rebase_path(cleaned_sources, ".", root_out_dir)
if (icu_use_data_file) {
sources += [ "$root_build_dir/icudtl.dat" ]
}
diff --git a/chrome/android/java_staging/src/org/chromium/chrome/browser/ChromeMobileApplication.java b/chrome/android/java_staging/src/org/chromium/chrome/browser/ChromeMobileApplication.java
index 1ac9afb..35b1446 100644
--- a/chrome/android/java_staging/src/org/chromium/chrome/browser/ChromeMobileApplication.java
+++ b/chrome/android/java_staging/src/org/chromium/chrome/browser/ChromeMobileApplication.java
@@ -24,7 +24,6 @@ import org.chromium.base.ResourceExtractor;
import org.chromium.base.ThreadUtils;
import org.chromium.base.VisibleForTesting;
import org.chromium.base.annotations.SuppressFBWarnings;
-import org.chromium.chrome.R;
import org.chromium.chrome.browser.accessibility.FontSizePrefs;
import org.chromium.chrome.browser.banners.AppBannerManager;
import org.chromium.chrome.browser.banners.AppDetailsDelegate;
@@ -128,8 +127,7 @@ public class ChromeMobileApplication extends ChromiumApplication {
}
private static final String[] CHROME_MANDATORY_PAKS = {
- "resources.pak",
- "chrome_100_percent.pak",
+ "en-US.pak", "resources.pak", "chrome_100_percent.pak",
};
private static final String PRIVATE_DATA_DIRECTORY_SUFFIX = "chrome";
private static final String DEV_TOOLS_SERVER_SOCKET_PREFIX = "chrome";
@@ -198,7 +196,7 @@ public class ChromeMobileApplication extends ChromiumApplication {
protected void initializeLibraryDependencies() {
// The ResourceExtractor is only needed by the browser process, but this will have no
// impact on the renderer process construction.
- ResourceExtractor.setMandatoryPaksToExtract(R.array.locale_paks, CHROME_MANDATORY_PAKS);
+ ResourceExtractor.setMandatoryPaksToExtract(CHROME_MANDATORY_PAKS);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, this);
}
diff --git a/chrome/android/shell/java/src/org/chromium/chrome/shell/ChromeShellApplication.java b/chrome/android/shell/java/src/org/chromium/chrome/shell/ChromeShellApplication.java
index d75ec52..042e2c7 100644
--- a/chrome/android/shell/java/src/org/chromium/chrome/shell/ChromeShellApplication.java
+++ b/chrome/android/shell/java/src/org/chromium/chrome/shell/ChromeShellApplication.java
@@ -9,7 +9,6 @@ import android.content.Intent;
import org.chromium.base.CommandLine;
import org.chromium.base.PathUtils;
import org.chromium.base.ResourceExtractor;
-import org.chromium.chrome.R;
import org.chromium.chrome.browser.ChromiumApplication;
import org.chromium.chrome.browser.identity.UniqueIdentificationGeneratorFactory;
import org.chromium.chrome.browser.identity.UuidBasedUniqueIdentificationGenerator;
@@ -30,6 +29,7 @@ public class ChromeShellApplication extends ChromiumApplication {
private static final String PRIVATE_DATA_DIRECTORY_SUFFIX = "chromeshell";
private static final String[] CHROME_MANDATORY_PAKS = {
+ "en-US.pak",
"resources.pak",
"chrome_100_percent.pak",
};
@@ -62,7 +62,7 @@ public class ChromeShellApplication extends ChromiumApplication {
@Override
protected void initializeLibraryDependencies() {
- ResourceExtractor.setMandatoryPaksToExtract(R.array.locale_paks, CHROME_MANDATORY_PAKS);
+ ResourceExtractor.setMandatoryPaksToExtract(CHROME_MANDATORY_PAKS);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, this);
}
diff --git a/chrome/chrome.gyp b/chrome/chrome.gyp
index 633b8a2..a5bbd94 100644
--- a/chrome/chrome.gyp
+++ b/chrome/chrome.gyp
@@ -575,7 +575,6 @@
'type': 'none',
'dependencies': [
'activity_type_ids_java',
- 'chrome_locale_paks',
'chrome_resources.gyp:chrome_strings',
'chrome_strings_grd',
'chrome_version_java',
@@ -645,18 +644,6 @@
],
},
{
- # GN: //chrome/android:chrome_locale_paks
- 'target_name': 'chrome_locale_paks',
- 'type': 'none',
- 'variables': {
- 'locale_pak_files': [ '<@(chrome_android_pak_locale_resources)' ],
- },
- 'includes': [
- 'chrome_android_paks.gypi',
- '../build/android/locale_pak_resources.gypi',
- ],
- },
- {
# GN: //chrome:content_setting_javagen
'target_name': 'content_setting_java',
'type': 'none',
diff --git a/chrome/chrome_android_paks.gypi b/chrome/chrome_android_paks.gypi
index 1be60d8..13f5845 100644
--- a/chrome/chrome_android_paks.gypi
+++ b/chrome/chrome_android_paks.gypi
@@ -7,8 +7,6 @@
'chrome_android_pak_input_resources': [
'<(PRODUCT_DIR)/resources.pak',
'<(PRODUCT_DIR)/chrome_100_percent.pak',
- ],
- 'chrome_android_pak_locale_resources': [
'<(PRODUCT_DIR)/locales/am.pak',
'<(PRODUCT_DIR)/locales/ar.pak',
'<(PRODUCT_DIR)/locales/bg.pak',
@@ -57,6 +55,50 @@
'chrome_android_pak_output_resources': [
'<(chrome_android_pak_output_folder)/resources.pak',
'<(chrome_android_pak_output_folder)/chrome_100_percent.pak',
+ '<(chrome_android_pak_output_folder)/am.pak',
+ '<(chrome_android_pak_output_folder)/ar.pak',
+ '<(chrome_android_pak_output_folder)/bg.pak',
+ '<(chrome_android_pak_output_folder)/ca.pak',
+ '<(chrome_android_pak_output_folder)/cs.pak',
+ '<(chrome_android_pak_output_folder)/da.pak',
+ '<(chrome_android_pak_output_folder)/de.pak',
+ '<(chrome_android_pak_output_folder)/el.pak',
+ '<(chrome_android_pak_output_folder)/en-GB.pak',
+ '<(chrome_android_pak_output_folder)/en-US.pak',
+ '<(chrome_android_pak_output_folder)/es.pak',
+ '<(chrome_android_pak_output_folder)/es-419.pak',
+ '<(chrome_android_pak_output_folder)/fa.pak',
+ '<(chrome_android_pak_output_folder)/fi.pak',
+ '<(chrome_android_pak_output_folder)/fil.pak',
+ '<(chrome_android_pak_output_folder)/fr.pak',
+ '<(chrome_android_pak_output_folder)/he.pak',
+ '<(chrome_android_pak_output_folder)/hi.pak',
+ '<(chrome_android_pak_output_folder)/hr.pak',
+ '<(chrome_android_pak_output_folder)/hu.pak',
+ '<(chrome_android_pak_output_folder)/id.pak',
+ '<(chrome_android_pak_output_folder)/it.pak',
+ '<(chrome_android_pak_output_folder)/ja.pak',
+ '<(chrome_android_pak_output_folder)/ko.pak',
+ '<(chrome_android_pak_output_folder)/lt.pak',
+ '<(chrome_android_pak_output_folder)/lv.pak',
+ '<(chrome_android_pak_output_folder)/nb.pak',
+ '<(chrome_android_pak_output_folder)/nl.pak',
+ '<(chrome_android_pak_output_folder)/pl.pak',
+ '<(chrome_android_pak_output_folder)/pt-BR.pak',
+ '<(chrome_android_pak_output_folder)/pt-PT.pak',
+ '<(chrome_android_pak_output_folder)/ro.pak',
+ '<(chrome_android_pak_output_folder)/ru.pak',
+ '<(chrome_android_pak_output_folder)/sk.pak',
+ '<(chrome_android_pak_output_folder)/sl.pak',
+ '<(chrome_android_pak_output_folder)/sr.pak',
+ '<(chrome_android_pak_output_folder)/sv.pak',
+ '<(chrome_android_pak_output_folder)/sw.pak',
+ '<(chrome_android_pak_output_folder)/th.pak',
+ '<(chrome_android_pak_output_folder)/tr.pak',
+ '<(chrome_android_pak_output_folder)/uk.pak',
+ '<(chrome_android_pak_output_folder)/vi.pak',
+ '<(chrome_android_pak_output_folder)/zh-CN.pak',
+ '<(chrome_android_pak_output_folder)/zh-TW.pak',
],
'conditions': [
['icu_use_data_file_flag==1', {
diff --git a/chromecast/browser/android/apk/src/org/chromium/chromecast/shell/CastApplication.java b/chromecast/browser/android/apk/src/org/chromium/chromecast/shell/CastApplication.java
index a9b0c6fc2..903609f 100644
--- a/chromecast/browser/android/apk/src/org/chromium/chromecast/shell/CastApplication.java
+++ b/chromecast/browser/android/apk/src/org/chromium/chromecast/shell/CastApplication.java
@@ -37,7 +37,7 @@ public class CastApplication extends ContentApplication {
}
public static void initializeApplicationParameters(Context context) {
- ResourceExtractor.setMandatoryPaksToExtract(0, MANDATORY_PAK_FILES);
+ ResourceExtractor.setMandatoryPaksToExtract(MANDATORY_PAK_FILES);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, context);
}
diff --git a/components/test/android/browsertests_apk/src/org/chromium/components_browsertests_apk/ComponentsBrowserTestsApplication.java b/components/test/android/browsertests_apk/src/org/chromium/components_browsertests_apk/ComponentsBrowserTestsApplication.java
index a8387ce..d1b128e 100644
--- a/components/test/android/browsertests_apk/src/org/chromium/components_browsertests_apk/ComponentsBrowserTestsApplication.java
+++ b/components/test/android/browsertests_apk/src/org/chromium/components_browsertests_apk/ComponentsBrowserTestsApplication.java
@@ -26,7 +26,7 @@ public class ComponentsBrowserTestsApplication extends BaseChromiumApplication {
}
public static void initializeApplicationParameters(Context context) {
- ResourceExtractor.setMandatoryPaksToExtract(0, MANDATORY_PAK_FILES);
+ ResourceExtractor.setMandatoryPaksToExtract(MANDATORY_PAK_FILES);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, context);
}
}
diff --git a/content/shell/android/browsertests_apk/src/org/chromium/content_browsertests_apk/ContentBrowserTestsApplication.java b/content/shell/android/browsertests_apk/src/org/chromium/content_browsertests_apk/ContentBrowserTestsApplication.java
index 0405e32..eeca243 100644
--- a/content/shell/android/browsertests_apk/src/org/chromium/content_browsertests_apk/ContentBrowserTestsApplication.java
+++ b/content/shell/android/browsertests_apk/src/org/chromium/content_browsertests_apk/ContentBrowserTestsApplication.java
@@ -27,7 +27,7 @@ public class ContentBrowserTestsApplication extends BaseChromiumApplication {
}
public static void initializeApplicationParameters(Context context) {
- ResourceExtractor.setMandatoryPaksToExtract(0, MANDATORY_PAK_FILES);
+ ResourceExtractor.setMandatoryPaksToExtract(MANDATORY_PAK_FILES);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, context);
}
diff --git a/content/shell/android/linker_test_apk/src/org/chromium/chromium_linker_test_apk/ChromiumLinkerTestApplication.java b/content/shell/android/linker_test_apk/src/org/chromium/chromium_linker_test_apk/ChromiumLinkerTestApplication.java
index f482427..ab019bb 100644
--- a/content/shell/android/linker_test_apk/src/org/chromium/chromium_linker_test_apk/ChromiumLinkerTestApplication.java
+++ b/content/shell/android/linker_test_apk/src/org/chromium/chromium_linker_test_apk/ChromiumLinkerTestApplication.java
@@ -27,7 +27,7 @@ public class ChromiumLinkerTestApplication extends BaseChromiumApplication {
}
public static void initializeApplicationParameters(Context context) {
- ResourceExtractor.setMandatoryPaksToExtract(0, MANDATORY_PAK_FILES);
+ ResourceExtractor.setMandatoryPaksToExtract(MANDATORY_PAK_FILES);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, context);
}
diff --git a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/ContentShellApplication.java b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/ContentShellApplication.java
index f97e6b030..d675a0b 100644
--- a/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/ContentShellApplication.java
+++ b/content/shell/android/shell_apk/src/org/chromium/content_shell_apk/ContentShellApplication.java
@@ -28,7 +28,7 @@ public class ContentShellApplication extends ContentApplication {
@Override
protected void initializeLibraryDependencies() {
- ResourceExtractor.setMandatoryPaksToExtract(0, MANDATORY_PAK_FILES);
+ ResourceExtractor.setMandatoryPaksToExtract(MANDATORY_PAK_FILES);
PathUtils.setPrivateDataDirectorySuffix(PRIVATE_DATA_DIRECTORY_SUFFIX, this);
}