transition

문제 신고 소스 보기

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

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

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

inputs stringsequence, 필수
이 전환에서 읽을 수 있는 빌드 설정의 목록입니다. 이는 구현 함수 매개변수의 설정 매개변수의 키 세트가 됩니다.
outputs stringsequence, 필수
이 전환에서 쓸 수 있는 빌드 설정의 목록입니다. 이 전환에서 반환된 사전의 키 세트의 상위 집합이어야 합니다.