表示依赖项边缘上的配置转换。例如,如果 //package:foo 依赖于具有配置转换的 //package:bar,则 //package:bar(及其依赖项)的配置将是 //package:foo 的配置加上转换函数指定的更改。
成员
过渡
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
|
可调用;
必需 用于实现此转换的函数。此函数始终有两个参数: settings 和 attr。settings 参数是一个字典,其键集由 inputs 参数定义。因此,对于每个 build 设置 --//foo=bar,如果 inputs 包含 //foo,则 settings 将包含条目 settings['//foo']='bar'。
此函数必须返回一个 |
inputs
|
字符串的序列;
必需 此转换可以读取的 build 设置的列表。这将成为实现函数参数的设置参数的键集。 |
outputs
|
字符串的序列;
必需 此转换可以写入的 build 设置的列表。此集必须是此转换返回的字典的键集的超集。 |