| Index: build/config/android/internal_rules.gni
|
| diff --git a/build/config/android/internal_rules.gni b/build/config/android/internal_rules.gni
|
| index 1a1a75266252ef7dd00e5637914ac6cbbfb3b30e..4edf0bbb5d7e5b49b36dd0a2e5c302a06c2297d3 100644
|
| --- a/build/config/android/internal_rules.gni
|
| +++ b/build/config/android/internal_rules.gni
|
| @@ -242,7 +242,8 @@ template("write_build_config") {
|
| build_config = invoker.build_config
|
|
|
| assert(type == "android_apk" || type == "java_library" ||
|
| - type == "android_resources" || type == "deps_dex")
|
| + type == "android_resources" || type == "deps_dex" ||
|
| + type == "android_assets")
|
|
|
| action(target_name) {
|
| deps = []
|
| @@ -283,15 +284,18 @@ template("write_build_config") {
|
|
|
| is_java_library = type == "java_library"
|
| is_apk = type == "android_apk"
|
| + is_android_assets = type == "android_assets"
|
| is_android_resources = type == "android_resources"
|
| is_deps_dex = type == "deps_dex"
|
|
|
| - supports_android = is_apk || is_android_resources || is_deps_dex ||
|
| - (is_java_library && defined(invoker.supports_android) &&
|
| - invoker.supports_android)
|
| - requires_android = is_apk || is_android_resources || is_deps_dex ||
|
| - (is_java_library && defined(invoker.requires_android) &&
|
| - invoker.requires_android)
|
| + supports_android =
|
| + is_apk || is_android_assets || is_android_resources || is_deps_dex ||
|
| + (is_java_library && defined(invoker.supports_android) &&
|
| + invoker.supports_android)
|
| + requires_android =
|
| + is_apk || is_android_assets || is_android_resources || is_deps_dex ||
|
| + (is_java_library && defined(invoker.requires_android) &&
|
| + invoker.requires_android)
|
|
|
| assert(!requires_android || supports_android,
|
| "requires_android requires" + " supports_android")
|
| @@ -339,6 +343,15 @@ template("write_build_config") {
|
| ]
|
| }
|
|
|
| + if (is_android_assets) {
|
| + inputs += invoker.assets
|
| + _rebased_assets = rebase_path(invoker.assets, root_build_dir)
|
| + args += [ "--assets=$_rebased_assets" ]
|
| + if (defined(invoker.disable_compression) && invoker.disable_compression) {
|
| + args += [ "--disable-asset-compression" ]
|
| + }
|
| + }
|
| +
|
| if (is_android_resources || is_apk) {
|
| assert(defined(invoker.resources_zip))
|
| args += [
|
| @@ -480,6 +493,8 @@ template("process_java_prebuilt") {
|
| # Creates an unsigned .apk.
|
| #
|
| # Variables
|
| +# assets_build_config: Path to android_apk .build_config containing merged
|
| +# asset information.
|
| # deps: Specifies the dependencies of this target.
|
| # dex_path: Path to classes.dex file to include (optional).
|
| # resource_packaged_apk_path: Path to .ap_ to use.
|
| @@ -525,6 +540,12 @@ template("package_apk") {
|
| "--resource-apk=$_rebased_resource_packaged_apk_path",
|
| "--output-apk=$_rebased_packaged_apk_path",
|
| ]
|
| + if (defined(invoker.assets_build_config)) {
|
| + inputs += [ invoker.assets_build_config ]
|
| + _rebased_build_config =
|
| + rebase_path(invoker.assets_build_config, root_build_dir)
|
| + args += [ "--assets-build-config=$_rebased_build_config" ]
|
| + }
|
| if (defined(invoker.dex_path)) {
|
| _rebased_dex_path = rebase_path(invoker.dex_path, root_build_dir)
|
| args += [ "--dex-file=$_rebased_dex_path" ]
|
| @@ -636,6 +657,8 @@ template("create_apk") {
|
| _incremental_deps = invoker.incremental_deps
|
| }
|
|
|
| + # TODO(agrieve): Remove support for asset_location in favor of using
|
| + # android_asset() everywhere (http://crbug.com/547162).
|
| if (defined(invoker.asset_location)) {
|
| _asset_location = invoker.asset_location
|
| assert(_asset_location != "") # Mark as used.
|
| @@ -802,7 +825,11 @@ template("create_apk") {
|
|
|
| package_target = "${target_name}__package"
|
| package_apk(package_target) {
|
| - forward_variables_from(invoker, [ "native_libs_dir" ])
|
| + forward_variables_from(invoker,
|
| + [
|
| + "assets_build_config",
|
| + "native_libs_dir",
|
| + ])
|
| deps = _deps + [ ":${_package_resources_target_name}" ]
|
|
|
| if (defined(_dex_path)) {
|
| @@ -815,6 +842,7 @@ template("create_apk") {
|
|
|
| _incremental_package_target = "${target_name}_incremental__package"
|
| package_apk(_incremental_package_target) {
|
| + forward_variables_from(invoker, [ "assets_build_config" ])
|
| _dex_target = "//build/android/incremental_install:bootstrap_java__dex"
|
| deps = _incremental_deps + [
|
| ":${_incremental_package_resources_target_name}",
|
|
|