为 Bazel 做贡献

报告问题 查看源代码 每夜 build · 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 代码搜索用户指南