このページでは、コントリビューターが Bazel コードベースに変更を提案して変更を加える方法について概説します。
- Bazel の貢献に関するポリシーを確認します。
- GitHub の問題を作成して、計画と設計について話し合います。動作を変更または追加するプルリクエストには、追跡用の対応する問題が必要です。
- 大幅な変更を提案する場合は、設計ドキュメントを作成します。
- 投稿者ライセンス契約に署名していることを確認します。
- 機能を実装する git コミットを準備します。テストを追加してドキュメントを更新してください。変更がユーザーに目に見える影響を与える場合は、リリースノートを追加してください。互換性のない変更の場合は、互換性を損なう変更をロールアウトするためのガイドをご覧ください。
- GitHub で pull リクエストを作成します。GitHub を初めて使用する場合は、プル リクエストについてをご覧ください。メインの Bazel リポジトリでブランチを作成する権限は制限されているため、リポジトリの独自のフォークに commit を push する必要があります。
- Bazel のメンテナンス担当者が 2 営業日以内(米国とドイツの祝日を除く)に審査担当者を割り当てます。その期間内に審査担当者が割り当てられない場合は、bazel-dev@googlegroups.com にメールを送信して審査担当者をリクエストできます。
- レビュアーと協力してコードレビューを完了します。変更ごとに新しい commit を作成し、push して pull リクエストに変更を加えます。審査に時間がかかりすぎる場合(審査担当者が応答しない場合など)は、bazel-dev@googlegroups.com にメールを送信してください。
審査が完了すると、Bazel のメンテナンス担当者がパッチを Google の内部バージョン管理システムに適用します。
これにより、内部の送信前チェックがトリガーされ、さらに変更が提案される場合があります。優先度を指定していない場合、変更を送信するメンテナンス担当者は、設計に影響しない「些細な」変更(リンティングなど)を追加します。より深い変更が必要な場合や、変更を直接適用する場合は、レビュー担当者とその希望を明確に審査コメントで伝える必要があります。
内部送信後、パッチは Git commit としてエクスポートされ、GitHub pull リクエストがクローズされます。最終的な変更はすべてあなたに帰属します。