Representa uma transição de configuração em uma borda de dependência. Por exemplo, se //package:foo depender de //package:bar com uma transição de configuração, a configuração dessas duas metas será diferente: a transição de //package:bar será determinada pela de //package:foo, sujeita à função definida por um objeto de transição.
Membros
transição
transition transition(implementation, inputs, outputs)
Exemplo:
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"],
)Para saber mais detalhes, acesse esta página.
Parâmetros
| Parâmetro | Descrição |
|---|---|
implementation
|
callable;
required A função que implementa essa transição. Essa função sempre tem dois parâmetros: settings e attr. O parâmetro settings é um dicionário cujo conjunto de chaves é definido pelo parâmetro de entradas. Portanto, para cada configuração de build --//foo=bar, se inputs contiver //foo, settings terá uma entrada settings['//foo']='bar'.O parâmetro Essa função precisa retornar um |
inputs
|
Sequência de strings;
Obrigatório Lista de configurações de build que podem ser lidas por essa transição. Esse é o conjunto de chaves do parâmetro "settings" do parâmetro da função de implementação. |
outputs
|
Sequência de strings;
Obrigatório Lista de configurações de build que podem ser gravadas por essa transição. Ele precisa ser um superconjunto do conjunto de chaves do dicionário retornado por essa transição. |