| Index: build/android/gyp/locale_pak_resources.py
|
| diff --git a/build/android/gyp/locale_pak_resources.py b/build/android/gyp/locale_pak_resources.py
|
| new file mode 100755
|
| index 0000000000000000000000000000000000000000..8bf92185c1db8735205c18f1705667bede0b065c
|
| --- /dev/null
|
| +++ b/build/android/gyp/locale_pak_resources.py
|
| @@ -0,0 +1,97 @@
|
| +#!/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())
|
|
|