transition

종속 항목 가장자리에서 구성 전환을 나타냅니다. 예를 들어 //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 required
이 전환을 구현하는 함수입니다. 이 함수에는 항상 두 개의 매개변수(settingsattr)가 있습니다. settings 매개변수는 키 집합이 입력 매개변수에 의해 정의된 사전입니다. 따라서 각 빌드 설정 --//foo=bar의 경우 inputs//foo가 포함되면 settingssettings['//foo']='bar' 항목이 있습니다.

attr 매개변수는 ctx.attr의 참조입니다. 이렇게 하면 구현 함수가 규칙의 속성에 액세스하여 속성 매개변수화 전환을 가능하게 할 수 있습니다.

이 함수는 빌드 설정 식별자에서 빌드 설정 값으로 dict를 반환해야 합니다. 이는 구성 전환을 나타냅니다. 반환된 dict의 각 항목에 대해 전환은 해당 설정을 새 값으로 업데이트합니다. 다른 모든 설정은 변경되지 않습니다. 이 함수는 분할 전환의 경우 dictlist 또는 dictdict를 반환할 수도 있습니다.

inputs 문자열시퀀스입니다. 필수
이 전환에서 읽을 수 있는 빌드 설정 목록입니다. 이는 구현 함수 매개변수의 설정 매개변수의 키 집합이 됩니다.
outputs 문자열시퀀스입니다. 필수
이 전환으로 쓸 수 있는 빌드 설정 목록입니다. 이 전환에서 반환된 사전의 키 집합의 상위 집합이어야 합니다.