xref: /aosp_15_r20/build/bazel/rules/java/library.bzl (revision 7594170e27e0732bc44b93d1440d87a54b6ffe7c)
1*7594170eSAndroid Build Coastguard Worker# Copyright (C) 2023 The Android Open Source Project
2*7594170eSAndroid Build Coastguard Worker#
3*7594170eSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
4*7594170eSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
5*7594170eSAndroid Build Coastguard Worker# You may obtain a copy of the License at
6*7594170eSAndroid Build Coastguard Worker#
7*7594170eSAndroid Build Coastguard Worker#      http:#www.apache.org/licenses/LICENSE-2.0
8*7594170eSAndroid Build Coastguard Worker#
9*7594170eSAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
10*7594170eSAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
11*7594170eSAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*7594170eSAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
13*7594170eSAndroid Build Coastguard Worker# limitations under the License.
14*7594170eSAndroid Build Coastguard Worker
15*7594170eSAndroid Build Coastguard Worker"""Macro wrapping the java_library for bp2build. """
16*7594170eSAndroid Build Coastguard Worker
17*7594170eSAndroid Build Coastguard Workerload(
18*7594170eSAndroid Build Coastguard Worker    "@rules_java//java:defs.bzl",
19*7594170eSAndroid Build Coastguard Worker    _java_library = "java_library",
20*7594170eSAndroid Build Coastguard Worker)
21*7594170eSAndroid Build Coastguard Workerload("//build/bazel/rules/java:sdk_transition.bzl", "sdk_transition_attrs")
22*7594170eSAndroid Build Coastguard Worker
23*7594170eSAndroid Build Coastguard Worker_sharded_java_library = experimental_java_library_export_do_not_use.sharded_java_library(
24*7594170eSAndroid Build Coastguard Worker    default_shard_size = 0,
25*7594170eSAndroid Build Coastguard Worker)
26*7594170eSAndroid Build Coastguard Worker
27*7594170eSAndroid Build Coastguard Worker# TODO(b/277801336): document these attributes.
28*7594170eSAndroid Build Coastguard Workerdef java_library(
29*7594170eSAndroid Build Coastguard Worker        name = "",
30*7594170eSAndroid Build Coastguard Worker        srcs = [],
31*7594170eSAndroid Build Coastguard Worker        deps = [],
32*7594170eSAndroid Build Coastguard Worker        javacopts = [],
33*7594170eSAndroid Build Coastguard Worker        sdk_version = None,
34*7594170eSAndroid Build Coastguard Worker        java_version = None,
35*7594170eSAndroid Build Coastguard Worker        errorprone_force_enable = None,
36*7594170eSAndroid Build Coastguard Worker        tags = [],
37*7594170eSAndroid Build Coastguard Worker        target_compatible_with = [],
38*7594170eSAndroid Build Coastguard Worker        visibility = None,
39*7594170eSAndroid Build Coastguard Worker        javac_shard_size = 0,
40*7594170eSAndroid Build Coastguard Worker        **kwargs):
41*7594170eSAndroid Build Coastguard Worker    """ java_library macro wrapper that handles custom attrs needed in AOSP
42*7594170eSAndroid Build Coastguard Worker
43*7594170eSAndroid Build Coastguard Worker    Args:
44*7594170eSAndroid Build Coastguard Worker        errorprone_force_enable: set this to true to always run Error Prone
45*7594170eSAndroid Build Coastguard Worker            on this target (overriding the value of environment variable
46*7594170eSAndroid Build Coastguard Worker            RUN_ERROR_PRONE). Error Prone can be force disabled for an individual
47*7594170eSAndroid Build Coastguard Worker            module by adding the "-XepDisableAllChecks" flag to javacopts
48*7594170eSAndroid Build Coastguard Worker    """
49*7594170eSAndroid Build Coastguard Worker    lib_name = name + "_private"
50*7594170eSAndroid Build Coastguard Worker
51*7594170eSAndroid Build Coastguard Worker    opts = javacopts
52*7594170eSAndroid Build Coastguard Worker    if errorprone_force_enable == None:
53*7594170eSAndroid Build Coastguard Worker        # TODO (b/227504307) temporarily disable errorprone until environment variable is handled
54*7594170eSAndroid Build Coastguard Worker        opts = opts + ["-XepDisableAllChecks"]
55*7594170eSAndroid Build Coastguard Worker
56*7594170eSAndroid Build Coastguard Worker    args = {
57*7594170eSAndroid Build Coastguard Worker        "name": lib_name,
58*7594170eSAndroid Build Coastguard Worker        "srcs": srcs,
59*7594170eSAndroid Build Coastguard Worker        "deps": deps,
60*7594170eSAndroid Build Coastguard Worker        "javacopts": opts,
61*7594170eSAndroid Build Coastguard Worker        "tags": tags + ["manual"],
62*7594170eSAndroid Build Coastguard Worker        "target_compatible_with": target_compatible_with,
63*7594170eSAndroid Build Coastguard Worker        "visibility": ["//visibility:private"],
64*7594170eSAndroid Build Coastguard Worker    }
65*7594170eSAndroid Build Coastguard Worker    args.update(kwargs)
66*7594170eSAndroid Build Coastguard Worker    if javac_shard_size > 0:
67*7594170eSAndroid Build Coastguard Worker        args["experimental_javac_shard_size"] = javac_shard_size
68*7594170eSAndroid Build Coastguard Worker        _sharded_java_library(**args)
69*7594170eSAndroid Build Coastguard Worker    else:
70*7594170eSAndroid Build Coastguard Worker        _java_library(**args)
71*7594170eSAndroid Build Coastguard Worker
72*7594170eSAndroid Build Coastguard Worker    java_library_sdk_transition(
73*7594170eSAndroid Build Coastguard Worker        name = name,
74*7594170eSAndroid Build Coastguard Worker        sdk_version = sdk_version,
75*7594170eSAndroid Build Coastguard Worker        java_version = java_version,
76*7594170eSAndroid Build Coastguard Worker        exports = lib_name,
77*7594170eSAndroid Build Coastguard Worker        tags = tags,
78*7594170eSAndroid Build Coastguard Worker        target_compatible_with = target_compatible_with,
79*7594170eSAndroid Build Coastguard Worker        visibility = visibility,
80*7594170eSAndroid Build Coastguard Worker    )
81*7594170eSAndroid Build Coastguard Worker
82*7594170eSAndroid Build Coastguard Worker# The list of providers to forward was determined using cquery on one
83*7594170eSAndroid Build Coastguard Worker# of the example targets listed under EXAMPLE_WRAPPER_TARGETS at
84*7594170eSAndroid Build Coastguard Worker# //build/bazel/ci/target_lists.sh. It may not be exhaustive. A unit
85*7594170eSAndroid Build Coastguard Worker# test ensures that the wrapper's providers and the wrapped rule's do
86*7594170eSAndroid Build Coastguard Worker# match.
87*7594170eSAndroid Build Coastguard Workerdef _java_library_sdk_transition_impl(ctx):
88*7594170eSAndroid Build Coastguard Worker    return [
89*7594170eSAndroid Build Coastguard Worker        ctx.attr.exports[0][JavaInfo],
90*7594170eSAndroid Build Coastguard Worker        ctx.attr.exports[0][InstrumentedFilesInfo],
91*7594170eSAndroid Build Coastguard Worker        ctx.attr.exports[0][ProguardSpecProvider],
92*7594170eSAndroid Build Coastguard Worker        ctx.attr.exports[0][OutputGroupInfo],
93*7594170eSAndroid Build Coastguard Worker        ctx.attr.exports[0][DefaultInfo],
94*7594170eSAndroid Build Coastguard Worker    ]
95*7594170eSAndroid Build Coastguard Worker
96*7594170eSAndroid Build Coastguard Workerjava_library_sdk_transition = rule(
97*7594170eSAndroid Build Coastguard Worker    implementation = _java_library_sdk_transition_impl,
98*7594170eSAndroid Build Coastguard Worker    attrs = sdk_transition_attrs,
99*7594170eSAndroid Build Coastguard Worker    provides = [JavaInfo],
100*7594170eSAndroid Build Coastguard Worker)
101