blob: b9edfadb2bbda0a8be1c879be24d7c717259e8fc [file] [log] [blame]
Alexei Frolove19ebb82020-05-14 17:21:20 -07001# Copyright 2020 The Pigweed Authors
Alexei Frolov942adf02019-12-11 17:07:28 -08002#
3# Licensed under the Apache License, Version 2.0 (the "License"); you may not
4# use this file except in compliance with the License. You may obtain a copy of
5# the License at
6#
7# https://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
11# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
12# License for the specific language governing permissions and limitations under
13# the License.
14
Armando Montanezfb3d3fb2020-06-09 18:12:12 -070015# gn-format disable
16import("//build_overrides/pigweed.gni")
17
Alexei Frolov05d8ef22020-06-08 10:32:29 -070018import("$dir_pw_build/input_group.gni")
Alexei Frolov942adf02019-12-11 17:07:28 -080019import("$dir_pw_build/python_script.gni")
Alexei Frolovedd2f142020-06-09 19:11:27 -070020import("$dir_pw_build/target_types.gni")
Alexei Frolove4b6f6c2020-06-12 15:08:27 -070021import("nanopb.gni")
Alexei Frolov4c0428a2020-06-10 10:46:04 -070022declare_args() {
23 # Generators with which to compile protobuf code. These are used by the
24 # pw_proto_library template to determine which build targets to create.
25 #
26 # Supported generators:
Alexei Frolov79b7cb02020-07-06 13:51:43 -070027 # "pwpb", "nanopb", "nanopb_rpc", "go"
Alexei Frolov4c0428a2020-06-10 10:46:04 -070028 pw_protobuf_GENERATORS = [
29 "pwpb",
30 "go",
31 ]
32}
Alexei Frolov942adf02019-12-11 17:07:28 -080033
34# Python script that invokes protoc.
35_gen_script_path =
36 "$dir_pw_protobuf_compiler/py/pw_protobuf_compiler/generate_protos.py"
37
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -070038_forwarded_vars = [
39 "testonly",
40 "visibility",
41]
42
Alexei Frolovf39cd8b2020-04-13 17:59:20 -070043# Generates pw_protobuf C++ code for proto files, creating a source_set of the
44# generated files. This is internal and should not be used outside of this file.
45# Use pw_proto_library instead.
Alexei Frolov942adf02019-12-11 17:07:28 -080046#
47# Args:
48# protos: List of input .proto files.
Alexei Frolovf39cd8b2020-04-13 17:59:20 -070049template("_pw_pwpb_proto_library") {
Alexei Frolov942adf02019-12-11 17:07:28 -080050 _proto_gen_dir = "$root_gen_dir/protos"
Alexei Frolove19ebb82020-05-14 17:21:20 -070051 _module_path = get_path_info(".", "abspath")
52 _relative_proto_paths = rebase_path(invoker.protos, _module_path)
53
54 _outputs = []
55 foreach(_proto, _relative_proto_paths) {
56 _output = string_replace(_proto, ".proto", ".pwpb.h")
57 _outputs += [ "$_proto_gen_dir/$_output" ]
58 }
Alexei Frolov942adf02019-12-11 17:07:28 -080059
60 _gen_target = "${target_name}_gen"
61 pw_python_script(_gen_target) {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -070062 forward_variables_from(invoker, _forwarded_vars)
Alexei Frolov942adf02019-12-11 17:07:28 -080063 script = _gen_script_path
64 args = [
65 "--language",
66 "cc",
67 "--module-path",
Alexei Frolove19ebb82020-05-14 17:21:20 -070068 _module_path,
69 "--include-file",
70 invoker.include_file,
Alexei Frolov942adf02019-12-11 17:07:28 -080071 "--out-dir",
72 _proto_gen_dir,
73 ] + get_path_info(invoker.protos, "abspath")
74 inputs = invoker.protos
75 outputs = _outputs
Alexei Frolove19ebb82020-05-14 17:21:20 -070076 deps = invoker.deps
Alexei Frolovbbf164c2019-12-16 12:51:59 -080077 if (defined(invoker.protoc_deps)) {
Alexei Frolove19ebb82020-05-14 17:21:20 -070078 deps += invoker.protoc_deps
Alexei Frolovbbf164c2019-12-16 12:51:59 -080079 }
Alexei Frolov942adf02019-12-11 17:07:28 -080080 }
81
82 # For C++ proto files, the generated proto directory is added as an include
83 # path for the code. This requires using "all_dependent_configs" to force the
84 # include on any code that transitively depends on the generated protos.
Alexei Frolov942adf02019-12-11 17:07:28 -080085 _include_config_target = "${target_name}_includes"
86 config(_include_config_target) {
Alexei Frolove19ebb82020-05-14 17:21:20 -070087 include_dirs = [ "$_proto_gen_dir" ]
Alexei Frolov942adf02019-12-11 17:07:28 -080088 }
89
90 # Create a library with the generated source files.
Alexei Frolovedd2f142020-06-09 19:11:27 -070091 pw_source_set(target_name) {
Alexei Frolov942adf02019-12-11 17:07:28 -080092 all_dependent_configs = [ ":$_include_config_target" ]
Alexei Frolove19ebb82020-05-14 17:21:20 -070093 deps = [ ":$_gen_target" ]
94 public_deps = [ dir_pw_protobuf ] + invoker.gen_deps
Alexei Frolov942adf02019-12-11 17:07:28 -080095 sources = get_target_outputs(":$_gen_target")
Alexei Frolovf39cd8b2020-04-13 17:59:20 -070096 public = filter_include(sources, [ "*.pwpb.h" ])
97 }
98}
99
Alexei Frolov79b7cb02020-07-06 13:51:43 -0700100# Generates nanopb RPC code for proto files, creating a source_set of the
101# generated files. This is internal and should not be used outside of this file.
102# Use pw_proto_library instead.
103#
104# Args:
105# protos: List of input .proto files.
106#
107template("_pw_nanopb_rpc_proto_library") {
108 assert(defined(dir_pw_third_party_nanopb) && dir_pw_third_party_nanopb != "",
109 "\$dir_pw_third_party_nanopb must be set to compile nanopb protobufs")
110
111 _proto_gen_dir = "$root_gen_dir/protos"
112 _module_path = get_path_info(".", "abspath")
113 _relative_proto_paths = rebase_path(invoker.protos, _module_path)
114
115 _outputs = []
116 foreach(_proto, _relative_proto_paths) {
117 _output_h = string_replace(_proto, ".proto", "_rpc.pb.h")
118 _outputs += [ "$_proto_gen_dir/$_output_h" ]
119 }
120
121 # Create a target which runs protoc configured with the nanopb_rpc plugin to
122 # generate the C++ proto RPC headers.
123 _gen_target = "${target_name}_gen"
124 pw_python_script(_gen_target) {
125 forward_variables_from(invoker, _forwarded_vars)
126 script = _gen_script_path
127 args = [
128 "--language",
129 "nanopb_rpc",
130 "--module-path",
131 _module_path,
132 "--include-paths",
133 "$dir_pw_third_party_nanopb/generator/proto",
134 "--include-file",
135 invoker.include_file,
136 "--out-dir",
137 _proto_gen_dir,
138 ] + get_path_info(invoker.protos, "abspath")
139 inputs = invoker.protos
140 outputs = _outputs
141
142 deps = invoker.deps
143 if (defined(invoker.protoc_deps)) {
144 deps += invoker.protoc_deps
145 }
146 }
147
148 # For C++ proto files, the generated proto directory is added as an include
149 # path for the code. This requires using "all_dependent_configs" to force the
150 # include on any code that transitively depends on the generated protos.
151 _include_root = rebase_path(get_path_info(".", "abspath"), "//")
152 _include_config_target = "${target_name}_includes"
153 config(_include_config_target) {
154 include_dirs = [
155 "$_proto_gen_dir",
156 "$_proto_gen_dir/$_include_root",
157 ]
158 }
159
160 # Create a library with the generated source files.
161 pw_source_set(target_name) {
162 all_dependent_configs = [ ":$_include_config_target" ]
163 deps = [ ":$_gen_target" ]
164 public_deps = [
165 dir_pw_third_party_nanopb,
166 "$dir_pw_rpc:nanopb_server",
167 ] + invoker.gen_deps
168 public = get_target_outputs(":$_gen_target")
169 }
170}
171
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700172# Generates nanopb code for proto files, creating a source_set of the generated
173# files. This is internal and should not be used outside of this file. Use
174# pw_proto_library instead.
175#
176# Args:
177# protos: List of input .proto files.
178template("_pw_nanopb_proto_library") {
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700179 assert(defined(dir_pw_third_party_nanopb) && dir_pw_third_party_nanopb != "",
180 "\$dir_pw_third_party_nanopb must be set to compile nanopb protobufs")
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700181
182 _proto_gen_dir = "$root_gen_dir/protos"
Alexei Frolove19ebb82020-05-14 17:21:20 -0700183 _module_path = get_path_info(".", "abspath")
184 _relative_proto_paths = rebase_path(invoker.protos, _module_path)
185
186 _outputs = []
187 foreach(_proto, _relative_proto_paths) {
188 _output_h = string_replace(_proto, ".proto", ".pb.h")
189 _output_c = string_replace(_proto, ".proto", ".pb.c")
190 _outputs += [
191 "$_proto_gen_dir/$_output_h",
192 "$_proto_gen_dir/$_output_c",
193 ]
194 }
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700195
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700196 _nanopb_plugin = "$dir_pw_third_party_nanopb/generator/protoc-gen-nanopb"
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700197 if (host_os == "win") {
198 _nanopb_plugin += ".bat"
199 }
200
201 # Create a target which runs protoc configured with the nanopb plugin to
202 # generate the C proto sources.
203 _gen_target = "${target_name}_gen"
204 pw_python_script(_gen_target) {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -0700205 forward_variables_from(invoker, _forwarded_vars)
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700206 script = _gen_script_path
207 args = [
208 "--language",
209 "nanopb",
210 "--module-path",
Alexei Frolove19ebb82020-05-14 17:21:20 -0700211 _module_path,
Alexei Frolovac5b6742020-05-01 13:28:14 -0700212 "--include-paths",
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700213 "$dir_pw_third_party_nanopb/generator/proto",
Alexei Frolove19ebb82020-05-14 17:21:20 -0700214 "--include-file",
215 invoker.include_file,
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700216 "--out-dir",
217 _proto_gen_dir,
218 "--custom-plugin",
219 get_path_info(_nanopb_plugin, "abspath"),
220 ] + get_path_info(invoker.protos, "abspath")
221 inputs = invoker.protos
222 outputs = _outputs
223
Alexei Frolove19ebb82020-05-14 17:21:20 -0700224 deps = invoker.deps
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700225 if (defined(invoker.protoc_deps)) {
Alexei Frolove19ebb82020-05-14 17:21:20 -0700226 deps += invoker.protoc_deps
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700227 }
228 }
229
230 # For C++ proto files, the generated proto directory is added as an include
231 # path for the code. This requires using "all_dependent_configs" to force the
232 # include on any code that transitively depends on the generated protos.
233 _include_root = rebase_path(get_path_info(".", "abspath"), "//")
234 _include_config_target = "${target_name}_includes"
235 config(_include_config_target) {
236 include_dirs = [
237 "$_proto_gen_dir",
238 "$_proto_gen_dir/$_include_root",
239 ]
240 }
241
242 # Create a library with the generated source files.
Alexei Frolovedd2f142020-06-09 19:11:27 -0700243 pw_source_set(target_name) {
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700244 all_dependent_configs = [ ":$_include_config_target" ]
Alexei Frolove19ebb82020-05-14 17:21:20 -0700245 deps = [ ":$_gen_target" ]
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700246 public_deps = [ dir_pw_third_party_nanopb ] + invoker.gen_deps
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700247 sources = get_target_outputs(":$_gen_target")
248 public = filter_include(sources, [ "*.pb.h" ])
Alexei Frolov942adf02019-12-11 17:07:28 -0800249 }
250}
251
Alexei Frolovdef14712019-12-23 13:03:32 -0800252# Generates Go code for proto files, listing the proto output directory in the
253# metadata variable GOPATH. Internal use only.
254#
255# Args:
256# protos: List of input .proto files.
257template("_pw_go_proto_library") {
258 _proto_gopath = "$root_gen_dir/go"
259 _proto_gen_dir = "$_proto_gopath/src"
260 _rebased_gopath = rebase_path(_proto_gopath)
261
262 pw_python_script(target_name) {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -0700263 forward_variables_from(invoker, _forwarded_vars)
Alexei Frolovdef14712019-12-23 13:03:32 -0800264 metadata = {
265 gopath = [ "GOPATH+=$_rebased_gopath" ]
Alexei Frolovc15a9882019-12-23 14:29:02 -0800266 external_deps = [
267 "github.com/golang/protobuf/proto",
268 "google.golang.org/grpc",
269 ]
Alexei Frolovdef14712019-12-23 13:03:32 -0800270 }
271 script = _gen_script_path
272 args = [
273 "--language",
274 "go",
275 "--module-path",
276 "//",
Alexei Frolove19ebb82020-05-14 17:21:20 -0700277 "--include-file",
278 invoker.include_file,
Alexei Frolovdef14712019-12-23 13:03:32 -0800279 "--out-dir",
280 _proto_gen_dir,
281 ] + get_path_info(invoker.protos, "abspath")
282 inputs = invoker.protos
Alexei Frolove19ebb82020-05-14 17:21:20 -0700283 deps = invoker.deps + invoker.gen_deps
Alexei Frolovdef14712019-12-23 13:03:32 -0800284 stamp = true
285 }
286}
287
Alexei Frolov942adf02019-12-11 17:07:28 -0800288# Generates protobuf code from .proto definitions for various languages.
289#
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700290# The generators to use are defined in the pw_protobuf_GENERATORS build
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700291# variable. Each listed generator creates a generated code target called
Alexei Frolov942adf02019-12-11 17:07:28 -0800292#
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700293# <target_name>_<generator>
Alexei Frolov942adf02019-12-11 17:07:28 -0800294#
295# For example, with the following definitions:
296#
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700297# pw_protobuf_GENERATORS = [ "pwpb", "py" ]
Alexei Frolov942adf02019-12-11 17:07:28 -0800298#
299# pw_proto_library("my_protos") {
300# sources = [ "foo.proto" ]
301# }
302#
303# Two build targets will be created for the declared "my_protos" target.
304#
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700305# "my_protos_pwpb" <-- C++ source_set containing generated proto code
306# "my_protos_py" <-- Python module containing generated proto code
Alexei Frolov942adf02019-12-11 17:07:28 -0800307#
308# Args:
309# sources: List of input .proto files.
310# deps: List of other pw_proto_library dependencies.
Alexei Frolov05d8ef22020-06-08 10:32:29 -0700311# inputs: Other files on which the protos depend (e.g. nanopb .options files).
Alexei Frolov942adf02019-12-11 17:07:28 -0800312template("pw_proto_library") {
313 assert(defined(invoker.sources) && invoker.sources != [],
Wyatt Heplerb4b73a62020-05-27 15:17:27 -0700314 "pw_proto_library requires .proto source files")
Alexei Frolov942adf02019-12-11 17:07:28 -0800315
Alexei Frolove19ebb82020-05-14 17:21:20 -0700316 # For each proto target, create a file which collects the base directories of
317 # all of its dependencies to list as include paths to protoc.
318 _include_metadata_target = "${target_name}_include_paths"
319 _include_metadata_file = "${target_gen_dir}/${target_name}_includes.txt"
320 generated_file(_include_metadata_target) {
Alexei Frolov942adf02019-12-11 17:07:28 -0800321 if (defined(invoker.deps)) {
Alexei Frolove19ebb82020-05-14 17:21:20 -0700322 # Collect metadata from the include path files of each dependency.
323 deps = process_file_template(invoker.deps, "{{source}}_include_paths")
Alexei Frolov942adf02019-12-11 17:07:28 -0800324 } else {
Alexei Frolove19ebb82020-05-14 17:21:20 -0700325 deps = []
Alexei Frolov942adf02019-12-11 17:07:28 -0800326 }
Alexei Frolove19ebb82020-05-14 17:21:20 -0700327 data_keys = [ "protoc_includes" ]
328 outputs = [ _include_metadata_file ]
329
330 # Indicate this library's base directory for its dependents.
331 metadata = {
Alexei Frolovf79d2272020-06-18 13:37:38 -0700332 protoc_includes = [ rebase_path(".") ]
Alexei Frolove19ebb82020-05-14 17:21:20 -0700333 }
334 }
335
Alexei Frolov05d8ef22020-06-08 10:32:29 -0700336 _deps = [ ":$_include_metadata_target" ]
337
338 if (defined(invoker.inputs)) {
339 # Toss any additional inputs into an input group dependency.
340 _input_target_name = "${target_name}_inputs"
341 pw_input_group(_input_target_name) {
342 inputs = invoker.inputs
343 }
344 _deps += [ ":$_input_target_name" ]
345 }
346
Alexei Frolov79b7cb02020-07-06 13:51:43 -0700347 # If the nanopb_rpc generator is selected, make sure that nanopb is also
348 # selected.
349 has_nanopb_rpc = pw_protobuf_GENERATORS + [ "nanopb_rpc" ] -
350 [ "nanopb_rpc" ] != pw_protobuf_GENERATORS
351 if (has_nanopb_rpc) {
352 _generators =
353 pw_protobuf_GENERATORS + [ "nanopb" ] - [ "nanopb" ] + [ "nanopb" ]
354 } else {
355 _generators = pw_protobuf_GENERATORS
356 }
357
358 foreach(_gen, _generators) {
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700359 _lang_target = "${target_name}_${_gen}"
Alexei Frolov8185c822020-06-12 10:45:04 -0700360 _gen_deps = []
361 if (defined(invoker.deps)) {
362 _gen_deps = process_file_template(invoker.deps, "{{source}}_${_gen}")
Alexei Frolov79b7cb02020-07-06 13:51:43 -0700363
364 if (_gen == "nanopb_rpc") {
365 # Generated RPC code also depends on the core generated protos.
366 _gen_deps += process_file_template(invoker.deps, "{{source}}_nanopb")
367 }
Alexei Frolov8185c822020-06-12 10:45:04 -0700368 }
Alexei Frolov942adf02019-12-11 17:07:28 -0800369
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700370 if (_gen == "pwpb") {
371 _pw_pwpb_proto_library(_lang_target) {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -0700372 forward_variables_from(invoker, _forwarded_vars)
Alexei Frolov942adf02019-12-11 17:07:28 -0800373 protos = invoker.sources
Alexei Frolov05d8ef22020-06-08 10:32:29 -0700374 deps = _deps
Alexei Frolove19ebb82020-05-14 17:21:20 -0700375 include_file = _include_metadata_file
376 gen_deps = _gen_deps
Alexei Frolovbbf164c2019-12-16 12:51:59 -0800377
378 # List the pw_protobuf plugin's files as a dependency to recompile
379 # generated code if they are modified.
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700380 protoc_deps = [ "$dir_pw_protobuf:codegen_protoc_plugin" ]
Alexei Frolov942adf02019-12-11 17:07:28 -0800381 }
Alexei Frolov79b7cb02020-07-06 13:51:43 -0700382 } else if (_gen == "nanopb_rpc") {
383 _pw_nanopb_rpc_proto_library(_lang_target) {
384 forward_variables_from(invoker, _forwarded_vars)
385 protos = invoker.sources
386 deps = _deps
387 include_file = _include_metadata_file
388 gen_deps = _gen_deps
389
390 # List the pw_protobuf plugin's files as a dependency to recompile
391 # generated code if they are modified.
392 protoc_deps = [ "$dir_pw_rpc:nanopb_protoc_plugin" ]
393 }
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700394 } else if (_gen == "nanopb") {
395 _pw_nanopb_proto_library(_lang_target) {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -0700396 forward_variables_from(invoker, _forwarded_vars)
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700397 protos = invoker.sources
Alexei Frolov05d8ef22020-06-08 10:32:29 -0700398 deps = _deps
Alexei Frolove19ebb82020-05-14 17:21:20 -0700399 include_file = _include_metadata_file
400 gen_deps = _gen_deps
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700401 }
402 } else if (_gen == "go") {
Alexei Frolovdef14712019-12-23 13:03:32 -0800403 _pw_go_proto_library(_lang_target) {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -0700404 forward_variables_from(invoker, _forwarded_vars)
Alexei Frolovdef14712019-12-23 13:03:32 -0800405 protos = invoker.sources
Alexei Frolov05d8ef22020-06-08 10:32:29 -0700406 deps = _deps
Alexei Frolove19ebb82020-05-14 17:21:20 -0700407 include_file = _include_metadata_file
408 gen_deps = _gen_deps
Alexei Frolovdef14712019-12-23 13:03:32 -0800409 }
Alexei Frolov942adf02019-12-11 17:07:28 -0800410 } else {
411 assert(false,
412 string_join(
413 " ",
414 [
Wyatt Heplerb4b73a62020-05-27 15:17:27 -0700415 "pw_proto_library doesn't know how to generate code for",
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700416 "generator '$_gen'. Please add support if you require it.",
Alexei Frolov942adf02019-12-11 17:07:28 -0800417 ]))
418 }
419 }
420
Wyatt Heplerb4b73a62020-05-27 15:17:27 -0700421 # All supported pw_protobuf generators.
422 _protobuf_generators = [
423 "pwpb",
424 "nanopb",
Alexei Frolov79b7cb02020-07-06 13:51:43 -0700425 "nanopb_rpc",
Wyatt Heplerb4b73a62020-05-27 15:17:27 -0700426 "go",
427 ]
428
429 # Create stub versions of the proto library for other protobuf generators.
Alexei Frolov79b7cb02020-07-06 13:51:43 -0700430 foreach(_gen, _protobuf_generators - _generators) {
Wyatt Heplerb4b73a62020-05-27 15:17:27 -0700431 pw_python_script("${target_name}_${_gen}") {
Wyatt Heplere0c4fdc2020-05-29 17:26:19 -0700432 forward_variables_from(invoker, _forwarded_vars)
Wyatt Heplerb4b73a62020-05-27 15:17:27 -0700433 script = string_join("/",
434 [
435 dir_pw_protobuf_compiler,
436 "py",
437 "pw_protobuf_compiler",
438 "generator_not_selected.py",
439 ])
440 args = [
441 "--library",
442 "${target_name}_${_gen}",
443 "--generator",
444 _gen,
445 ]
446 inputs = invoker.sources
447 stamp = true
448 }
449 }
450
Alexei Frolov942adf02019-12-11 17:07:28 -0800451 # If the user attempts to use the target directly instead of one of the
Alexei Frolovf39cd8b2020-04-13 17:59:20 -0700452 # generator targets, run a script which prints a nice error message.
Alexei Frolov942adf02019-12-11 17:07:28 -0800453 pw_python_script(target_name) {
454 script = string_join("/",
455 [
456 dir_pw_protobuf_compiler,
457 "py",
458 "pw_protobuf_compiler",
459 "proto_target_invalid.py",
460 ])
461 args = [
462 "--target",
463 target_name,
464 "--dir",
465 get_path_info(".", "abspath"),
466 "--root",
467 "//",
Alexei Frolov4c0428a2020-06-10 10:46:04 -0700468 ] + pw_protobuf_GENERATORS
Alexei Frolov942adf02019-12-11 17:07:28 -0800469 stamp = true
470 }
471}