Commit aaf0add8 authored by Christopher Grant's avatar Christopher Grant Committed by Commit Bot

Reland "Introduce bundle-specific native libraries"

This is a reland of 50ab16b8

Original change's description:
> Introduce bundle-specific native libraries
> 
> This will allow native code to be stripped out of the main library
> when it moves to a Dynamic Feature Module.  For now, the libraries will
> be identical.
> 
> BUG=874584
> 
> Change-Id: I8a54e6402a3686939dd14b509c614da99b0ff913
> Reviewed-on: https://chromium-review.googlesource.com/c/1332248
> Reviewed-by: Yaron Friedman <yfriedman@chromium.org>
> Reviewed-by: David Turner <digit@chromium.org>
> Reviewed-by: Tibor Goldschwendt <tiborg@chromium.org>
> Commit-Queue: Christopher Grant <cjgrant@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#608519}

Bug: 874584
Change-Id: I197543b47e1613f93164ebd6f9a4c9d84743e284
Reviewed-on: https://chromium-review.googlesource.com/c/1344875
Commit-Queue: Christopher Grant <cjgrant@chromium.org>
Reviewed-by: default avataragrieve <agrieve@chromium.org>
Cr-Commit-Position: refs/heads/master@{#610456}
parent f72ca071
This diff is collapsed.
...@@ -4,10 +4,10 @@ ...@@ -4,10 +4,10 @@
import("//base/android/linker/config.gni") import("//base/android/linker/config.gni")
import("//base/android/proguard/proguard.gni") import("//base/android/proguard/proguard.gni")
import("//build/config/android/rules.gni")
import("//build/config/locales.gni")
import("//build/config/android/extract_unwind_tables.gni") import("//build/config/android/extract_unwind_tables.gni")
import("//build/config/android/rules.gni")
import("//build/config/compiler/compiler.gni") import("//build/config/compiler/compiler.gni")
import("//build/config/locales.gni")
import("//chrome/common/features.gni") import("//chrome/common/features.gni")
import("//device/vr/buildflags/buildflags.gni") import("//device/vr/buildflags/buildflags.gni")
import("channel.gni") import("channel.gni")
...@@ -220,14 +220,25 @@ template("monochrome_public_common_apk_or_module_tmpl") { ...@@ -220,14 +220,25 @@ template("monochrome_public_common_apk_or_module_tmpl") {
!invoker.use_trichrome_library) { !invoker.use_trichrome_library) {
# Always build 64-bit //android_webview:monochrome because Chrome runs # Always build 64-bit //android_webview:monochrome because Chrome runs
# in 32-bit mode. # in 32-bit mode.
if (invoker.target_type == "android_app_bundle_module") {
_suffix = "_base"
} else {
_suffix = ""
}
if (android_64bit_target_cpu) { if (android_64bit_target_cpu) {
shared_libraries = [ "//android_webview:monochrome" ] shared_libraries = [ "//android_webview:monochrome" ]
} else { if (invoker.add_unwind_tables_in_apk) {
shared_libraries = [ "//chrome/android:monochrome" ] shared_library_for_unwind_asset = "monochrome"
} }
if (android_64bit_target_cpu && build_apk_secondary_abi) { if (build_apk_secondary_abi) {
secondary_abi_shared_libraries = secondary_abi_shared_libraries =
[ "//chrome/android:monochrome_secondary_abi_lib" ] [ "//chrome/android:monochrome${_suffix}_secondary_abi_lib" ]
}
} else {
shared_libraries = [ "//chrome/android:monochrome${_suffix}" ]
if (invoker.add_unwind_tables_in_apk) {
shared_library_for_unwind_asset = "monochrome${_suffix}"
}
} }
} else { } else {
# Include a 32-bit placeholder library to ensure that Chrome runs in # Include a 32-bit placeholder library to ensure that Chrome runs in
...@@ -239,9 +250,6 @@ template("monochrome_public_common_apk_or_module_tmpl") { ...@@ -239,9 +250,6 @@ template("monochrome_public_common_apk_or_module_tmpl") {
native_lib_placeholders = [ "libdummy.so" ] native_lib_placeholders = [ "libdummy.so" ]
} }
} }
if (invoker.add_unwind_tables_in_apk) {
shared_library_for_unwind_asset = "monochrome"
}
alternative_android_sdk_dep = webview_framework_dep alternative_android_sdk_dep = webview_framework_dep
app_as_shared_lib = true app_as_shared_lib = true
...@@ -282,9 +290,13 @@ template("monochrome_public_common_apk_or_module_tmpl") { ...@@ -282,9 +290,13 @@ template("monochrome_public_common_apk_or_module_tmpl") {
"//android_webview/apk:webview_license_activity_java", "//android_webview/apk:webview_license_activity_java",
"//android_webview/glue", "//android_webview/glue",
"//chrome/android:chrome_public_non_pak_assets", "//chrome/android:chrome_public_non_pak_assets",
"//chrome/android:monochrome_apk_pak_assets",
"//chrome/android/monochrome:monochrome_license_provider_java", "//chrome/android/monochrome:monochrome_license_provider_java",
] ]
if (invoker.target_type == "android_app_bundle_module") {
deps += [ "//chrome/android:monochrome_bundle_pak_assets" ]
} else {
deps += [ "//chrome/android:monochrome_apk_pak_assets" ]
}
if (_enable_multidex && invoker.target_type == "android_apk" && if (_enable_multidex && invoker.target_type == "android_apk" &&
!defined(invoker.negative_main_dex_globs)) { !defined(invoker.negative_main_dex_globs)) {
...@@ -328,21 +340,3 @@ template("monochrome_public_common_apk_or_module_tmpl") { ...@@ -328,21 +340,3 @@ template("monochrome_public_common_apk_or_module_tmpl") {
} }
} }
} }
# These empty templates are still being called from the clank/ BUILD.gn
# scripts. Remove them when they have been fixed to call the
# xxx_common_apk_or_module_tmpl templates above.
template("chrome_public_apk_tmpl") {
chrome_public_common_apk_or_module_tmpl(target_name) {
forward_variables_from(invoker, "*")
target_type = "android_apk"
}
}
template("monochrome_public_apk_tmpl") {
monochrome_public_common_apk_or_module_tmpl(target_name) {
forward_variables_from(invoker, "*")
target_type = "android_apk"
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment