diff options
author | Narayan Kamath <narayan@google.com> | 2014-01-21 15:32:36 +0000 |
---|---|---|
committer | Narayan Kamath <narayan@google.com> | 2014-02-10 15:50:16 +0000 |
commit | 91447d88f2bdf9c2bf8d1a53570efef6172fba74 (patch) | |
tree | dc46e96130696c26e8fd3883227314ef5c0b7ad1 /tools/aapt/Command.cpp | |
parent | 378c6775a62d9c461cde51f06c1b14bb014c78fd (diff) | |
download | frameworks_base-91447d88f2bdf9c2bf8d1a53570efef6172fba74.zip frameworks_base-91447d88f2bdf9c2bf8d1a53570efef6172fba74.tar.gz frameworks_base-91447d88f2bdf9c2bf8d1a53570efef6172fba74.tar.bz2 |
Extended locales in AAPT / AssetManager.
Support 3 letter language codes, script codes &
variants. The bulk of the changes are related to
the implementation of command line filtering of
locales etc. The previous code assumed that the
value of each "axis" (locale, density, size etc.)
could be represented by a 4 byte type. This is
no longer the case.
This change introduces a new class, AaptLocaleValue
which holds a (normalized) locale parsed from a
directory name or a filter string. This class takes
responsibility for parsing locales as well as
writing them to ResTable_config structures, which is
their representation in the resource table.
This includes minor changes at the java / JNI level
for AssetManager. We now call locale.toLanguageTag()
to give the native layer a well formed BCP-47 tag.
I've removed some duplicated parsing code in
AssetManager.cpp and replaced them with functions on
ResTable_config. The native getLocales function has
been changed to return well formed BCP-47 locales as
well, so that the corresponding java function can use
Locale.forLanguageTag to construct a Locale object
out of it.
Finally, this change introduces default and copy
constructors for ResTable_config to prevent having
to memset() the associated memory to 0 on every
stack allocation.
Change-Id: I899a56a9a182ee6be52b9389d1ae59266f5482e9
Diffstat (limited to 'tools/aapt/Command.cpp')
-rw-r--r-- | tools/aapt/Command.cpp | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/tools/aapt/Command.cpp b/tools/aapt/Command.cpp index 48e3125..8e856b7 100644 --- a/tools/aapt/Command.cpp +++ b/tools/aapt/Command.cpp @@ -600,6 +600,7 @@ int doDump(Bundle* bundle) // the API version because key resources like icons will have an implicit // version if they are using newer config types like density. ResTable_config config; + memset(&config, 0, sizeof(ResTable_config)); config.language[0] = 'e'; config.language[1] = 'n'; config.country[0] = 'U'; |