forked from rules-proto-grpc/rules_proto_grpc
-
Notifications
You must be signed in to change notification settings - Fork 0
/
plugin.bzl
85 lines (79 loc) · 4.63 KB
/
plugin.bzl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
ProtoPluginInfo = provider(fields = {
"name": "The proto plugin name",
"options": "A list of options to pass to the compiler for this plugin",
"outputs": "Output filenames generated on a per-proto basis. Example: '{basename}_pb2.py",
"out": "Output filename generated on a per-plugin basis; to be used in the value for --NAME-out=OUT",
"output_directory": "Boolean flag that indicates that the plugin should just output a directory. Used for plugins that have no direct mapping from source file name to output name. Cannot be used in conjunction with outputs or out",
"tool": "The plugin binary. If absent, it is assumed the plugin is built-in to protoc itself and plugin_name will be used if available, otherwise the plugin name",
"tool_executable": "The plugin binary executable",
"use_built_in_shell_environment": "Whether the tool should use the built in shell environment or not",
"protoc_plugin_name": "The name used for the plugin binary on the protoc command line. Useful for targeting built-in plugins. Uses plugin name when not set",
"exclusions": "Exclusion filters to apply when generating outputs with this plugin. Used to prevent generating files that are included in the protobuf library, for example. Can exclude either by proto name prefix or by proto folder prefix",
"data": "Additional files required for running the plugin",
})
def _proto_plugin_impl(ctx):
# Handle back-compat for transitivity by converting to exclusions
exclusions = list(ctx.attr.exclusions)
if ctx.attr.transitivity:
for pattern, trans_type in ctx.attr.transitivity.items():
if trans_type == 'exclude':
exclusions.append(pattern)
else:
fail('Cannot convert transitivity filter with type "{}" to exclusion'.format(trans_type))
# Build ProtoPluginInfo provider
return [
ProtoPluginInfo(
name = ctx.attr.name,
options = ctx.attr.options,
outputs = ctx.attr.outputs,
out = ctx.attr.out,
output_directory = ctx.attr.output_directory,
tool = ctx.attr.tool,
tool_executable = ctx.executable.tool,
use_built_in_shell_environment = ctx.attr.use_built_in_shell_environment,
protoc_plugin_name = ctx.attr.protoc_plugin_name,
exclusions = exclusions,
data = ctx.files.data,
)
]
proto_plugin = rule(
implementation = _proto_plugin_impl,
attrs = {
"options": attr.string_list(
doc = "A list of options to pass to the compiler for this plugin",
),
"outputs": attr.string_list(
doc = "Output filenames generated on a per-proto basis. Example: '{basename}_pb2.py'",
),
"out": attr.string(
doc = "Output filename generated on a per-plugin basis; to be used in the value for --NAME-out=OUT",
),
"output_directory": attr.bool(
doc = "Boolean flag that indicates that the plugin should just output a directory. Used for plugins that have no direct mapping from source file name to output name. Cannot be used in conjunction with outputs or out",
default = False,
),
"tool": attr.label(
doc = "The plugin binary. If absent, it is assumed the plugin is built-in to protoc itself and builtin_plugin_name will be used if available, otherwise the plugin name",
cfg = "exec",
allow_files = True,
executable = True,
),
"use_built_in_shell_environment": attr.bool(
doc = "Whether the tool should use the built in shell environment or not",
default = False,
),
"protoc_plugin_name": attr.string(
doc = "The name used for the plugin binary on the protoc command line. Useful for targeting built-in plugins. Uses plugin name when not set",
),
"exclusions": attr.string_list(
doc = "Exclusion filters to apply when generating outputs with this plugin. Used to prevent generating files that are included in the protobuf library, for example. Can exclude either by proto name prefix or by proto folder prefix",
),
"transitivity": attr.string_dict(
doc = "(deprecated, use exclusions). Transitive filters to apply when the 'transitive' property is enabled. This string_dict can be used to exclude or explicitly include protos from the compilation list by using `exclude` or `include` respectively as the dict value",
),
"data": attr.label_list(
doc = "Additional files required for running the plugin",
allow_files = True,
),
},
)