规则
- cc_proto_library
 - java_lite_proto_library
 - java_proto_library
 - proto_library
 - py_proto_library
 - proto_lang_toolchain
 - proto_toolchain
 
cc_proto_library
查看规则来源cc_proto_library(name, deps, aspect_hints, compatible_with, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, features, package_metadata, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
cc_proto_library 从 .proto 文件生成 C++ 代码。
deps 必须指向 proto_library
 规则。
示例:
cc_library(
    name = "lib",
    deps = [":foo_cc_proto"],
)
cc_proto_library(
    name = "foo_cc_proto",
    deps = [":foo_proto"],
)
proto_library(
    name = "foo_proto",
)
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          deps
         | 
        
                     标签列表;默认值为  proto_library 规则的列表。
         | 
      
java_lite_proto_library
查看规则来源java_lite_proto_library(name, deps, aspect_hints, compatible_with, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, features, package_metadata, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
java_lite_proto_library 从 .proto 文件生成 Java 代码。
deps 必须指向 proto_library
 规则。
示例:
java_library(
    name = "lib",
    runtime_deps = [":foo"],
)
java_lite_proto_library(
    name = "foo",
    deps = [":bar"],
)
proto_library(
    name = "bar",
)
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          deps
         | 
        
                     标签列表;默认值为  proto_library 规则列表。
         | 
      
java_proto_library
查看规则来源java_proto_library(name, deps, aspect_hints, compatible_with, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, features, licenses, package_metadata, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
java_proto_library 从 .proto 文件生成 Java 代码。
deps 必须指向 proto_library
 规则。
示例:
java_library(
    name = "lib",
    runtime_deps = [":foo_java_proto"],
)
java_proto_library(
    name = "foo_java_proto",
    deps = [":foo_proto"],
)
proto_library(
    name = "foo_proto",
)
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          deps
         | 
        
                     标签列表;默认值为  proto_library 规则列表。
         | 
      
proto_library
查看规则来源proto_library(name, deps, srcs, data, allow_exports, aspect_hints, compatible_with, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, exports, features, import_prefix, licenses, option_deps, package_metadata, restricted_to, strip_import_prefix, tags, target_compatible_with, testonly, toolchains, visibility)
使用 proto_library 定义可从多种语言使用的 Protocol Buffers 库。proto_library 可以列在受支持规则的 deps 子句中,例如 java_proto_library。
在命令行中编译时,proto_library 会创建一个名为 foo-descriptor-set.proto.bin 的文件,该文件是规则源的消息的描述符集。该文件是序列化的 FileDescriptorSet,如需了解详情,请参阅 
https://developers.google.com/protocol-buffers/docs/techniques#self-description。
它仅包含 proto_library 规则直接提及的 .proto 文件的相关信息;传递描述符集的集合可通过 [ProtoInfo].transitive_descriptor_sets Starlark 提供程序获取。
请参阅 proto_info.bzl 中的文档。
建议的代码组织方式:
- 每个 
.proto文件中只能有一条proto_library规则。 - 名为 
foo.proto的文件将位于名为foo_proto的规则中,该规则位于同一软件包中。 - 封装名为 
foo_proto的proto_library的[language]_proto_library应命名为foo_[language]_proto,并位于同一软件包中。 
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          deps
         | 
        
                     标签列表;默认值为  proto_library 规则的列表。proto_library 只能依赖于其他 proto_library 目标。它可能不依赖于特定语言的库。
         | 
      
          srcs
         | 
        
                     标签列表;默认值为  .proto 和 .protodevel 文件列表。这通常是一个非空列表。srcs 为空的一种使用情形是别名库。这是一个 proto_library 规则,在 deps 中包含一个或多个其他 proto_library。此模式可用于导出具有持久名称的公共 API,例如。
         | 
      
          allow_exports
         | 
        
                     标签;默认值为   | 
      
          exports
         | 
        
                     标签列表;默认值为   | 
      
          import_prefix
         | 
        
                     字符串;默认值为  设置后,此规则的  系统会先移除   | 
      
          option_deps
         | 
        
                     标签列表;默认值为  proto_library 规则的列表。
proto_library 只能依赖于其他 proto_library 目标。它可能不依赖于特定语言的库。
         | 
      
          strip_import_prefix
         | 
        
                     字符串;默认值为  设置后,此规则的  如果它是相对路径(不以斜杠开头),则会被视为软件包相对路径。如果它是绝对路径,则会被理解为相对于代码库的路径。 
  | 
      
py_proto_library
查看规则来源py_proto_library(name, deps, aspect_hints, compatible_with, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, features, package_metadata, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          deps
         | 
        
                     标签列表;默认值为   | 
      
proto_lang_toolchain
查看规则来源proto_lang_toolchain(name, allowlist_different_package, aspect_hints, blacklisted_protos, command_line, compatible_with, denylisted_protos, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, features, mnemonic, output_files, package_metadata, plugin, plugin_format_flag, progress_message, protoc_minimal_do_not_use, restricted_to, runtime, tags, target_compatible_with, testonly, toolchain_type, toolchains, visibility)
如果使用 Bazel,请从 https://github.com/bazelbuild/rules_proto 加载规则。
指定 LANG_proto_library 规则(例如 java_proto_library) 应调用 proto 编译器。
某些 LANG_proto_library 规则允许使用命令行标志指定要使用的工具链;请参阅其文档。
通常情况下,您不应编写此类规则,除非您想调整 Java 编译器。
没有编译器。proto-compiler 取自我们附加到的 proto_library 规则。它作为命令行标志传递给 Blaze。有几项功能要求在 proto_library 规则本身上调用 proto-compiler。强制执行 LANG_proto_library 使用的编译器与 proto_library 使用的编译器相同,这很有好处。
示例
一个简单的示例:
proto_lang_toolchain(
    name = "javalite_toolchain",
    command_line = "--javalite_out=shared,immutable:$(OUT)",
    plugin = ":javalite_plugin",
    runtime = ":protobuf_lite",
)
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          allowlist_different_package
         | 
        
                     标签;默认值为   | 
      
          blacklisted_protos
         | 
        
                     标签列表;默认值为  denylisted_protos 的别名。将在未来版本中移除。
         | 
      
          command_line
         | 
        
                     字符串;必需 此值将传递给 proto 编译器以生成代码。仅包含特定于此代码生成器/插件的部分(例如,不包含 -I 参数)
  | 
      
          denylisted_protos
         | 
        
                     标签列表;默认值为  denylisted_protos 的 srcs 属性中的文件生成任何代码。
这适用于已链接到 proto 运行时(例如 any.proto)的 .proto 文件。
         | 
      
          mnemonic
         | 
        
                     字符串;默认值为   | 
      
          output_files
         | 
        
                     字符串;默认值为  command_line 中 $(OUT) 的格式,可以是单个文件的路径,也可以是多个文件的情况下的输出目录。
可能的值包括:“single”“multiple”。
         | 
      
          plugin
         | 
        
                     标签;默认值为  --plugin=protoc-gen-PLUGIN=<executable>.
         | 
      
          plugin_format_flag
         | 
        
                     字符串;默认值为  --plugin=protoc-gen-PLUGIN=<executable>.
         | 
      
          progress_message
         | 
        
                     字符串;默认值为   | 
      
          protoc_minimal_do_not_use
         | 
        
                     标签;默认值为   | 
      
          runtime
         | 
        
                     标签;默认值为   | 
      
          toolchain_type
         | 
        
                     标签;默认值为   | 
      
proto_toolchain
查看规则来源proto_toolchain(name, aspect_hints, command_line, compatible_with, deprecation, exec_compatible_with, exec_group_compatible_with, exec_properties, features, mnemonic, output_files, package_metadata, progress_message, proto_compiler, restricted_to, tags, target_compatible_with, testonly, toolchains, visibility)
参数
| 属性 | |
|---|---|
name | 
        
           名称;必需 相应目标的唯一名称。  | 
      
          command_line
         | 
        
                     字符串;默认值为   | 
      
          mnemonic
         | 
        
                     字符串;默认值为   | 
      
          output_files
         | 
        
                     字符串;默认值为   | 
      
          progress_message
         | 
        
                     字符串;默认值为   | 
      
          proto_compiler
         | 
        
                     标签;默认值为   |