Reglas
proto_lang_toolchain
proto_lang_toolchain(name, blacklisted_protos, command_line, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, features, licenses, mnemonic, plugin, plugin_format_flag, progress_message, proto_compiler, restricted_to, runtime, tags, target_compatible_with, testonly, visibility)
Obsoleta. Por favor https://github.com/bazelbuild/rules_proto.
Especifica cómo una regla LANG_proto_library (p.ej., java_proto_library) deben invocar el
proto-compiler.
Algunas reglas LANG_proto_library permiten especificar qué cadena de herramientas utilizar mediante marcas de la línea de comandos.
consulta su documentación.
Por lo general, no debes escribir ese tipo de reglas, a menos que desees ajustar tu compilador de Java.
No hay compilador. El proto-compiler se toma de la regla proto_library a la que adjuntamos. Sí
pasado como una marca de línea de comandos a Blaze.
Varias funciones requieren que se invoque un proto-compiler en la misma regla proto_library.
Es beneficioso hacer que el compilador que usa LANG_proto_library sea el mismo.
proto_library.
Ejemplos
Un ejemplo sencillo sería el siguiente:
proto_lang_toolchain(
name = "javalite_toolchain",
command_line = "--javalite_out=shared,immutable:$(OUT)",
plugin = ":javalite_plugin",
runtime = ":protobuf_lite",
)
Argumentos
| Atributos | |
|---|---|
name |
Un nombre único para este destino. |
blacklisted_protos
|
srcs de
blacklisted_protos
Se usa para archivos .proto que ya están vinculados en entornos de ejecución proto, como
any.proto
|
command_line
|
|
mnemonic
|
|
plugin
|
--plugin=protoc-gen-PLUGIN=
|
plugin_format_flag
|
--plugin=protoc-gen-PLUGIN=
|
progress_message
|
|
proto_compiler
|
|
runtime
|
|
proto_library
proto_library(name, deps, srcs, data, compatible_with, deprecation, distribs, exec_compatible_with, exec_properties, exports, features, import_prefix, licenses, restricted_to, strip_import_prefix, tags, target_compatible_with, testonly, visibility)
Obsoleta. Utiliza https://github.com/bazelbuild/rules_proto.
Usa proto_library para definir bibliotecas de búferes de protocolo
que pueden usarse en varios idiomas. Es posible que aparezca un proto_library
en la cláusula deps de las reglas admitidas, como java_proto_library.
Cuando se compila en la línea de comandos, un proto_library crea un archivo llamado
foo-descriptor-set.proto.bin, que es el conjunto de descriptores de la
envía la regla srcs. El archivo es un FileDescriptorSet serializado, que es
descritos en
https://developers.google.com/protocol-buffers/docs/techniques#self-description.
Solo contiene información sobre los archivos .proto mencionados directamente por un
Regla proto_library; la colección de conjuntos de descriptores transitivos está disponible mediante
el proveedor de Starlark [ProtoInfo].transitive_descriptor_sets.
Consulta la documentación en ProtoInfo.java.
Organización de código recomendada:
- Una regla
proto_librarypor archivo.proto. - Un archivo llamado
foo.protoestará en una regla llamadafoo_proto, que se encuentra en el mismo paquete. - Un
[language]_proto_libraryque une unproto_libraryllamado Se debe llamar afoo_protofoo_[language]_protoy deben ubicarse en el mismo paquete.
Argumentos
| Atributos | |
|---|---|
name |
Un nombre único para este destino. |
deps
|
proto_library de las que depende el destino.
Un proto_library solo puede depender de otros
proto_library objetivos.
Es posible que no dependa de las bibliotecas específicas de un lenguaje.
|
srcs
|
.proto y .protodevel que se
procesada para crear el destino. Por lo general, no está vacía. Un caso de uso
donde srcs puede estar vacío es una biblioteca de alias. Este es un
La regla proto_library tiene uno o más objetos proto_library en deps.
Este patrón puede usarse, p.ej., exportar una API pública con un nombre persistente.
|
exports
|
|
import_prefix
|
Cuando se establece, se asignan los archivos de origen .proto en el atributo Se quitó el prefijo del atributo |
strip_import_prefix
|
Cuando se establece, se asignan los archivos de origen .proto en el atributo Si es una ruta de acceso relativa (que no comienza con una barra diagonal), se toma como una ruta de acceso uno. Si es una absoluta, se entiende como una ruta de acceso relativa de repositorio. El prefijo del atributo |