为 Bazel 做贡献

报告问题 查看源代码 每夜 build · 8.0 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

您可以通过多种方式为 Bazel 项目和生态系统提供帮助。

在使用 Bazel 的过程中,您可能会发现可以改进的地方。在以下情况下,您可以报告问题,为我们提供帮助:

  • Bazel 崩溃或您遇到的 bug 只能使用 bazel clean 解决
  • 文件不完整或不明确。您还可以使用您所查看页面右上角的“创建问题”链接,在该页面上报告问题。
  • 错误消息有待改进。

加入社区

您可以通过以下方式与 Bazel 社区互动:

  • Stack Overflow 上回答问题。
  • Slack 上帮助其他用户。
  • 改进文档或贡献示例
  • 分享您的经验或技巧,例如在博客或社交媒体上。

贡献代码

Bazel 是一个大型项目,更改 Bazel 源代码可能很困难。

您可以通过以下方式为 Bazel 生态系统做出贡献:

  • 提交拉取请求,帮助规则维护者。
  • 创建新规则并将其开源。
  • 为 Bazel 相关工具(例如迁移工具)做出贡献。
  • 改进了 Bazel 与其他 IDE 和工具的集成。

在进行更改之前,请创建 GitHub 问题或发送电子邮件至 bazel-discuss@

最有帮助的贡献是修复 bug 或添加功能(而不是样式、重构或“清理”更改)。您的更改应包含测试和文档,同时注意向后兼容性、可移植性以及对内存用量和性能的影响。

如需了解如何提交更改,请参阅补丁接受流程

Bazel 的代码说明

Bazel 拥有一个大型代码库,其中代码分布在多个位置。如需了解详情,请参阅代码库指南

Bazel 的结构如下:

  • 客户端代码位于 src/main/cpp 中,并提供命令行界面。
  • 协议缓冲区位于 src/main/protobuf 中。
  • 服务器代码位于 src/main/javasrc/test/java 中。
    • 核心代码,主要由 SkyFrame 和一些实用程序组成。
    • 内置规则位于 com.google.devtools.build.lib.rulescom.google.devtools.build.lib.bazel.rules 中。您可能需要先阅读编写规则的难点
  • Java 原生接口位于 src/main/native 中。
  • 编译 Bazel 部分的列表中介绍了各种语言支持工具。

搜索 Bazel 的源代码

如需快速搜索 Bazel 的源代码,请使用 Bazel 代码搜索。您可以浏览 Bazel 的代码库、分支和文件。您还可以查看历史记录、差异和归因信息。如需了解详情,请参阅 Bazel 代码搜索用户指南