依存関係エッジをまたぐ構成遷移を表します。たとえば、//package:foo が構成遷移で //package:bar に依存している場合、これらの 2 つのターゲットの構成は異なります。//package:bar の遷移は、遷移オブジェクトで定義された関数に従って、//package:foo の遷移によって決まります。
メンバー
transition
transition transition(implementation, inputs, outputs)
例:
def _transition_impl(settings, attr):
# This transition just reads the current CPU value as a demonstration.
# A real transition could incorporate this into its followup logic.
current_cpu = settings["//command_line_option:cpu"]
return {"//command_line_option:compilation_mode": "dbg"}
build_in_debug_mode = transition(
implementation = _transition_impl,
inputs = ["//command_line_option:cpu"],
outputs = ["//command_line_option:compilation_mode"],
)詳しくはこちらをご覧ください。
パラメータ
| パラメータ | 説明 |
|---|---|
implementation
|
callable;
必須 この遷移を実装する関数。この関数には常に settings と attr の 2 つのパラメータがあります。settings パラメータは、キーセットが inputs パラメータで定義される辞書です。したがって、ビルド設定 --//foo=bar ごとに、inputs に //foo が含まれている場合、settings にはエントリ settings['//foo']='bar' が含まれます。
この関数は、ビルド設定 ID からビルド設定値への |
inputs
|
文字列のシーケンス。必須 この遷移で読み取ることができるビルド設定のリスト。これは、実装関数パラメータの設定パラメータのキーセットになります。 |
outputs
|
文字列のシーケンス。必須 この遷移によって書き込まれるビルド設定のリスト。これは、この遷移によって返される辞書のキーセットのスーパーセットである必要があります。 |