Bağımlılık kenarında bir yapılandırma geçişini temsil eder. Örneğin, //package:foo
bir yapılandırma geçişiyle //package:bar
'e bağlıysa bu iki hedefin yapılandırması farklı olur: //package:bar
'un geçişi, bir geçiş nesnesi tarafından tanımlanan işleve tabi olarak //package:foo
'ün geçişine göre belirlenir.
Üyeler
geçiş
transition transition(implementation, inputs, outputs)
Örnek:
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"], )
Daha fazla bilgiyi burada bulabilirsiniz.
Parametreler
Parametre | Açıklama |
---|---|
implementation
|
callable;
required Bu geçişi uygulayan işlev. Bu işlevin her zaman iki parametresi vardır: settings ve attr . settings parametresi, anahtar grubu inputs parametresi tarafından tanımlanan bir sözlüktür. Dolayısıyla, her derleme ayarı --//foo=bar için inputs , //foo içeriyorsa settings 'da bir settings['//foo']='bar' girişi olur.
Bu işlev, derleme ayarı tanımlayıcısından derleme ayarı değerine bir |
inputs
|
Dize dizisi;
zorunlu Bu geçiş tarafından okunabilen derleme ayarlarının listesi. Bu, uygulama işlevi parametresinin ayarlar parametresinin anahtar kümesi olur. |
outputs
|
Dize dizisi;
zorunlu Bu geçiş tarafından yazılabilen derleme ayarlarının listesi. Bu, bu geçiş tarafından döndürülen sözlüğün anahtar kümesinin bir üst kümesi olmalıdır. |