Rules
- cc_proto_library
- java_lite_proto_library
- java_proto_library
- proto_library
- py_proto_library
- proto_lang_toolchain
- proto_toolchain
cc_proto_library
View rule sourceopen_in_newcc_proto_library generates C++ code from .proto files.
deps must point to proto_library\ rules.
Example:
Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of proto_library
rules to generate C++ code for.
java_lite_proto_library
View rule sourceopen_in_newjava_lite_proto_library generates Java code from .proto files.
deps must point to proto_library\ rules.
Example:
Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of proto_library
rules to generate Java code for.
java_proto_library
View rule sourceopen_in_newjava_proto_library generates Java code from .proto files.
deps must point to proto_library\ rules.
Example:
Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of proto_library
rules to generate Java code for.
proto_library
View rule sourceopen_in_newproto_library to define libraries of protocol buffers which
may be used from multiple languages. A proto_library may be listed
in the deps clause of supported rules, such as
java_proto_library.
When compiled on the command-line, a proto_library creates a file
named foo-descriptor-set.proto.bin, which is the descriptor set for
the messages the rule srcs. The file is a serialized
FileDescriptorSet, which is described in
https://developers.google.com/protocol-buffers/docs/techniques#self-description.
It only contains information about the .proto files directly
mentioned by a proto_library rule; the collection of transitive
descriptor sets is available through the
[ProtoInfo].transitive_descriptor_sets Starlark provider.
See documentation in proto_info.bzl.
Recommended code organization:
-
One
proto_libraryrule per.protofile. -
A file named
foo.protowill be in a rule namedfoo_proto, which is located in the same package. -
A
[language]_proto_librarythat wraps aproto_librarynamedfoo_protoshould be calledfoo_[language]_proto, and be located in the same package.
Arguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of other proto_library rules that the target depends upon.
A proto_library may only depend on other proto_library
targets. It may not depend on language-specific libraries.
srcs
List of labels; default is []
The list of .proto and .protodevel files that are
processed to create the target. This is usually a non empty list. One usecase
where srcs can be empty is an alias-library. This is a
proto_library rule having one or more other proto_library in deps.
This pattern can be used to e.g. export a public api under a persistent name.
allow_exports
Label; default is None
An optional allowlist that prevents proto library to be reexported or used in
lang_proto_library that is not in one of the listed packages.
exports
List of labels; default is []
List of proto_library targets that can be referenced via “import public” in the
proto source.
It’s an error if you use “import public” but do not list the corresponding library
in the exports attribute.
Note that you have list the library both in deps and exports since not all
lang_proto_library implementations have been changed yet.
import_prefix
String; default is ""
The prefix to add to the paths of the .proto files in this rule.
When set, the .proto source files in the srcs attribute of this rule are
accessible at is the value of this attribute prepended to their repository-relative path.
The prefix in the strip_import_prefix attribute is removed before this
prefix is added.
option_deps
List of labels; default is []
The list of other proto_library rules that the target depends upon for options only.
A proto_library may only depend on other proto_library
targets. It may not depend on language-specific libraries.
strip_import_prefix
String; default is "/"
The prefix to strip from the paths of the .proto files in this rule.
When set, .proto source files in the srcs attribute of this rule are
accessible at their path with this prefix cut off.
If it’s a relative path (not starting with a slash), it’s taken as a package-relative
one. If it’s an absolute one, it’s understood as a repository-relative path.
The prefix in the import_prefix attribute is added after this prefix is
stripped.
py_proto_library
View rule sourceopen_in_newArguments
Attributesname
Name; required
A unique name for this target.
deps
List of labels; default is []
The list of `proto_library` rules to generate Python libraries for.
Usually this is just the one target: the proto library of interest.
It can be any target providing `ProtoInfo`.
proto_lang_toolchain
View rule sourceopen_in_newjava_proto_library) should invoke the
proto-compiler.
Some LANG_proto_library rules allow specifying which toolchain to use using command-line flags;
consult their documentation.
Normally you should not write those kind of rules unless you want to
tune your Java compiler.
There’s no compiler. The proto-compiler is taken from the proto_library rule we attach to. It is
passed as a command-line flag to Blaze.
Several features require a proto-compiler to be invoked on the proto_library rule itself.
It’s beneficial to enforce the compiler that LANG_proto_library uses is the same as the one
proto_library does.
Examples
A simple example would be:Arguments
Attributesname
Name; required
A unique name for this target.
allowlist_different_package
Label; default is None
blacklisted_protos
List of labels; default is []
Deprecated. Alias for denylisted_protos. Will be removed in a future release.
command_line
String; required
This value will be passed to proto-compiler to generate the code. Only include the parts
specific to this code-generator/plugin (e.g., do not include -I parameters)
$(OUT)is LANG_proto_library-specific. The rules are expected to define how they interpret this variable. For Java, for example, $(OUT) will be replaced with the src-jar filename to create.
denylisted_protos
List of labels; default is []
No code will be generated for files in the srcs attribute of
denylisted_protos.
This is used for .proto files that are already linked into proto runtimes, such as
any.proto.
mnemonic
String; default is "GenProto"
This value will be set as the mnemonic on protoc action.
output_files
String; default is "legacy"
Controls how $(OUT) in command_line is formatted, either by
a path to a single file or output directory in case of multiple files.
Possible values are: “single”, “multiple”.
plugin
Label; default is None
If provided, will be made available to the action that calls the proto-compiler, and will be
passed to the proto-compiler:
--plugin=protoc-gen-PLUGIN=<executable>.``plugin_format_flag
String; default is ""
If provided, this value will be passed to proto-compiler to use the plugin.
The value must contain a single %s which is replaced with plugin executable.
--plugin=protoc-gen-PLUGIN=<executable>.``progress_message
String; default is "Generating proto_library %{label}"
This value will be set as the progress message on protoc action.
protoc_minimal_do_not_use
Label; default is None
runtime
Label; default is None
A language-specific library that the generated code is compiled against.
The exact behavior is LANG_proto_library-specific.
Java, for example, should compile against the runtime.
toolchain_type
Label; default is None
proto_toolchain
View rule sourceopen_in_newArguments
Attributesname
Name; required
A unique name for this target.
command_line
String; default is "--descriptor_set_out=%s"
mnemonic
String; default is "GenProtoDescriptorSet"
output_files
String; default is "single"
progress_message
String; default is "Generating Descriptor Set proto_library %{label}"
proto_compiler
Label; default is None