module_ctx

問題を報告 ソースを表示

ヘルパー関数を含むモジュール拡張のコンテキストと、依存関係グラフ全体の関連タグに関する情報。モジュール拡張機能を作成するときに、module_language オブジェクトを implementation 関数の引数として取得します。

メンバー

ダウンロード

struct module_ctx.download(url, output='', sha256='', executable=False, allow_fail=False, canonical_id='', auth={}, *, integrity='')

指定された URL の出力パスにファイルをダウンロードし、success を含む構造体を返します。ダウンロードが正常に完了した場合はフラグ true、成功した場合は sha256integrity のフィールドを含むファイルのハッシュを返します。

パラメータ

パラメータ 説明
url 文字列、または文字列のイテラブル。 必須
同じファイルを参照するミラー URL のリスト。
output stringLabelpath。デフォルトは ''
です。出力ファイルのパス(リポジトリ ディレクトリを基準とする相対パス)です。
sha256 デフォルトは '' です。
ダウンロードしたファイルの想定される SHA-256 ハッシュです。ダウンロードしたファイルの SHA-256 ハッシュと一致している必要があります。リモート ファイルは変更される可能性があるため、SHA-256 を省略するとセキュリティ リスクが発生します。このフィールドを省略すると、ビルドが非密閉型のものになります。開発を容易にするためのオプションですが、リリース前に設定する必要があります。
executable デフォルトは False です。
作成されたファイルの実行可能フラグを設定します。デフォルトでは false です。
allow_fail デフォルトは False です
設定されている場合は、ダウンロードに失敗した場合にエラーを返すのではなく、戻り値でエラーを示します。
canonical_id デフォルトは '' です。
設定すると、キャッシュ ヒットを、同じ正規 ID でファイルがキャッシュに追加された場合にのみキャッシュ ヒットに制限されます。
auth デフォルトは {} です。
一部の URL の認証情報を指定するディクショナリ(省略可)。
integrity デフォルトは '' です。
ダウンロードされるファイルの想定されるチェックサム(サブリソースの整合性形式)。ダウンロードしたファイルのチェックサムと一致する必要があります。リモート ファイルが変更される可能性があるため、チェックサムを省略するとセキュリティ上のリスクが発生します。このフィールドを省略すると、ビルドが非密閉型のものになります。開発を容易にするためのオプションですが、リリース前に設定する必要があります。

download_and_extract

struct module_ctx.download_and_extract(url, output='', sha256='', type='', stripPrefix='', allow_fail=False, canonical_id='', auth={}, *, integrity='', rename_files={})

指定された URL の出力パスにファイルをダウンロードして抽出し、success を含む構造体を返します。フラグ(ダウンロードが正常に完了した場合は true、成功した場合は sha256integrity を含むファイルのハッシュ)が含まれます。

パラメータ

パラメータ 説明
url 文字列、または文字列のイテラブル。 必須
同じファイルを参照するミラー URL のリスト。
output stringLabelpath。デフォルトは ''
アーカイブを展開するディレクトリへのパス(リポジトリ ディレクトリを基準とする相対パス)です。
sha256 デフォルトは '' です。
ダウンロードしたファイルの想定される SHA-256 ハッシュです。ダウンロードしたファイルの SHA-256 ハッシュと一致している必要があります。リモート ファイルは変更される可能性があるため、SHA-256 を省略するとセキュリティ リスクが発生します。このフィールドを省略すると、ビルドが非密閉型のものになります。開発を容易にするためのオプションですが、リリース前に設定する必要があります。指定すると、まず、指定したハッシュを持つファイルがないかリポジトリのキャッシュがチェックされます。ダウンロードは、ファイルがキャッシュに見つからなかった場合にのみ試行されます。ダウンロードが正常に完了すると、ファイルがキャッシュに追加されます。
type デフォルトは '' です。
ダウンロードされたファイルのアーカイブ タイプです。デフォルトでは、アーカイブの種類は URL のファイル拡張子によって決まります。ファイルの拡張子がない場合は、zip、jar、war、aar、tar、tar.gz、tgz、tar.xz、txz、.tar.zst、.tzst、tar.bz2、.t.deb のいずれかを明示的に指定できます。
stripPrefix デフォルトは '' です。
抽出されたファイルから削除するディレクトリ接頭辞です。多くのアーカイブには、アーカイブ内のすべてのファイルを含む最上位ディレクトリがあります。このフィールドを使用すると、この接頭辞を build_file で何度も指定しなくても、抽出されたファイルから削除できます。
allow_fail デフォルトは False です
設定されている場合は、ダウンロードに失敗した場合にエラーを返すのではなく、戻り値でエラーを示します。
canonical_id デフォルトは '' です。
設定すると、キャッシュ ヒットを、同じ正規 ID でファイルがキャッシュに追加された場合にのみキャッシュ ヒットに制限されます。
auth デフォルトは {} です。
一部の URL の認証情報を指定するディクショナリ(省略可)。
integrity デフォルトは '' です。
ダウンロードされるファイルの想定されるチェックサム(サブリソースの整合性形式)。ダウンロードしたファイルのチェックサムと一致する必要があります。リモート ファイルが変更される可能性があるため、チェックサムを省略するとセキュリティ上のリスクが発生します。このフィールドを省略すると、ビルドが非密閉型のものになります。開発を容易にするためのオプションですが、リリース前に設定する必要があります。
rename_files デフォルトは {} です。
抽出時に名前を変更するファイルを指定するディクショナリ(省略可)。名前がキーと完全に一致するアーカイブ エントリは、ディレクトリ接頭辞が調整される前に、その値に名前が変更されます。これは、Unicode 以外のファイル名を含むアーカイブや、大文字と小文字を区別しないファイルシステム上の同じパスに抽出されるファイルを含むアーカイブの抽出に使用できます。

execute

exec_result module_ctx.execute(arguments, timeout=600, environment={}, quiet=True, working_directory="")

引数のリストで指定されたコマンドを実行します。コマンドの実行時間は timeout(秒、デフォルトは 600 秒)によって制限されます。このメソッドは、コマンドの出力を含む exec_result 構造体を返します。environment マップを使用すると、プロセスに渡す一部の環境変数をオーバーライドできます。

パラメータ

パラメータ 説明
arguments required
引数のリスト。最初の要素は、実行するプログラムのパスにする必要があります。
timeout デフォルトは 600 です。
コマンドの最大時間(秒)です(デフォルトは 600 秒)。
environment デフォルトは {} です。
一部の環境変数がプロセスに渡されるように設定されます。
quiet デフォルトは True です。
stdout と stderr をターミナルに出力する場合。
working_directory デフォルトは "" です。
コマンド実行用の作業ディレクトリ。リポジトリ ルートからの相対パスまたは絶対パスを指定できます。

extension_metadata

extension_metadata module_ctx.extension_metadata(root_module_direct_deps=None, root_module_direct_dev_deps=None)

Bazel 拡張機能によって生成されたリポジトリに関するメタデータを提供するために、モジュール拡張機能の実装関数から返すことができる不透明オブジェクトを作成します。

パラメータ

パラメータ 説明
root_module_direct_deps stringシーケンス、または string、または None。デフォルトは None です。
拡張機能がルート モジュールの直接的な依存関係と見なすリポジトリの名前。ルート モジュールが追加のリポジトリをインポートする場合、または use_repo を介してこれらのリポジトリをすべてインポートしていない場合、拡張機能が評価されると、Bazel は警告と修正コマンドを出力します。

root_module_direct_depsroot_module_direct_dev_deps のいずれかを指定する場合は、もう 1 つも指定する必要があります。これら 2 つのパラメータで指定するリストは互いに重複している必要があります。

root_module_direct_depsroot_module_direct_dev_deps のいずれか 1 つのみを特別な値 "all" に設定できます。これは、拡張機能によって生成されたすべてのリポジトリの名前を含むリストを値として指定したかのように扱われます。

root_module_direct_dev_deps stringシーケンス、または string、または None。デフォルトは None です。
拡張機能がルート モジュールの直接的な開発依存関係と見なすリポジトリの名前。ルート モジュールが追加のリポジトリをインポートする場合や、use_extension(..., dev_dependency = True) で作成した拡張機能プロキシで use_repo を介してこれらのリポジトリをすべてインポートしていない場合、拡張機能の評価時に Bazel から警告と修正コマンドが出力されます。

root_module_direct_depsroot_module_direct_dev_deps のいずれかを指定する場合は、もう 1 つも指定する必要があります。これら 2 つのパラメータで指定するリストは互いに重複している必要があります。

root_module_direct_depsroot_module_direct_dev_deps のいずれか 1 つのみを特別な値 "all" に設定できます。これは、拡張機能によって生成されたすべてのリポジトリの名前を含むリストを値として指定したかのように扱われます。

あなた宛てに表示されます。

None module_ctx.file(path, content='', executable=True, legacy_utf8=True)

リポジトリ ディレクトリに、指定されたコンテンツを含むファイルを生成します。

パラメータ

パラメータ 説明
path stringLabel、または path。リポジトリ ディレクトリを基準とする、作成するファイルの
パス(必須)。
content デフォルトは '' です。
作成するファイルの内容。デフォルトでは空です。
executable デフォルトは True です。
作成されたファイルの実行可能フラグをデフォルトで true に設定します。
legacy_utf8 デフォルトは True です。
ファイルのコンテンツを UTF-8 にエンコードします。デフォルトでは true です。今後のバージョンでデフォルトが変更され、このパラメータは削除されます。

is_dev_dependency

bool module_ctx.is_dev_dependency(tag)

devDependency = True を使用した use_extension 呼び出しの結果に指定されたタグが指定されたかどうかを返します。

パラメータ

パラメータ 説明
tag bazel_module_tag; required
bazel_module.tags から取得したタグ。

modules

list module_ctx.modules

このモジュール拡張機能を使用している、外部依存関係グラフ内のすべての Bazel モジュールのリスト。各モジュールは、この拡張機能に指定されたすべてのタグを公開する bazel_module オブジェクトです。この辞書の反復順序は、ルート モジュールから始まる幅優先探索と同じであることが保証されます。

os

repository_os module_ctx.os

システムの情報にアクセスするための構造体。

パス

path module_ctx.path(path)

文字列、ラベル、またはパスからパスを返します。パスが相対パスの場合は、リポジトリ ディレクトリを基準として解決されます。パスがラベルの場合は、対応するファイルのパスに解決されます。リモート・リポジトリは分析フェーズで実行されるため、ターゲットの結果に依存できません(ラベルは、生成されていないファイルを指している必要があります)。パスにパスを指定した場合は、パスがそのまま返されます。

パラメータ

パラメータ 説明
path stringLabel、または path。必須
パスの作成元となる文字列、ラベル、またはパス

read

string module_ctx.read(path)

ファイル システム上のファイルのコンテンツを読み取ります。

パラメータ

パラメータ 説明
path stringLabelpath。読み取り元のファイルの
パス(必須)。

report_progress

None module_ctx.report_progress(status='')

このリポジトリまたはモジュール拡張機能の取得の進行状況ステータスを更新します。

パラメータ

パラメータ 説明
status string: デフォルトは ''
取得の進行状況を示す文字列

root_module_has_non_dev_dependency

bool module_ctx.root_module_has_non_dev_dependency

ルート モジュールがこの拡張機能を非 dev 依存関係として使用するかどうか。

これは

path module_ctx.which(program)

対応するプログラムのパスを返します。パス内にそのようなプログラムが存在しない場合は None を返します。

パラメータ

パラメータ 説明
program required
プログラムはパス内で検出します。
None が返されることがあります。