xref: /aosp_15_r20/external/grpc-grpc/bazel/cc_grpc_library.bzl (revision cc02d7e222339f7a4f6ba5f422e6413f4bd931f2)
1*cc02d7e2SAndroid Build Coastguard Worker# Copyright 2021 The gRPC Authors
2*cc02d7e2SAndroid Build Coastguard Worker#
3*cc02d7e2SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
4*cc02d7e2SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
5*cc02d7e2SAndroid Build Coastguard Worker# You may obtain a copy of the License at
6*cc02d7e2SAndroid Build Coastguard Worker#
7*cc02d7e2SAndroid Build Coastguard Worker#     http://www.apache.org/licenses/LICENSE-2.0
8*cc02d7e2SAndroid Build Coastguard Worker#
9*cc02d7e2SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
10*cc02d7e2SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
11*cc02d7e2SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*cc02d7e2SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
13*cc02d7e2SAndroid Build Coastguard Worker# limitations under the License.
14*cc02d7e2SAndroid Build Coastguard Worker"""Generates and compiles C++ grpc stubs from proto_library rules."""
15*cc02d7e2SAndroid Build Coastguard Worker
16*cc02d7e2SAndroid Build Coastguard Workerload("@rules_proto//proto:defs.bzl", "proto_library")
17*cc02d7e2SAndroid Build Coastguard Workerload("//bazel:generate_cc.bzl", "generate_cc")
18*cc02d7e2SAndroid Build Coastguard Workerload("//bazel:protobuf.bzl", "well_known_proto_libs")
19*cc02d7e2SAndroid Build Coastguard Worker
20*cc02d7e2SAndroid Build Coastguard Workerdef cc_grpc_library(
21*cc02d7e2SAndroid Build Coastguard Worker        name,
22*cc02d7e2SAndroid Build Coastguard Worker        srcs,
23*cc02d7e2SAndroid Build Coastguard Worker        deps,
24*cc02d7e2SAndroid Build Coastguard Worker        proto_only = False,
25*cc02d7e2SAndroid Build Coastguard Worker        well_known_protos = False,
26*cc02d7e2SAndroid Build Coastguard Worker        generate_mocks = False,
27*cc02d7e2SAndroid Build Coastguard Worker        use_external = False,
28*cc02d7e2SAndroid Build Coastguard Worker        grpc_only = False,
29*cc02d7e2SAndroid Build Coastguard Worker        **kwargs):
30*cc02d7e2SAndroid Build Coastguard Worker    """Generates C++ grpc classes for services defined in a proto file.
31*cc02d7e2SAndroid Build Coastguard Worker
32*cc02d7e2SAndroid Build Coastguard Worker    If grpc_only is True, this rule is compatible with proto_library and
33*cc02d7e2SAndroid Build Coastguard Worker    cc_proto_library native rules such that it expects proto_library target
34*cc02d7e2SAndroid Build Coastguard Worker    as srcs argument and generates only grpc library classes, expecting
35*cc02d7e2SAndroid Build Coastguard Worker    protobuf messages classes library (cc_proto_library target) to be passed in
36*cc02d7e2SAndroid Build Coastguard Worker    deps argument. By default grpc_only is False which makes this rule to behave
37*cc02d7e2SAndroid Build Coastguard Worker    in a backwards-compatible mode (trying to generate both proto and grpc
38*cc02d7e2SAndroid Build Coastguard Worker    classes).
39*cc02d7e2SAndroid Build Coastguard Worker
40*cc02d7e2SAndroid Build Coastguard Worker    Assumes the generated classes will be used in cc_api_version = 2.
41*cc02d7e2SAndroid Build Coastguard Worker
42*cc02d7e2SAndroid Build Coastguard Worker    Args:
43*cc02d7e2SAndroid Build Coastguard Worker        name (str): Name of rule.
44*cc02d7e2SAndroid Build Coastguard Worker        srcs (list): A single .proto file which contains services definitions,
45*cc02d7e2SAndroid Build Coastguard Worker          or if grpc_only parameter is True, a single proto_library which
46*cc02d7e2SAndroid Build Coastguard Worker          contains services descriptors.
47*cc02d7e2SAndroid Build Coastguard Worker        deps (list): A list of C++ proto_library (or cc_proto_library) which
48*cc02d7e2SAndroid Build Coastguard Worker          provides the compiled code of any message that the services depend on.
49*cc02d7e2SAndroid Build Coastguard Worker        proto_only (bool): If True, create only C++ proto classes library,
50*cc02d7e2SAndroid Build Coastguard Worker          avoid creating C++ grpc classes library (expect it in deps).
51*cc02d7e2SAndroid Build Coastguard Worker          Deprecated, use native cc_proto_library instead. False by default.
52*cc02d7e2SAndroid Build Coastguard Worker        well_known_protos (bool): Should this library additionally depend on
53*cc02d7e2SAndroid Build Coastguard Worker          well known protos. Deprecated, the well known protos should be
54*cc02d7e2SAndroid Build Coastguard Worker          specified as explicit dependencies of the proto_library target
55*cc02d7e2SAndroid Build Coastguard Worker          (passed in srcs parameter) instead. False by default.
56*cc02d7e2SAndroid Build Coastguard Worker        generate_mocks (bool): when True, Google Mock code for client stub is
57*cc02d7e2SAndroid Build Coastguard Worker          generated. False by default.
58*cc02d7e2SAndroid Build Coastguard Worker        use_external (bool): Not used.
59*cc02d7e2SAndroid Build Coastguard Worker        grpc_only (bool): if True, generate only grpc library, expecting
60*cc02d7e2SAndroid Build Coastguard Worker          protobuf messages library (cc_proto_library target) to be passed as
61*cc02d7e2SAndroid Build Coastguard Worker          deps. False by default (will become True by default eventually).
62*cc02d7e2SAndroid Build Coastguard Worker        **kwargs: rest of arguments, e.g., compatible_with and visibility
63*cc02d7e2SAndroid Build Coastguard Worker    """
64*cc02d7e2SAndroid Build Coastguard Worker    if len(srcs) > 1:
65*cc02d7e2SAndroid Build Coastguard Worker        fail("Only one srcs value supported", "srcs")
66*cc02d7e2SAndroid Build Coastguard Worker    if grpc_only and proto_only:
67*cc02d7e2SAndroid Build Coastguard Worker        fail("A mutualy exclusive configuration is specified: grpc_only = True and proto_only = True")
68*cc02d7e2SAndroid Build Coastguard Worker
69*cc02d7e2SAndroid Build Coastguard Worker    extra_deps = []
70*cc02d7e2SAndroid Build Coastguard Worker    proto_targets = []
71*cc02d7e2SAndroid Build Coastguard Worker
72*cc02d7e2SAndroid Build Coastguard Worker    if not grpc_only:
73*cc02d7e2SAndroid Build Coastguard Worker        proto_target = "_" + name + "_only"
74*cc02d7e2SAndroid Build Coastguard Worker        cc_proto_target = name if proto_only else "_" + name + "_cc_proto"
75*cc02d7e2SAndroid Build Coastguard Worker
76*cc02d7e2SAndroid Build Coastguard Worker        proto_deps = ["_" + dep + "_only" for dep in deps if dep.find(":") == -1]
77*cc02d7e2SAndroid Build Coastguard Worker        proto_deps += [dep.split(":")[0] + ":" + "_" + dep.split(":")[1] + "_only" for dep in deps if dep.find(":") != -1 and dep.find("com_google_googleapis") == -1]
78*cc02d7e2SAndroid Build Coastguard Worker        proto_deps += [dep for dep in deps if dep.find("com_google_googleapis") != -1]
79*cc02d7e2SAndroid Build Coastguard Worker        if well_known_protos:
80*cc02d7e2SAndroid Build Coastguard Worker            proto_deps += well_known_proto_libs()
81*cc02d7e2SAndroid Build Coastguard Worker        proto_library(
82*cc02d7e2SAndroid Build Coastguard Worker            name = proto_target,
83*cc02d7e2SAndroid Build Coastguard Worker            srcs = srcs,
84*cc02d7e2SAndroid Build Coastguard Worker            deps = proto_deps,
85*cc02d7e2SAndroid Build Coastguard Worker            **kwargs
86*cc02d7e2SAndroid Build Coastguard Worker        )
87*cc02d7e2SAndroid Build Coastguard Worker
88*cc02d7e2SAndroid Build Coastguard Worker        native.cc_proto_library(
89*cc02d7e2SAndroid Build Coastguard Worker            name = cc_proto_target,
90*cc02d7e2SAndroid Build Coastguard Worker            deps = [":" + proto_target],
91*cc02d7e2SAndroid Build Coastguard Worker            **kwargs
92*cc02d7e2SAndroid Build Coastguard Worker        )
93*cc02d7e2SAndroid Build Coastguard Worker        extra_deps.append(":" + cc_proto_target)
94*cc02d7e2SAndroid Build Coastguard Worker        proto_targets.append(proto_target)
95*cc02d7e2SAndroid Build Coastguard Worker    else:
96*cc02d7e2SAndroid Build Coastguard Worker        if not srcs:
97*cc02d7e2SAndroid Build Coastguard Worker            fail("srcs cannot be empty", "srcs")
98*cc02d7e2SAndroid Build Coastguard Worker        proto_targets += srcs
99*cc02d7e2SAndroid Build Coastguard Worker
100*cc02d7e2SAndroid Build Coastguard Worker    if not proto_only:
101*cc02d7e2SAndroid Build Coastguard Worker        codegen_grpc_target = "_" + name + "_grpc_codegen"
102*cc02d7e2SAndroid Build Coastguard Worker        generate_cc(
103*cc02d7e2SAndroid Build Coastguard Worker            name = codegen_grpc_target,
104*cc02d7e2SAndroid Build Coastguard Worker            srcs = proto_targets,
105*cc02d7e2SAndroid Build Coastguard Worker            plugin = "@com_github_grpc_grpc//src/compiler:grpc_cpp_plugin",
106*cc02d7e2SAndroid Build Coastguard Worker            well_known_protos = well_known_protos,
107*cc02d7e2SAndroid Build Coastguard Worker            generate_mocks = generate_mocks,
108*cc02d7e2SAndroid Build Coastguard Worker            **kwargs
109*cc02d7e2SAndroid Build Coastguard Worker        )
110*cc02d7e2SAndroid Build Coastguard Worker
111*cc02d7e2SAndroid Build Coastguard Worker        native.cc_library(
112*cc02d7e2SAndroid Build Coastguard Worker            name = name,
113*cc02d7e2SAndroid Build Coastguard Worker            srcs = [":" + codegen_grpc_target],
114*cc02d7e2SAndroid Build Coastguard Worker            hdrs = [":" + codegen_grpc_target],
115*cc02d7e2SAndroid Build Coastguard Worker            deps = deps +
116*cc02d7e2SAndroid Build Coastguard Worker                   extra_deps +
117*cc02d7e2SAndroid Build Coastguard Worker                   ["@com_github_grpc_grpc//:grpc++_codegen_proto"],
118*cc02d7e2SAndroid Build Coastguard Worker            **kwargs
119*cc02d7e2SAndroid Build Coastguard Worker        )
120