Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(2782)

Unified Diff: build/config/android/rules.gni

Issue 386473002: Add dexing for libraries and apks (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@gn-apk-first
Patch Set: Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « build/config/android/internal_rules.gni ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: build/config/android/rules.gni
diff --git a/build/config/android/rules.gni b/build/config/android/rules.gni
index ae0d1e3c89bf2aa6e1217b300d76d0ee96b12f1c..924c261a6b9529716f50b53d3ce6c68d35b7cf43 100644
--- a/build/config/android/rules.gni
+++ b/build/config/android/rules.gni
@@ -425,6 +425,7 @@ template("android_library") {
base_path = "$target_gen_dir/$target_name"
build_config = base_path + ".build_config"
jar_path = base_path + ".jar"
+ dex_path = base_path + ".dex.jar"
write_build_config("${target_name}__build_config") {
type = "android_library"
@@ -495,11 +496,12 @@ template("android_library") {
template("android_apk") {
gen_dir = "$target_gen_dir/$target_name"
base_path = "$gen_dir/$target_name"
- build_config = base_path + ".build_config"
- resource_zip_path = base_path + ".resources.zip"
- all_resources_zip_path = base_path + ".resources.all.zip"
- resource_srcjar_path = base_path + ".resources.srcjar"
- jar_path = base_path + ".jar"
+ build_config = "$base_path.build_config"
+ resources_zip_path = "$base_path.resources.zip"
+ all_resources_zip_path = "$base_path.resources.all.zip"
+ resource_srcjar_path = "$base_path.resources.srcjar"
+ jar_path = "$base_path.jar"
+ final_dex_path = "$gen_dir/classes.dex"
# Just mark these as used for now.
assert(!defined(invoker.native_libs)
@@ -507,7 +509,6 @@ template("android_apk") {
assert(!defined(invoker.final_apk_path)
|| invoker.final_apk_path == "" || true)
- final_deps = []
# TODO(cjhopman): Remove this once we correctly generate the real
# NativeLibraries.java
@@ -519,32 +520,43 @@ template("android_apk") {
write_build_config("${target_name}__build_config") {
type = "android_apk"
srcjar = resource_srcjar_path
- resources_zip = resource_zip_path
+ dex_path = final_dex_path
+ resources_zip = resources_zip_path
if (defined(invoker.deps)) {
deps = invoker.deps
}
}
+ final_deps = []
+
final_deps += [":${target_name}__process_resources"]
process_resources("${target_name}__process_resources") {
android_manifest = invoker.android_manifest
resource_dirs = ["//build/android/ant/empty/res"]
- zip_path = resource_zip_path
+ zip_path = resources_zip_path
srcjar_path = resource_srcjar_path
generate_constant_ids = true
}
+ rebased_build_config = rebase_path(build_config, root_build_dir)
+
final_deps += [":${target_name}__java"]
android_java_library("${target_name}__java") {
java_files = invoker.java_files
+ dex_path = base_path + ".dex.jar"
}
- # TODO(cjhopman): dex
- # TODO(cjhopman): native
- # TODO(cjhopman): create+finalize apk
+ final_deps += [":${target_name}__final_dex"]
+ dex("${target_name}__final_dex") {
+ sources = [jar_path]
+ inputs = [build_config]
+ output = final_dex_path
+ dex_arg_key = "${rebased_build_config}:apk_dex:dependency_dex_files"
+ args = ["--inputs=@FileArg($dex_arg_key)"]
+ }
group(target_name) {
deps = final_deps
« no previous file with comments | « build/config/android/internal_rules.gni ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698