MODULE.bazel ファイルで使用できるメソッド。
メンバー
- archive_override
- bazel_dep
- git_override
- 含める
- inject_repo
- local_path_override
- モジュール
- multiple_version_override
- override_repo
- register_execution_platforms
- register_toolchains
- single_version_override
- use_extension
- use_repo
- use_repo_rule
archive_override
None
archive_override(module_name, urls, integrity='', strip_prefix='', patches=[], patch_cmds=[], patch_strip=0)
この依存関係は、レジストリではなく、特定の場所にあるアーカイブ ファイル(zip、gzip など)から取得されることを指定します。このディレクティブはルート モジュールでのみ有効になります。つまり、あるモジュールが他のユーザーによって依存関係として使用されている場合、そのモジュール自体のオーバーライドは無視されます。
パラメータ
パラメータ | 説明 |
---|---|
module_name
|
string;
必須 このオーバーライドを適用する Bazel モジュール依存関係の名前。 |
urls
|
string;文字列の Iterable。
必須 アーカイブの URLhttp(s):// または file:// の URL を使用できます。 |
integrity
|
string;
デフォルトは '' です アーカイブ ファイルで想定されるチェックサム(サブリソースの整合性形式)。 |
strip_prefix
|
string;
デフォルトは '' です 抽出されたファイルから削除するディレクトリ接頭辞。 |
patches
|
文字列の反復可能オブジェクト。デフォルトは [] 。このモジュールに適用するパッチファイルを指すラベルのリスト。パッチファイルは、最上位プロジェクトのソースツリーに存在している必要があります。リスト順に適用されます。 |
patch_cmds
|
文字列のイテラブル。
デフォルトは [] です パッチ適用後に Linux/macOS で適用される Bash コマンドの順序。 |
patch_strip
|
int;
デフォルトは 0 です Unix パッチの --strip 引数と同じです。 |
bazel_dep
None
bazel_dep(name, version='', max_compatibility_level=-1, repo_name='', dev_dependency=False)
別の Bazel モジュールに対する直接的な依存関係を宣言します。
パラメータ
パラメータ | 説明 |
---|---|
name
|
string;
必須 直接的な依存関係として追加するモジュールの名前。 |
version
|
string;
デフォルトは '' です 直接的な依存関係として追加するモジュールのバージョン。 |
max_compatibility_level
|
int;
デフォルトは -1 です 直接依存関係として追加されるモジュールでサポートされる最大 compatibility_level 。モジュールのバージョンは、サポートされている最小の compatibility_level を意味し、この属性が指定されていない場合は、最大値が暗黙的に指定されます。
|
repo_name
|
string;
デフォルトは '' です この依存関係を表す外部リポジトリの名前。デフォルトでは、モジュールの名前になります。 |
dev_dependency
|
bool。デフォルトは False 。true の場合、現在のモジュールがルート モジュールでない場合、または `--ignore_dev_dependency` が有効になっている場合、この依存関係は無視されます。 |
git_override
None
git_override(module_name, remote, commit='', patches=[], patch_cmds=[], patch_strip=0, init_submodules=False, strip_prefix='')
依存関係が Git リポジトリの特定の commit から得られるように指定します。このディレクティブはルート モジュールでのみ有効になります。つまり、モジュールが他のモジュールによって依存関係として使用されている場合、そのモジュールのオーバーライドは無視されます。
パラメータ
パラメータ | 説明 |
---|---|
module_name
|
string;
必須 このオーバーライドを適用する Bazel モジュール依存関係の名前。 |
remote
|
string;
必須 Git リポジトリの URL。 |
commit
|
文字列。デフォルトは '' 。チェックアウトするコミット。 |
patches
|
文字列のイテラブル。
デフォルトは [] です このモジュールに適用するパッチファイルを指すラベルのリスト。パッチファイルは、最上位プロジェクトのソースツリーに存在している必要があります。リスト順に適用されます。 |
patch_cmds
|
文字列のイテラブル。
デフォルトは [] です パッチ適用後に Linux/macOS で適用される Bash コマンドの順序。 |
patch_strip
|
int。デフォルトは 0 。Unix パッチの --strip 引数と同じです。 |
init_submodules
|
bool;
デフォルトは False です フェッチされたリポジトリ内の git サブモジュールを再帰的に初期化するかどうか。 |
strip_prefix
|
string;
デフォルトは '' です 抽出されたファイルから削除するディレクトリ接頭辞。これは Git リポジトリのサブディレクトリをターゲットにするために使用できます。サブディレクトリには、この `git_override` に渡される `module_name` 引数と同じモジュール名の独自の `MODULE.bazel` ファイルが必要です。 |
含む
None
include(label)
別の MODULE.bazel のようなファイルの内容が含まれます。実質的には、include()
はインクルードされたファイルが include()
呼び出しの場所にテキストで配置されているかのように動作します。ただし、変数バインディング(use_extension
に使用されるものなど)は、インクルードされているファイルやインクルードするファイルではなく、それらが含まれるファイルにのみ表示されます。include()
はルート モジュールでのみ使用できます。bazel_dep
の MODULE ファイルで include()
を使用するとエラーになります。
メイン リポジトリ内のファイルのみを含めることができます。
include()
を使用すると、ルート モジュール ファイルを複数の部分に分割して、巨大な MODULE.bazel ファイルを回避したり、個々のセマンティック セグメントのアクセス制御を管理したりできます。
パラメータ
パラメータ | 説明 |
---|---|
label
|
string;
必須 含めるファイルを指すラベル。ラベルはメイン リポジトリ内のファイルを参照する必要があります。つまり、必ずダブル スラッシュ( // )で始める必要があります。
|
inject_repo
None
inject_repo(extension_proxy, *args, **kwargs)
指定されたモジュール拡張機能に 1 つ以上の新しいリポジトリを挿入します。
現在のモジュールがルート モジュールでない場合、または「--ignore_dev_dependency」でない場合は無視されます。
有効になります。
既存のリポジトリをオーバーライドするには、代わりに override_repo
を使用します。
パラメータ
パラメータ | 説明 |
---|---|
extension_proxy
|
module_extension_proxy;
必須use_extension 呼び出しによって返されるモジュール拡張プロキシ オブジェクト。
|
args
|
必須 現在のモジュールから参照可能なリポジトリで、 同じ名前で作成します。 |
kwargs
|
必須 拡張機能に挿入する新しいリポジトリ。値は、 現在のモジュールのスコープにあるすべてのリポジトリを その拡張機能の下部に表示されます |
local_path_override
None
local_path_override(module_name, path)
依存関係がローカル ディスクの特定のディレクトリから取得されるように指定します。このディレクティブはルート モジュールでのみ有効になります。つまり、あるモジュールが他のユーザーによって依存関係として使用されている場合、そのモジュール自体のオーバーライドは無視されます。
パラメータ
パラメータ | 説明 |
---|---|
module_name
|
string;
必須 このオーバーライドを適用する Bazel モジュール依存関係の名前。 |
path
|
string;
必須 このモジュールが配置されているディレクトリのパス。 |
モジュール
None
module(name='', version='', compatibility_level=0, repo_name='', bazel_compatibility=[])
現在の Bazel リポジトリで表される Bazel モジュールの特定のプロパティを宣言します。これらのプロパティは、モジュールの重要なメタデータ(名前やバージョンなど)か、現在のモジュールとその依存関係の動作に影響します。これは 1 回だけ呼び出す必要があります。呼び出す場合は、MODULE.bazel ファイル内の最初のディレクティブにする必要があります。このモジュールは、このモジュールがルート モジュールである場合にのみ省略できます(別のモジュールに依存しない場合など)。
パラメータ
パラメータ | 説明 |
---|---|
name
|
文字列。デフォルトは '' です。モジュールの名前。このモジュールがルート モジュールである場合にのみ省略できます(別のモジュールに依存しない場合と同様です)。有効なモジュール名は、1)小文字(a~z)、数字(0~9)、ピリオド(.)、ハイフン(-)、アンダースコア(_)のみを含める必要があります。2)先頭は小文字にする必要があります。3)末尾は小文字または数字にする必要があります。 |
version
|
string;
デフォルトは '' です モジュールのバージョン。このモジュールがルート モジュールである場合にのみ省略できます(別のモジュールに依存しない場合と同様です)。バージョンは緩和された SemVer 形式にする必要があります。詳細については、ドキュメントをご覧ください。 |
compatibility_level
|
int;
デフォルトは 0 です モジュールの互換性レベル互換性のない大きな変更が行われるたびに変更する必要があります。これは基本的に「メジャー バージョン」です。SemVer で表します。ただし、バージョン文字列自体に埋め込まれるのではなく、個別のフィールドとして存在します。互換性レベルが異なるモジュールは、名前の異なるモジュールであるかのようにバージョン解決に関与しますが、最終的な依存関係グラフに、名前が同じで互換性レベルが異なる複数のモジュールを含めることはできません( multiple_version_override が有効になっている場合を除く)。詳しくは、ドキュメントをご覧ください。 |
repo_name
|
string;
デフォルトは '' です モジュール自体から見える、このモジュールを表すリポジトリの名前。デフォルトでは、リポジトリの名前はモジュールの名前です。これを指定すると、モジュール名とは異なるリポジトリ名を使用しているプロジェクトの移行が容易になります。 |
bazel_compatibility
|
文字列のイテラブル。
デフォルトは [] です ユーザーがこのモジュールと互換性のある Bazel バージョンを宣言できる bazel バージョンのリスト。依存関係の解決には影響しませんが、bzlmod はこの情報を使用して、現在の Bazel バージョンに互換性があるかどうかを確認します。この値の形式は、カンマで区切った一連の制約値の文字列です。3 つの制約がサポートされています。<=X.X.X: Bazel バージョンは X.X.X 以下である必要があります。新しいバージョンに既知の互換性のない変更がある場合に使用します。>=X.X.X: Bazel のバージョンは X.X.X 以上である必要があります。X.X.X 以降でのみ利用可能な機能に依存している場合に使用します。-X.X.X: Bazel バージョン X.X.X は互換性がありません。障害となる X.X.X のバグが新しいバージョンで修正された場合に使用します。 |
multiple_version_override
None
multiple_version_override(module_name, versions, registry='')
依存関係は引き続きレジストリから取得されるべきだが、その依存関係の複数のバージョンの共存を許可することを指定します。詳しくは、こちらのドキュメントをご覧ください。このディレクティブはルート モジュールでのみ有効になります。つまり、あるモジュールが他のユーザーによって依存関係として使用されている場合、そのモジュール自体のオーバーライドは無視されます。
パラメータ
パラメータ | 説明 |
---|---|
module_name
|
string;
必須 このオーバーライドを適用する Bazel モジュール依存関係の名前。 |
versions
|
文字列のイテレーター。必須 共存を許可するバージョンを明示的に指定します。これらのバージョンは、依存関係グラフの事前選択にすでに存在している必要があります。このモジュールの依存関係は、同じ互換性レベルで許可されているバージョンに最も近いバージョンに「アップグレード」されます。同じ互換性レベルで許可されているバージョンよりもバージョンが大きい依存関係はエラーになります。 |
registry
|
文字列。デフォルトは '' 。このモジュールのレジストリをオーバーライドします。レジストリのデフォルト リストからこのモジュールを検索するのではなく、指定されたレジストリを使用する必要があります。 |
override_repo
None
override_repo(extension_proxy, *args, **kwargs)
指定されたモジュール拡張機能によって定義された 1 つ以上のリポジトリを、指定されたリポジトリでオーバーライドします
現在のモジュールから参照できます。現在のモジュールがルートでない場合は無視されます。
「--ignore_dev_dependency」が有効になっていることを確認します。
代わりに inject_repo
を使用して、新しいリポジトリを追加します。
パラメータ
パラメータ | 説明 |
---|---|
extension_proxy
|
module_extension_proxy;
必須use_extension 呼び出しによって返されるモジュール拡張プロキシ オブジェクト。
|
args
|
必須 同じリポジトリでオーバーライドする必要がある拡張機能のリポジトリ 名前で識別されます。 |
kwargs
|
必須 拡張機能によって生成されたリポジトリに適用されるオーバーライド。ここで、 現在のモジュールのスコープ内にあるリポジトリの名前で、 拡張機能でオーバーライドするリポジトリの名前。 |
register_execution_platforms
None
register_execution_platforms(dev_dependency=False, *platform_labels)
このモジュールが選択されたときに登録する、定義済みの実行プラットフォームを指定します。絶対的なターゲット パターン(@
または //
で始まるパターン)にする必要があります。詳細については、ツールチェーンの解決をご覧ください。複数のターゲットに展開されるパターン(:all
など)は、名前の辞書順で登録されます。
パラメータ
パラメータ | 説明 |
---|---|
dev_dependency
|
bool。デフォルトは False 。true の場合、現在のモジュールがルート モジュールでない場合や `--ignore_dev_dependency` が有効になっている場合、実行プラットフォームは登録されません。 |
platform_labels
|
文字列のシーケンス。必須 登録するターゲット パターン。 |
register_toolchains
None
register_toolchains(dev_dependency=False, *toolchain_labels)
このモジュールを選択したときに登録する、すでに定義されているツールチェーンを指定します。絶対的なターゲット パターン(@
または //
で始まるパターン)にする必要があります。詳細については、ツールチェーンの解決をご覧ください。:all
など、複数のターゲットに展開されるパターンは、ターゲット名(ツールチェーン実装の名前ではない)で辞書順に登録されます。
パラメータ
パラメータ | 説明 |
---|---|
dev_dependency
|
bool;
デフォルトは False です true の場合、現在のモジュールがルート モジュールでない場合、または「--ignore_dev_dependency」が有効になっている場合、ツールチェーンは登録されません。 |
toolchain_labels
|
文字列のシーケンス。
必須 登録するターゲット パターン。 |
single_version_override
None
single_version_override(module_name, version='', registry='', patches=[], patch_cmds=[], patch_strip=0)
依存関係は引き続きレジストリから取得されるものの、そのバージョンを固定するか、レジストリがオーバーライドされるか、適用されるパッチのリストを指定するように指定します。このディレクティブはルート モジュールでのみ有効になります。つまり、あるモジュールが他のユーザーによって依存関係として使用されている場合、そのモジュール自体のオーバーライドは無視されます。
パラメータ
パラメータ | 説明 |
---|---|
module_name
|
string;
必須 このオーバーライドを適用する Bazel モジュール依存関係の名前。 |
version
|
string;
デフォルトは '' 依存関係グラフで宣言されているこのモジュールのバージョンをオーバーライドします。言い換えると、このモジュールは「固定」オーバーライドできますオーバーライドする対象がレジストリまたはパッチの場合は、この属性を省略できます。 |
registry
|
文字列。デフォルトは '' 。このモジュールのレジストリをオーバーライドします。レジストリのデフォルト リストからこのモジュールを検索するのではなく、指定されたレジストリを使用する必要があります。 |
patches
|
文字列の反復可能オブジェクト。デフォルトは [] 。このモジュールに適用するパッチファイルを指すラベルのリスト。パッチファイルは、最上位プロジェクトのソースツリーに存在している必要があります。リストの順序で適用されます。 パッチによって MODULE.bazel ファイルに変更が加えられた場合、その変更は、パッチファイルがルートモジュールによって提供された場合にのみ有効になります。 |
patch_cmds
|
文字列の反復可能オブジェクト。デフォルトは [] 。パッチ適用後に Linux / macOS で適用される Bash コマンドのシーケンス。 MODULE.bazel ファイルに加えた変更は有効になりません。 |
patch_strip
|
int。デフォルトは 0 。Unix パッチの --strip 引数と同じです。 |
use_extension
module_extension_proxy use_extension(extension_bzl_file, extension_name, *, dev_dependency=False, isolate=False)モジュール拡張機能を表すプロキシ オブジェクトを返します。このオブジェクトのメソッドを呼び出して、モジュール拡張タグを作成できます。
パラメータ
パラメータ | 説明 |
---|---|
extension_bzl_file
|
文字列;
必須 Starlark ファイルのラベル。モジュール拡張機能を定義します。 |
extension_name
|
string;
必須 使用するモジュール拡張機能の名前。この名前のシンボルは、Starlark ファイルによってエクスポートする必要があります。 |
dev_dependency
|
bool;
デフォルトは False です true の場合、現在のモジュールがルート モジュールでない場合、または「--ignore_dev_dependency」が有効になっている場合、このモジュール拡張機能の使用は無視されます。 |
isolate
|
bool;
デフォルトは False です 試験運用版。このパラメータは試験運用版であり、随時変更される可能性があります。これに依存しないでください。 --experimental_isolated_extension_usages を設定することで、試験運用版として有効にできます。true に設定すると、このモジュール拡張機能のこの使用は、このモジュールと他のモジュールの両方において、他のすべての使用から分離されます。この用途で作成されたタグは他の用途には影響しません。また、この用途のために拡張機能によって生成されたリポジトリは、拡張機能によって生成された他のすべてのリポジトリとは異なります。 このパラメータは現在試験運用中であり、フラグ |
use_repo
None
use_repo(extension_proxy, *args, **kwargs)
指定されたモジュール拡張機能によって生成された 1 つ以上のリポジトリを現在のモジュールのスコープにインポートします。
パラメータ
パラメータ | 説明 |
---|---|
extension_proxy
|
module_extension_proxy;
必須use_extension 呼び出しによって返されるモジュール拡張プロキシ オブジェクト。
|
args
|
必須 インポートするリポジトリの名前。 |
kwargs
|
必須 現在のモジュールのスコープに異なる名前でインポートする特定のリポジトリを指定します。キーは現在のスコープで使用する名前にする必要があります。値は、モジュール拡張機能によってエクスポートされた元の名前にする必要があります。 |
use_repo_rule
repo_rule_proxy use_repo_rule(repo_rule_bzl_file, repo_rule_name)MODULE.bazel ファイルでリポジトリ ルールとして 1 回以上直接呼び出せるプロキシ値を返します。この方法で作成されたリポジトリは、プロキシの
name
属性を使用して宣言された名前で、現在のモジュールにのみ表示されます。暗黙的なブール値 dev_dependency
属性をプロキシで使用して、現在のモジュールがルート モジュールである場合にのみ特定のリポジトリが作成されることを示すこともできます。
パラメータ
パラメータ | 説明 |
---|---|
repo_rule_bzl_file
|
文字列。必須 Repo ルールを定義する Starlark ファイルのラベル。 |
repo_rule_name
|
string;
必須 使用するリポジトリ ルールの名前。この名前のシンボルは、Starlark ファイルによってエクスポートする必要があります。 |