빌드 타겟 식별자입니다.
모든 Label
인스턴스 l
의 경우 문자열 표현 str(l)
에는 Label()
호출이 발생한 위치와 관계없이 Label(str(l)) == l
속성이 있습니다.
print()
또는 fail()
에 위치 인수로 전달되면 Label
는 대신 사람이 읽기 쉽게 최적화된 문자열 표현을 사용합니다. 이 표현은 가능하면 기본 저장소의 관점에서 표시 저장소 이름을 사용합니다.
회원
라벨
Label Label(input)
.bzl
소스 파일이 있는 패키지의 컨텍스트에서 라벨 문자열을 Label
객체로 변환합니다. 주어진 값이 이미 Label
인 경우 변경되지 않은 상태로 반환됩니다.매크로의 경우 관련 함수인 native.package_relative_label()
가 현재 빌드 중인 패키지의 컨텍스트에서 입력을 Label
로 변환합니다. 이 함수를 사용하여 라벨 값 규칙 속성에서 자동으로 실행되는 문자열-라벨 변환을 모방합니다.
매개변수
매개변수 | 설명 |
---|---|
input
|
string 또는 Label;
필수 입력 라벨 문자열 또는 Label 객체입니다. 라벨 객체가 전달되면 있는 그대로 반환됩니다. |
이름
string Label.name
Label("@@foo//pkg/foo:abc").name == "abc"
패키지
string Label.package
Label("@@repo//pkg/foo:abc").package == "pkg/foo"
상대
Label Label.relative(relName)
--+incompatible_enable_deprecated_label_apis
를 설정하여 실험적으로 사용 설정할 수 있습니다.지원 중단됨 이 메서드는 명시적인 저장소 이름이 포함된 인수와 함께 사용하면 놀랍게 동작합니다. 대신
Label.same_package_label()
, native.package_relative_label()
또는 Label()
를 사용하세요.절대 레이블 (//
로 시작) 또는 현재 패키지를 기준으로 하는 상대 레이블을 확인합니다. 이 라벨이 원격 저장소에 있는 경우 인수는 해당 저장소를 기준으로 확인됩니다. 인수에 저장소 이름이 포함된 경우 현재 라벨은 무시되고 인수는 있는 그대로 반환됩니다. 단, 저장소 이름이 현재 저장소 매핑에 있는 경우 재작성됩니다. 예약된 라벨도 있는 그대로 반환됩니다.
예:
Label("//foo/bar:baz").relative(":quux") == Label("//foo/bar:quux") Label("//foo/bar:baz").relative("//wiz:quux") == Label("//wiz:quux") Label("@repo//foo/bar:baz").relative("//wiz:quux") == Label("@repo//wiz:quux") Label("@repo//foo/bar:baz").relative("//visibility:public") == Label("//visibility:public") Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@other//wiz:quux")
전달된 저장소 매핑이 {'@other' : '@remapped'}
이면 다음과 같이 재매핑이 실행됩니다.
Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@remapped//wiz:quux")
매개변수
매개변수 | 설명 |
---|---|
relName
|
string;
required 이 라벨을 기준으로 확인되는 라벨입니다. |
repo_name
string Label.repo_name
@
)는 포함되지 않습니다. 예를 들면 다음과 같습니다. Label("@@foo//bar:baz").repo_name == "foo"
same_package_label
Label Label.same_package_label(target_name)
매개변수
매개변수 | 설명 |
---|---|
target_name
|
string;
required 새 라벨의 대상 이름입니다. |
workspace_name
string Label.workspace_name
--+incompatible_enable_deprecated_label_apis
를 설정하여 실험적으로 사용 설정할 수 있습니다.지원 중단됨 필드 이름 'workspace name'은 잘못된 이름입니다. 동일한 동작을 하는
Label.repo_name
을 대신 사용하세요.이 라벨에서 참조하는 타겟이 포함된 저장소의 표준 이름으로, 선행 at 기호 (@
)는 포함되지 않습니다. 예를 들면 다음과 같습니다.
Label("@@foo//bar:baz").workspace_name == "foo"
workspace_root
string Label.workspace_root
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"