tree: 2e71722bbaa7b5a8b5a8204035a6a23873c91c9d [path history] [tgz]
  1. cmd/
  2. compile/
  3. filter/
  4. flatten/
  5. integration-tests/
  6. io/
  7. java/
  8. jni/
  9. link/
  10. optimize/
  11. process/
  12. proto/
  13. split/
  14. test/
  15. tools/
  16. unflatten/
  17. util/
  18. xml/
  19. .clang-format
  20. Android.bp
  21. AppInfo.h
  22. ConfigDescription.cpp
  23. ConfigDescription.h
  24. ConfigDescription_test.cpp
  25. Debug.cpp
  26. Debug.h
  27. Diagnostics.h
  28. DominatorTree.cpp
  29. DominatorTree.h
  30. DominatorTree_test.cpp
  31. Flags.cpp
  32. Flags.h
  33. Format.proto
  34. LoadedApk.cpp
  35. LoadedApk.h
  36. Locale.cpp
  37. Locale.h
  38. Locale_test.cpp
  39. Main.cpp
  40. NameMangler.h
  41. NameMangler_test.cpp
  42. readme.md
  43. Resource.cpp
  44. Resource.h
  45. Resource_test.cpp
  46. ResourceParser.cpp
  47. ResourceParser.h
  48. ResourceParser_test.cpp
  49. ResourceTable.cpp
  50. ResourceTable.h
  51. ResourceTable_test.cpp
  52. ResourceUtils.cpp
  53. ResourceUtils.h
  54. ResourceUtils_test.cpp
  55. ResourceValues.cpp
  56. ResourceValues.h
  57. ResourceValues_test.cpp
  58. SdkConstants.cpp
  59. SdkConstants.h
  60. SdkConstants_test.cpp
  61. Source.h
  62. StringPool.cpp
  63. StringPool.h
  64. StringPool_test.cpp
  65. ValueVisitor.h
  66. ValueVisitor_test.cpp
tools/aapt2/readme.md

Android Asset Packaging Tool 2.0 (AAPT2) release notes

Version 2.13

aapt2 optimize ...

  • aapt2 optimize can now split a binary APK with the same --split parameters as the link phase.

Version 2.12

aapt2 optimize ...

  • aapt2 optimize now understands map (complex) values under the type id. It ignores their contents and interprets them as a sentinel id type. This was added to support existing apps that build with their id types as map values. AAPT and AAPT2 always generate a simple value for the type ID, so it is unclear how some these apps are encoded.

Version 2.11

aapt2 link ...

  • Adds the ability to specify assets directories with the -A parameter. Assets work just like assets in the original AAPT. It is not recommended to package assets with aapt2, however, since the resulting APK is post-processed by other tools anyways. Assets do not get processed by AAPT2, just copied, so incremental building gets slower if they are included early on.

Version 2.10

aapt2 link ...

  • Add ability to specify package ID to compile with for regular apps (not shared or static libs). This package ID is limited to the range 0x7f-0xff inclusive. Specified with the --package-id flag.
  • Fixed issue with resources being stripped for locales and other configuration.
  • Fixed issue with escaping strings in XML resources.

Version 2.9

aapt2 link ...

  • Added sparse resource type encoding, which encodes resource entries that are sparse with a binary search tree representation. Only available when minSdkVersion >= API O or resource qualifier of resource types is >= v26 (or whatever API level O becomes). Enabled with --enable-sparse-encoding flag.

aapt2 optimize ...

  • Adds an optimization pass that supports:
    • stripping out any density assets that do not match the --target-densities list of densities.
    • resource deduping when the resources are dominated and identical (already happens during link phase but this covers apps built with aapt).
    • new sparse resource type encoding with the --enable-sparse-encoding flag if possible (minSdkVersion >= O or resource qualifier >= v26).

Version 2.8

aapt2 link ...

  • Adds shared library support. Build a shared library with the --shared-lib flag. Build a client of a shared library by simply including it via -I.

Version 2.7

aapt2 compile ...

  • Fixes bug where psuedolocalization auto-translated strings marked 'translateable="false"'.

Version 2.6

aapt2

  • Support legacy configVarying resource type.
  • Support <bag> tag and treat as <style> regardless of type.
  • Add <feature-group> manifest tag verification.
  • Add <meta-data> tag support to <instrumentation>.

Version 2.5

aapt2 link ...

  • Transition XML versioning: Adds a new flag --no-version-transitions to disable automatic versioning of Transition XML resources.

Version 2.4

aapt2 link ...

  • Supports <meta-data> tags in <manifest>.

Version 2.3

aapt2

  • Support new font resource type.

Version 2.2

aapt2 compile ...

aapt link ...

  • Duplicate resource filtering: removes duplicate resources in dominated configurations that are always identical when selected at runtime. This can be disabled with --no-resource-deduping.

Version 2.1

aapt2 link ...

  • Configuration Split APK support: supports splitting resources that match a set of configurations to a separate APK which can be loaded alongside the base APK on API 21+ devices. This is done using the flag --split path/to/split.apk:<config1>[,<config2>,...].
  • SDK version resource filtering: Resources with an SDK version qualifier that is unreachable at runtime due to the minimum SDK level declared by the AndroidManifest.xml are stripped.

Version 2.0

aapt2 compile ...

  • Pseudo-localization: generates pseudolocalized versions of default strings when the --pseudo-localize option is specified.
  • Legacy mode: treats some class of errors as warnings in order to be more compatible with AAPT when --legacy is specified.
  • Compile directory: treats the input file as a directory when --dir is specified. This will emit a zip of compiled files, one for each file in the directory. The directory must follow the Android resource directory structure (res/values-[qualifiers]/file.ext).

aapt2 link ...

  • Automatic attribute versioning: adds version qualifiers to resources that use attributes introduced in a later SDK level. This can be disabled with --no-auto-version.
  • Min SDK resource filtering: removes resources that can't possibly be selected at runtime due to the application's minimum supported SDK level.