blob: 02969b267e6d5bb337f897e9d0cc4c942ca5a1b5 [file] [log] [blame]
# Copyright 2018 The Bazel Authors. All rights reserved.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""Rule adapter for android_binary."""
load("//mobile_install:launcher_direct.bzl", "make_direct_launcher")
load("//mobile_install:process.bzl", "process")
load(
"//mobile_install:providers.bzl",
"MIAndroidDexInfo",
"MIAndroidResourcesInfo",
"MIJavaResourcesInfo",
"providers",
)
load("//mobile_install:transform.bzl", "dex", "filter_jars")
load("//mobile_install:utils.bzl", "utils")
load("//providers:providers.bzl", "AndroidBinaryNativeLibsInfo", "AndroidBuildStampInfo", "AndroidIdeInfo")
load("//rules:visibility.bzl", "PROJECT_VISIBILITY")
load("//rules/flags:flags.bzl", "flags")
load("@rules_java//java/common:java_info.bzl", "JavaInfo")
load(":base.bzl", "make_adapter")
load(":desugar.bzl", "get_desugar_classpath")
visibility(PROJECT_VISIBILITY)
def _aspect_attrs():
"""Attrs of the rule requiring traversal by the aspect."""
return ["_android_sdk", "deps", "resources", "instruments"]
def extract(target, ctx):
# extract is made visibile for testing
"""extract the rule and target data.
Args:
target: The target.
ctx: The context.
Returns:
Input for process method
"""
extension_registry_class_jar = utils.get_extension_registry_class_jar(target)
build_stamp_java_info = target[AndroidBuildStampInfo].java_info if AndroidBuildStampInfo in target else None
java_package = target[AndroidIdeInfo].java_package
if java_package == None:
fail("Unable to infer Java package for %s. Try setting `custom_package` if it does not live under a java/ or javatests/ package." % str(target))
return dict(
debug_key = utils.only(ctx.rule.files.debug_key, allow_empty = True),
debug_signing_keys = ctx.rule.files.debug_signing_keys,
debug_signing_lineage_file = utils.only(ctx.rule.files.debug_signing_lineage_file, allow_empty = True),
key_rotation_min_sdk = ctx.rule.attr.key_rotation_min_sdk,
merged_manifest = target[AndroidIdeInfo].generated_manifest,
native_libs = target[AndroidIdeInfo].native_libs,
package = java_package,
resource_apk = target[AndroidIdeInfo].resource_apk,
resource_src_jar = target[AndroidIdeInfo].resource_jar.source_jar, # This is the R with real ids.
aar_native_libs = target[AndroidBinaryNativeLibsInfo].transitive_native_libs_by_cpu_architecture,
android_dex_info = providers.make_mi_android_dex_info(
dex_shards = dex(
ctx,
filter_jars(
ctx.label.name + "_resources.jar",
target[JavaInfo].runtime_output_jars,
) +
(
[
extension_registry_class_jar,
] if extension_registry_class_jar else []
) +
(
build_stamp_java_info.runtime_output_jars if build_stamp_java_info else []
),
get_desugar_classpath(target[JavaInfo]),
),
deps = providers.collect(MIAndroidDexInfo, ctx.rule.attr.deps),
),
# TODO(djwhang): It wasteful to collect packages in
# android_resources_info, rather we should be looking to pull them
# from the resources_v3_info.
android_resources_info = providers.make_mi_android_resources_info(
package = target[AndroidIdeInfo].java_package,
deps = providers.collect(
MIAndroidResourcesInfo,
ctx.rule.attr.deps,
),
),
java_resources_info = providers.make_mi_java_resources_info(
deps = providers.collect(
MIJavaResourcesInfo,
ctx.rule.attr.deps,
),
),
apk = target[AndroidIdeInfo].signed_apk,
)
def adapt(target, ctx):
# adapt is made visibile for testing
"""Adapts the android rule
Args:
target: The target.
ctx: The context.
Returns:
A list of providers
"""
# launcher is created here to be used as the sibling everywhere else.
launcher = utils.isolated_declare_file(ctx, ctx.label.name + "_mi/launcher")
mi_app_info = process(ctx, sibling = launcher, **extract(target, ctx))
mi_app_launch_info = make_direct_launcher(
ctx,
mi_app_info,
launcher,
use_adb_root = flags.get(ctx).use_adb_root,
)
return [
mi_app_info,
mi_app_launch_info,
OutputGroupInfo(
mobile_install_INTERNAL_ = depset(mi_app_launch_info.runfiles).to_list(),
mobile_install_launcher_INTERNAL_ = [mi_app_launch_info.launcher],
),
]
android_binary = make_adapter(_aspect_attrs, adapt)