| Index: build/config/android/rules.gni
|
| diff --git a/build/config/android/rules.gni b/build/config/android/rules.gni
|
| index 0b7593d2da201bba3acc9f24d5331c86f37e8639..0c135b362893b073904b951598c7b7f644386c08 100644
|
| --- a/build/config/android/rules.gni
|
| +++ b/build/config/android/rules.gni
|
| @@ -5,8 +5,8 @@
|
| import("//base/android/linker/config.gni")
|
| import("//build/config/android/config.gni")
|
| import("//build/config/android/internal_rules.gni")
|
| +import("//third_party/android_platform/config.gni")
|
| import("//tools/grit/grit_rule.gni")
|
| -import("//tools/relocation_packer/config.gni")
|
|
|
| assert(is_android)
|
|
|
| @@ -253,7 +253,12 @@ template("java_cpp_template") {
|
| include_path = "//"
|
| }
|
|
|
| - action_foreach("${target_name}__apply_gcc") {
|
| + apply_gcc_target_name = "${target_name}__apply_gcc"
|
| + zip_srcjar_target_name = "${target_name}__zip_srcjar"
|
| + final_target_name = target_name
|
| +
|
| + action_foreach(apply_gcc_target_name) {
|
| + visibility = [ ":$zip_srcjar_target_name" ]
|
| script = "//build/android/gyp/gcc_preprocess.py"
|
| if (defined(invoker.inputs)) {
|
| inputs = invoker.inputs + []
|
| @@ -262,6 +267,16 @@ template("java_cpp_template") {
|
|
|
| sources = invoker.sources
|
|
|
| + if (defined(invoker.deps)) {
|
| + deps = invoker.deps
|
| + }
|
| + if (defined(invoker.public_deps)) {
|
| + public_deps = invoker.public_deps
|
| + }
|
| + if (defined(invoker.data_deps)) {
|
| + data_deps = invoker.data_deps
|
| + }
|
| +
|
| gen_dir =
|
| "${target_gen_dir}/${target_name}/java_cpp_template/${package_name}"
|
| gcc_template_output_pattern = "${gen_dir}/{{source_name_part}}.java"
|
| @@ -291,19 +306,26 @@ template("java_cpp_template") {
|
| }
|
| }
|
|
|
| - apply_gcc_outputs = get_target_outputs(":${target_name}__apply_gcc")
|
| - base_gen_dir = get_label_info(":${target_name}__apply_gcc", "target_gen_dir")
|
| + apply_gcc_outputs = get_target_outputs(":$apply_gcc_target_name")
|
| + base_gen_dir = get_label_info(":$apply_gcc_target_name", "target_gen_dir")
|
|
|
| srcjar_path = "${target_gen_dir}/${target_name}.srcjar"
|
| - zip("${target_name}__zip_srcjar") {
|
| + zip(zip_srcjar_target_name) {
|
| + visibility = [ ":$final_target_name" ]
|
| inputs = apply_gcc_outputs
|
| output = srcjar_path
|
| base_dir = base_gen_dir
|
| + deps = [
|
| + ":$apply_gcc_target_name",
|
| + ]
|
| }
|
|
|
| - group(target_name) {
|
| + group(final_target_name) {
|
| + if (defined(invoker.visibility)) {
|
| + visibility = invoker.visibility
|
| + }
|
| deps = [
|
| - ":${target_name}__zip_srcjar",
|
| + ":$zip_srcjar_target_name",
|
| ]
|
| }
|
| }
|
| @@ -344,7 +366,13 @@ template("java_cpp_enum") {
|
| assert(defined(invoker.sources))
|
| assert(defined(invoker.outputs))
|
|
|
| - action("${target_name}__generate_enum") {
|
| + generate_enum_target_name = "${target_name}__generate_enum"
|
| + zip_srcjar_target_name = "${target_name}__zip_srcjar"
|
| + final_target_name = target_name
|
| +
|
| + action(generate_enum_target_name) {
|
| + visibility = [ ":$zip_srcjar_target_name" ]
|
| +
|
| # The sources aren't compiled so don't check their dependencies.
|
| check_includes = false
|
|
|
| @@ -365,20 +393,26 @@ template("java_cpp_enum") {
|
| args += rebase_path(invoker.sources, root_build_dir)
|
| }
|
|
|
| - generate_enum_outputs = get_target_outputs(":${target_name}__generate_enum")
|
| - base_gen_dir =
|
| - get_label_info(":${target_name}__generate_enum", "target_gen_dir")
|
| + generate_enum_outputs = get_target_outputs(":$generate_enum_target_name")
|
| + base_gen_dir = get_label_info(":$generate_enum_target_name", "target_gen_dir")
|
|
|
| srcjar_path = "${target_gen_dir}/${target_name}.srcjar"
|
| - zip("${target_name}__zip_srcjar") {
|
| + zip(zip_srcjar_target_name) {
|
| + visibility = [ ":$final_target_name" ]
|
| inputs = generate_enum_outputs
|
| output = srcjar_path
|
| base_dir = base_gen_dir
|
| + deps = [
|
| + ":$generate_enum_target_name",
|
| + ]
|
| }
|
|
|
| - group(target_name) {
|
| + group(final_target_name) {
|
| + if (defined(invoker.visibility)) {
|
| + visibility = invoker.visibility
|
| + }
|
| deps = [
|
| - ":${target_name}__zip_srcjar",
|
| + ":$zip_srcjar_target_name",
|
| ]
|
| }
|
| }
|
| @@ -406,6 +440,10 @@ template("jinja_template") {
|
| assert(defined(invoker.output))
|
|
|
| action(target_name) {
|
| + if (defined(invoker.visibility)) {
|
| + visibility = invoker.visibility
|
| + }
|
| +
|
| sources = [
|
| invoker.input,
|
| ]
|
| @@ -523,10 +561,9 @@ template("jinja_template_resources") {
|
| # android_manifest: AndroidManifest.xml for this target. Defaults to
|
| # //build/android/AndroidManifest.xml.
|
| # custom_package: java package for generated .java files.
|
| -# v14_verify_only: If true, don't generate v14/v17 resources and just verify
|
| -# that the resources are v14-compliant (see
|
| -# build/android/gyp/generate_v14_compatible_resources.py). Defaults to
|
| -# false.
|
| +# v14_skip: If true, don't run v14 resource generator on this. Defaults to
|
| +# false. (see build/android/gyp/generate_v14_compatible_resources.py)
|
| +#
|
| # shared_resources: If true make a resource package that can be loaded by a
|
| # different application at runtime to access the package's resources.
|
| #
|
| @@ -552,7 +589,13 @@ template("android_resources") {
|
| r_text_path = base_path + "_R.txt"
|
| build_config = base_path + ".build_config"
|
|
|
| - write_build_config("${target_name}__build_config") {
|
| + build_config_target_name = "${target_name}__build_config"
|
| + process_resources_target_name = "${target_name}__process_resources"
|
| + final_target_name = target_name
|
| +
|
| + write_build_config(build_config_target_name) {
|
| + visibility = [ ":$process_resources_target_name" ]
|
| +
|
| type = "android_resources"
|
| resources_zip = zip_path
|
| srcjar = srcjar_path
|
| @@ -573,24 +616,36 @@ template("android_resources") {
|
| android_manifest = invoker.android_manifest
|
| }
|
|
|
| - process_resources("${target_name}__process_resources") {
|
| + process_resources(process_resources_target_name) {
|
| + visibility = [ ":$final_target_name" ]
|
| +
|
| resource_dirs = invoker.resource_dirs
|
| if (defined(invoker.custom_package)) {
|
| custom_package = invoker.custom_package
|
| }
|
|
|
| - if (defined(invoker.v14_verify_only)) {
|
| - v14_verify_only = invoker.v14_verify_only
|
| + if (defined(invoker.v14_skip)) {
|
| + v14_skip = invoker.v14_skip
|
| }
|
|
|
| if (defined(invoker.shared_resources)) {
|
| shared_resources = invoker.shared_resources
|
| }
|
| +
|
| + deps = [
|
| + ":$build_config_target_name",
|
| + ]
|
| + if (defined(invoker.deps)) {
|
| + # Invoker may have added deps that generate the input resources.
|
| + deps += invoker.deps
|
| + }
|
| }
|
|
|
| - group(target_name) {
|
| + group(final_target_name) {
|
| + if (defined(invoker.visibility)) {
|
| + visibility = invoker.visibility
|
| + }
|
| deps = [
|
| - ":${target_name}__build_config",
|
| ":${target_name}__process_resources",
|
| ]
|
| }
|
| @@ -651,6 +706,9 @@ template("java_strings_grd") {
|
| base_dir = grit_output_dir
|
| inputs = generate_strings_outputs
|
| output = resources_zip
|
| + deps = [
|
| + ":$grit_target_name",
|
| + ]
|
| }
|
|
|
| group(target_name) {
|
| @@ -687,23 +745,35 @@ template("java_strings_grd_prebuilt") {
|
| resources_zip = base_path + ".resources.zip"
|
| build_config = base_path + ".build_config"
|
|
|
| - write_build_config("${target_name}__build_config") {
|
| + build_config_target_name = "${target_name}__build_config"
|
| + zip_target_name = "${target_name}__zip"
|
| + final_target_name = target_name
|
| +
|
| + write_build_config(build_config_target_name) {
|
| + visibility = [ ":$zip_target_name" ]
|
| type = "android_resources"
|
| - if (defined(invoker.deps)) {
|
| - deps = invoker.deps
|
| - }
|
| }
|
|
|
| - zip("${target_name}__zip") {
|
| + zip(zip_target_name) {
|
| + visibility = [ ":$final_target_name" ]
|
| +
|
| base_dir = invoker.grit_output_dir
|
| inputs = rebase_path(invoker.generated_files, ".", base_dir)
|
| output = resources_zip
|
| + deps = [
|
| + ":$build_config_target_name",
|
| + ]
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| }
|
|
|
| - group(target_name) {
|
| + group(final_target_name) {
|
| + if (defined(invoker.visibility)) {
|
| + visibility = invoker.visibility
|
| + }
|
| deps = [
|
| - ":${target_name}__build_config",
|
| - ":${target_name}__zip",
|
| + ":$zip_target_name",
|
| ]
|
| }
|
| }
|
| @@ -729,7 +799,7 @@ template("java_strings_grd_prebuilt") {
|
| #
|
| # chromium_code: If true, extra analysis warning/errors will be enabled.
|
| #
|
| -# datadeps, testonly
|
| +# data_deps, testonly
|
| #
|
| # Example
|
| # java_binary("foo") {
|
| @@ -749,8 +819,8 @@ template("java_binary") {
|
| if (defined(invoker.chromium_code)) {
|
| chromium_code = invoker.chromium_code
|
| }
|
| - if (defined(invoker.datadeps)) {
|
| - deps = invoker.datadeps
|
| + if (defined(invoker.data_deps)) {
|
| + deps = invoker.data_deps
|
| }
|
| if (defined(invoker.deps)) {
|
| deps = invoker.deps
|
| @@ -863,7 +933,7 @@ template("junit_binary") {
|
| # dependencies for this target. This will allow depending on an
|
| # android_library target, for example.
|
| #
|
| -# datadeps, testonly
|
| +# data_deps, testonly
|
| #
|
| # Example
|
| # java_library("foo_java") {
|
| @@ -891,8 +961,8 @@ template("java_library") {
|
| if (defined(invoker.chromium_code)) {
|
| chromium_code = invoker.chromium_code
|
| }
|
| - if (defined(invoker.datadeps)) {
|
| - deps = invoker.datadeps
|
| + if (defined(invoker.data_deps)) {
|
| + deps = invoker.data_deps
|
| }
|
| if (defined(invoker.deps)) {
|
| deps = invoker.deps
|
| @@ -1027,8 +1097,8 @@ template("android_library") {
|
| if (defined(invoker.chromium_code)) {
|
| chromium_code = invoker.chromium_code
|
| }
|
| - if (defined(invoker.datadeps)) {
|
| - deps = invoker.datadeps
|
| + if (defined(invoker.data_deps)) {
|
| + deps = invoker.data_deps
|
| }
|
| if (defined(invoker.deps)) {
|
| deps = invoker.deps
|
| @@ -1147,7 +1217,7 @@ template("android_java_prebuilt") {
|
| #
|
| # Variables
|
| # android_manifest: Path to AndroidManifest.xml.
|
| -# datadeps: List of dependencies needed at runtime. These will be built but
|
| +# data_deps: List of dependencies needed at runtime. These will be built but
|
| # won't change the generated .apk in any way (in fact they may be built
|
| # after the .apk is).
|
| # deps: List of dependencies. All Android java resources and libraries in the
|
| @@ -1204,10 +1274,13 @@ template("android_apk") {
|
| base_path = "$gen_dir/$target_name"
|
| _build_config = "$target_gen_dir/$target_name.build_config"
|
| resources_zip_path = "$base_path.resources.zip"
|
| - all_resources_zip_path = "$base_path.resources.all.zip"
|
| + _all_resources_zip_path = "$base_path.resources.all.zip"
|
| jar_path = "$base_path.jar"
|
| - final_dex_path = "$gen_dir/classes.dex"
|
| _template_name = target_name
|
| +
|
| + final_dex_path = "$gen_dir/classes.dex"
|
| + final_dex_target_name = "${_template_name}__final_dex"
|
| +
|
| _final_apk_path = ""
|
| if (defined(invoker.final_apk_path)) {
|
| _final_apk_path = invoker.final_apk_path
|
| @@ -1222,6 +1295,15 @@ template("android_apk") {
|
|
|
| _native_libs = []
|
|
|
| + _version_code = "1"
|
| + if (defined(invoker.version_code)) {
|
| + _version_code = invoker.version_code
|
| + }
|
| +
|
| + _version_name = "Developer Build"
|
| + if (defined(invoker.version_name)) {
|
| + _version_name = invoker.version_name
|
| + }
|
| _keystore_path = android_default_keystore_path
|
| _keystore_name = android_default_keystore_name
|
| _keystore_password = android_default_keystore_password
|
| @@ -1239,11 +1321,15 @@ template("android_apk") {
|
|
|
| _load_library_from_apk = false
|
|
|
| + # The dependency that makes the chromium linker, if any is needed.
|
| + _chromium_linker_dep = []
|
| +
|
| if (defined(invoker.native_libs)) {
|
| _use_chromium_linker = false
|
| if (defined(invoker.use_chromium_linker)) {
|
| _use_chromium_linker =
|
| invoker.use_chromium_linker && chromium_linker_supported
|
| + _chromium_linker_dep = [ "//base/android/linker:chromium_android_linker" ]
|
| }
|
|
|
| if (defined(invoker.load_library_from_apk) &&
|
| @@ -1287,16 +1373,25 @@ template("android_apk") {
|
|
|
| _android_manifest = invoker.android_manifest
|
| _rebased_build_config = rebase_path(_build_config, root_build_dir)
|
| + _create_abi_split =
|
| + defined(invoker.create_abi_split) && invoker.create_abi_split
|
| + _create_density_splits =
|
| + defined(invoker.create_density_splits) && invoker.create_density_splits
|
| +
|
| + # Help GN understand that _create_abi_split is not unused (bug in GN).
|
| + assert(_create_abi_split || true)
|
|
|
| - write_build_config("${_template_name}__build_config") {
|
| + build_config_target = "${_template_name}__build_config"
|
| + write_build_config(build_config_target) {
|
| type = "android_apk"
|
| dex_path = final_dex_path
|
| resources_zip = resources_zip_path
|
| build_config = _build_config
|
| android_manifest = _android_manifest
|
|
|
| + deps = _chromium_linker_dep
|
| if (defined(invoker.deps)) {
|
| - deps = invoker.deps
|
| + deps += invoker.deps
|
| }
|
|
|
| if (defined(invoker.apk_under_test)) {
|
| @@ -1308,21 +1403,30 @@ template("android_apk") {
|
|
|
| final_deps = []
|
|
|
| - final_deps += [ ":${_template_name}__process_resources" ]
|
| - process_resources("${_template_name}__process_resources") {
|
| + process_resources_target = "${_template_name}__process_resources"
|
| + final_deps += [ ":$process_resources_target" ]
|
| + process_resources(process_resources_target) {
|
| srcjar_path = "${target_gen_dir}/${target_name}.srcjar"
|
| r_text_path = "${target_gen_dir}/${target_name}_R.txt"
|
| android_manifest = _android_manifest
|
| resource_dirs = [ "//build/android/ant/empty/res" ]
|
| zip_path = resources_zip_path
|
| + all_resources_zip_path = _all_resources_zip_path
|
| generate_constant_ids = true
|
| - build_config = _build_config
|
|
|
| if (defined(invoker.include_all_resources)) {
|
| include_all_resources = invoker.include_all_resources
|
| }
|
| +
|
| + build_config = _build_config
|
| + deps = [
|
| + ":$build_config_target",
|
| + ]
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| }
|
| - _srcjar_deps += [ ":${_template_name}__process_resources" ]
|
| + _srcjar_deps += [ ":$process_resources_target" ]
|
|
|
| if (_native_libs != []) {
|
| _enable_chromium_linker_tests = false
|
| @@ -1338,6 +1442,9 @@ template("android_apk") {
|
| inputs = [
|
| _build_config,
|
| ]
|
| + deps = [
|
| + ":$build_config_target",
|
| + ]
|
|
|
| defines = [
|
| "NATIVE_LIBRARIES_LIST=" +
|
| @@ -1357,11 +1464,16 @@ template("android_apk") {
|
| _srcjar_deps += [ ":${_template_name}__native_libraries_java" ]
|
| }
|
|
|
| - final_deps += [ ":${_template_name}__java" ]
|
| - java_library_impl("${_template_name}__java") {
|
| + java_target = "${_template_name}__java"
|
| + final_deps += [ ":$java_target" ]
|
| + java_library_impl(java_target) {
|
| supports_android = true
|
| requires_android = true
|
| override_build_config = _build_config
|
| + deps = [
|
| + ":$build_config_target",
|
| + ]
|
| +
|
| android_manifest = _android_manifest
|
| chromium_code = true
|
| if (defined(invoker.java_files)) {
|
| @@ -1373,15 +1485,20 @@ template("android_apk") {
|
| }
|
| srcjar_deps = _srcjar_deps
|
| dex_path = base_path + ".dex.jar"
|
| +
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| }
|
|
|
| if (_dist_jar_path != "") {
|
| - final_deps += [ ":${_template_name}__create_dist_jar" ]
|
| + create_dist_target = "${_template_name}__create_dist_jar"
|
| + final_deps += [ ":$create_dist_target" ]
|
|
|
| # TODO(cjhopman): This is only ever needed to calculate the list of tests to
|
| # run. See build/android/pylib/instrumentation/test_jar.py. We should be
|
| # able to just do that calculation at build time instead.
|
| - action("${_template_name}__create_dist_jar") {
|
| + action(create_dist_target) {
|
| script = "//build/android/gyp/create_dist_jar.py"
|
| depfile = "$target_gen_dir/$target_name.d"
|
| inputs = [
|
| @@ -1401,13 +1518,18 @@ template("android_apk") {
|
| inputs += [ jar_path ]
|
| _rebased_jar_path = rebase_path([ jar_path ], root_build_dir)
|
| args += [ "--inputs=$_rebased_jar_path" ]
|
| + deps = [
|
| + ":$build_config_target", # Generates the build config file.
|
| + ":$java_target", # Generates the jar file.
|
| + ]
|
| }
|
| }
|
|
|
| - final_deps += [ ":${_template_name}__final_dex" ]
|
| - dex("${_template_name}__final_dex") {
|
| + final_deps += [ ":$final_dex_target_name" ]
|
| + dex("$final_dex_target_name") {
|
| deps = [
|
| - ":${_template_name}__java",
|
| + ":$build_config_target",
|
| + ":$java_target",
|
| ]
|
| sources = [
|
| jar_path,
|
| @@ -1428,8 +1550,13 @@ template("android_apk") {
|
| outputs = [
|
| depfile,
|
| ]
|
| - inputs = [ _build_config ] + _native_libs
|
| - deps = []
|
| +
|
| + inputs = _native_libs
|
| + deps = _chromium_linker_dep
|
| +
|
| + inputs += [ _build_config ]
|
| + deps += [ ":$build_config_target" ]
|
| +
|
| skip_packing_list = [
|
| "gdbserver",
|
| "libchromium_android_linker.so",
|
| @@ -1445,12 +1572,9 @@ template("android_apk") {
|
| "--depfile",
|
| rebase_path(depfile, root_build_dir),
|
| "--enable-packing=$enable_packing_arg",
|
| - "--has-relocations-with-addends=$relocations_have_addends",
|
| "--exclude-packing-list=$skip_packing_list",
|
| "--android-pack-relocations",
|
| rebase_path(relocation_packer_exe, root_build_dir),
|
| - "--android-objcopy",
|
| - rebase_path(android_objcopy, root_build_dir),
|
| "--stripped-libraries-dir",
|
| rebase_path(root_build_dir, root_build_dir),
|
| "--packed-libraries-dir",
|
| @@ -1459,6 +1583,16 @@ template("android_apk") {
|
| "--clear-dir",
|
| ]
|
|
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| + if (defined(invoker.public_deps)) {
|
| + public_deps = invoker.public_deps
|
| + }
|
| + if (defined(invoker.data_deps)) {
|
| + data_deps = invoker.data_deps
|
| + }
|
| +
|
| if (is_debug) {
|
| rebased_gdbserver = rebase_path([ android_gdbserver ], root_build_dir)
|
| inputs += [ android_gdbserver ]
|
| @@ -1471,25 +1605,27 @@ template("android_apk") {
|
| create_apk("${_template_name}__create") {
|
| apk_path = _final_apk_path
|
| android_manifest = _android_manifest
|
| - resources_zip = all_resources_zip_path
|
| + resources_zip = _all_resources_zip_path
|
| dex_path = final_dex_path
|
| load_library_from_apk = _load_library_from_apk
|
| + create_density_splits = _create_density_splits
|
|
|
| - version_code = "1"
|
| - if (defined(invoker.version_code)) {
|
| - version_code = invoker.version_code
|
| - }
|
| -
|
| - version_name = "Developer Build"
|
| - if (defined(invoker.version_name)) {
|
| - version_name = invoker.version_name
|
| - }
|
| + version_code = _version_code
|
| + version_name = _version_name
|
|
|
| keystore_name = _keystore_name
|
| keystore_path = _keystore_path
|
| keystore_password = _keystore_password
|
|
|
| - deps = []
|
| + # This target generates the input file _all_resources_zip_path.
|
| + deps = [
|
| + ":$process_resources_target",
|
| + ":$final_dex_target_name",
|
| + ]
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| +
|
| if (defined(invoker.asset_location)) {
|
| asset_location = invoker.asset_location
|
|
|
| @@ -1501,16 +1637,157 @@ template("android_apk") {
|
| }
|
| }
|
|
|
| - if (_native_libs != []) {
|
| + if (_native_libs != [] && !_create_abi_split) {
|
| native_libs_dir = _native_libs_dir
|
| deps += [ ":${_template_name}__prepare_native" ]
|
| }
|
| }
|
|
|
| + if (_native_libs != [] && _create_abi_split) {
|
| + _manifest_rule = "${_template_name}__split_manifest_abi_${android_app_abi}"
|
| + generate_split_manifest(_manifest_rule) {
|
| + main_manifest = _android_manifest
|
| + out_manifest =
|
| + "$gen_dir/split-manifests/${android_app_abi}/AndroidManifest.xml"
|
| + split_name = "abi_${android_app_abi}"
|
| + }
|
| +
|
| + _apk_rule = "${_template_name}__split_apk_abi_${android_app_abi}"
|
| + final_deps += [ ":$_apk_rule" ]
|
| + create_apk(_apk_rule) {
|
| + _split_paths = process_file_template(
|
| + [ _final_apk_path ],
|
| + "{{source_dir}}/{{source_name_part}}-abi-${android_app_abi}.apk")
|
| + apk_path = _split_paths[0]
|
| + base_path = "$gen_dir/$_apk_rule"
|
| +
|
| + manifest_outputs = get_target_outputs(":${_manifest_rule}")
|
| + android_manifest = manifest_outputs[1]
|
| + load_library_from_apk = _load_library_from_apk
|
| +
|
| + version_code = _version_code
|
| + version_name = _version_name
|
| +
|
| + keystore_name = _keystore_name
|
| + keystore_path = _keystore_path
|
| + keystore_password = _keystore_password
|
| +
|
| + native_libs_dir = _native_libs_dir
|
| + deps = [
|
| + ":${_template_name}__prepare_native",
|
| + ]
|
| + }
|
| + }
|
| +
|
| group(target_name) {
|
| deps = final_deps
|
| - if (defined(invoker.datadeps)) {
|
| - datadeps = invoker.datadeps
|
| + if (defined(invoker.data_deps)) {
|
| + data_deps = invoker.data_deps
|
| + }
|
| + }
|
| +}
|
| +
|
| +# Declare an Android instrumentation test apk
|
| +#
|
| +# This target creates an Android instrumentation test apk.
|
| +#
|
| +# Variables
|
| +# android_manifest: Path to AndroidManifest.xml.
|
| +# data_deps: List of dependencies needed at runtime. These will be built but
|
| +# won't change the generated .apk in any way (in fact they may be built
|
| +# after the .apk is).
|
| +# deps: List of dependencies. All Android java resources and libraries in the
|
| +# "transitive closure" of these dependencies will be included in the apk.
|
| +# Note: this "transitive closure" actually only includes such targets if
|
| +# they are depended on through android_library or android_resources targets
|
| +# (and so not through builtin targets like 'action', 'group', etc).
|
| +# java_files: List of .java files to include in the apk.
|
| +# srcjar_deps: List of srcjar dependencies. The .java files in the srcjars
|
| +# will be added to java_files and be included in this apk.
|
| +# apk_name: Name for final apk.
|
| +# final_apk_path: Path to final built apk. Default is
|
| +# $root_out_dir/apks/$apk_name.apk. Setting this will override apk_name.
|
| +# native_libs: List paths of native libraries to include in this apk. If these
|
| +# libraries depend on other shared_library targets, those dependencies will
|
| +# also be included in the apk.
|
| +# apk_under_test: The apk being tested.
|
| +# isolate_file: Isolate file containing the list of test data dependencies.
|
| +#
|
| +# DEPRECATED_java_in_dir: Directory containing java files. All .java files in
|
| +# this directory will be included in the library. This is only supported to
|
| +# ease the gyp->gn conversion and will be removed in the future.
|
| +#
|
| +# Example
|
| +# instrumentation_test_apk("foo_test_apk") {
|
| +# android_manifest = "AndroidManifest.xml"
|
| +# apk_name = "FooTest"
|
| +# apk_under_test = "Foo"
|
| +# java_files = [
|
| +# "android/org/chromium/foo/FooTestCase.java",
|
| +# "android/org/chromium/foo/FooExampleTest.java",
|
| +# ]
|
| +# deps = [
|
| +# ":foo_test_support_java"
|
| +# ]
|
| +# }
|
| +template("instrumentation_test_apk") {
|
| + set_sources_assignment_filter([])
|
| + testonly = true
|
| + _template_name = target_name
|
| +
|
| + if (defined(invoker.apk_name)) {
|
| + test_runner_data_dep = [ ":${_template_name}__test_runner_script" ]
|
| + test_runner_script("${_template_name}__test_runner_script") {
|
| + test_name = invoker.target_name
|
| + test_type = "instrumentation"
|
| + test_apk = invoker.apk_name
|
| + if (defined(invoker.isolate_file)) {
|
| + isolate_file = invoker.isolate_file
|
| + }
|
| + }
|
| + }
|
| +
|
| + android_apk(target_name) {
|
| + if (defined(invoker.android_manifest)) {
|
| + android_manifest = invoker.android_manifest
|
| + }
|
| + data_deps = [
|
| + "//testing/android/driver:driver_apk",
|
| + "//tools/android/forwarder2",
|
| + "//tools/android/md5sum",
|
| + ]
|
| + if (defined(test_runner_data_dep)) {
|
| + data_deps += test_runner_data_dep
|
| + }
|
| + if (defined(invoker.data_deps)) {
|
| + data_deps += invoker.data_deps
|
| + }
|
| + deps = [
|
| + "//testing/android/broker:broker_java",
|
| + ]
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| + if (defined(invoker.java_files)) {
|
| + java_files = invoker.java_files
|
| + }
|
| + if (defined(invoker.srcjar_deps)) {
|
| + srcjar_deps = invoker.srcjar_deps
|
| + }
|
| + if (defined(invoker.apk_name)) {
|
| + apk_name = invoker.apk_name
|
| + }
|
| + if (defined(invoker.final_apk_path)) {
|
| + final_apk_path = invoker.final_apk_path
|
| + }
|
| + if (defined(invoker.native_libs)) {
|
| + native_libs = invoker.native_libs
|
| + }
|
| + if (defined(invoker.apk_under_test)) {
|
| + apk_under_test = invoker.apk_under_test
|
| + }
|
| + if (defined(invoker.DEPRECATED_java_in_dir)) {
|
| + DEPRECATED_java_in_dir = invoker.DEPRECATED_java_in_dir
|
| }
|
| }
|
| }
|
| @@ -1565,7 +1842,9 @@ template("unittest_apk") {
|
| android_apk(target_name) {
|
| final_apk_path = "$root_build_dir/${apk_name}_apk/${apk_name}-debug.apk"
|
| java_files = [
|
| + "//testing/android/native_test/java/src/org/chromium/native_test/NativeBrowserTestActivity.java",
|
| "//testing/android/native_test/java/src/org/chromium/native_test/NativeTestActivity.java",
|
| + "//testing/android/native_test/java/src/org/chromium/native_test/NativeUnitTestActivity.java",
|
| "//testing/android/native_test/java/src/org/chromium/native_test/NativeTestInstrumentationTestRunner.java",
|
| ]
|
| android_manifest = "//testing/android/native_test/java/AndroidManifest.xml"
|
| @@ -1581,14 +1860,12 @@ template("unittest_apk") {
|
| if (defined(invoker.deps)) {
|
| deps += invoker.deps
|
| }
|
| - datadeps = [
|
| - "//tools/android/md5sum",
|
| - ]
|
| + data_deps = [ "//tools/android/md5sum" ]
|
| if (host_os == "linux") {
|
| - datadeps += [ "//tools/android/forwarder2" ]
|
| + data_deps += [ "//tools/android/forwarder2" ]
|
| }
|
| - if (defined(invoker.datadeps)) {
|
| - datadeps += invoker.datadeps
|
| + if (defined(invoker.data_deps)) {
|
| + data_deps += invoker.data_deps
|
| }
|
| }
|
| }
|
| @@ -1687,6 +1964,7 @@ template("android_aidl") {
|
| # create_native_executable_dist("foo_dist") {
|
| # dist_dir = "$root_build_dir/foo_dist"
|
| # binary = "$root_build_dir/exe.stripped/foo"
|
| +# deps = [ ":the_thing_that_makes_foo" ]
|
| # }
|
| template("create_native_executable_dist") {
|
| set_sources_assignment_filter([])
|
| @@ -1696,7 +1974,6 @@ template("create_native_executable_dist") {
|
|
|
| dist_dir = invoker.dist_dir
|
| binary = invoker.binary
|
| - final_deps = []
|
| template_name = target_name
|
|
|
| libraries_list =
|
| @@ -1707,9 +1984,13 @@ template("create_native_executable_dist") {
|
| #'<(DEPTH)/build/android/setup.gyp:copy_system_libraries',
|
| #],
|
|
|
| + find_deps_target_name = "${template_name}__find_library_dependencies"
|
| + copy_target_name = "${template_name}__copy_libraries_and_exe"
|
| +
|
| stripped_libraries_dir = "$root_build_dir/lib.stripped"
|
| - final_deps += [ ":${template_name}__find_library_dependencies" ]
|
| - action("${template_name}__find_library_dependencies") {
|
| + action(find_deps_target_name) {
|
| + visibility = [ ":$copy_target_name" ]
|
| +
|
| script = "//build/android/gyp/write_ordered_libraries.py"
|
| depfile = "$target_gen_dir/$target_name.d"
|
| inputs = [
|
| @@ -1732,10 +2013,14 @@ template("create_native_executable_dist") {
|
| "--readelf",
|
| rebase_path(android_readelf, root_build_dir),
|
| ]
|
| + if (defined(invoker.deps)) {
|
| + deps = invoker.deps
|
| + }
|
| }
|
|
|
| - final_deps += [ ":${template_name}__copy_libraries_and_exe" ]
|
| - copy_ex("${template_name}__copy_libraries_and_exe") {
|
| + copy_ex(copy_target_name) {
|
| + visibility = [ ":$template_name" ]
|
| +
|
| clear_dir = true
|
| inputs = [
|
| binary,
|
| @@ -1748,10 +2033,22 @@ template("create_native_executable_dist") {
|
| "--files=$rebased_binaries_list",
|
| "--files=@FileArg($rebased_libraries_list:libraries)",
|
| ]
|
| +
|
| + deps = [
|
| + ":$find_deps_target_name",
|
| + ]
|
| + if (defined(invoker.deps)) {
|
| + deps += invoker.deps
|
| + }
|
| }
|
|
|
| - group(target_name) {
|
| - deps = final_deps
|
| + group(template_name) {
|
| + if (defined(invoker.visibility)) {
|
| + visibility = invoker.visibility
|
| + }
|
| + deps = [
|
| + ":$copy_target_name",
|
| + ]
|
| }
|
| }
|
|
|
|
|