native.cc_library
). 네이티브 모듈은 로드 단계에서만 사용할 수 있습니다 (예: 규칙 구현이 아니라 매크로에 사용). 속성은 None
값을 무시하고 속성이 설정되지 않은 것처럼 처리합니다.다음 함수도 사용할 수 있습니다.
회원
기존_규칙
unknown native.existing_rule(name)이 스레드의 패키지에서 인스턴스화된 규칙의 속성을 설명하는 변경 불가능한 dict 객체를 반환하거나 해당 이름의 규칙 인스턴스가 없는 경우
None
을 반환합니다.여기서 변경 불가능한 dict-like 객체는 dict와 같은 반복, len(x)
, name in x
, x[name]
, x.get(name)
, x.items()
, x.keys()
, x.values()
를 지원하는 변경 불가능한 객체 x
를 의미합니다.
--noincompatible_existing_rules_immutable_view
플래그가 설정되면 대신 동일한 콘텐츠로 변경 가능한 새 dict를 반환합니다.
결과에는 문자로 구성된 비공개 속성 및 표시되지 않는 기존 속성 유형 몇 개를 제외한 각 항목에 대한 항목이 포함됩니다. 또한 이 규칙에는 규칙 인스턴스의 name
및 kind
에 대한 항목(예: 'cc_binary'
)이 포함되어 있습니다.
결과 값은 다음과 같이 속성 값을 나타냅니다.
- str, int, bool 유형의 속성은 그대로 표현됩니다.
- 라벨은 동일한 패키지의 대상에 대해
':foo'
형식의 문자열로, 다른 패키지의 대상에 대해'//pkg:name'
형식으로 변환됩니다. - 목록은 튜플로 표현되며 dict는 변경 가능한 새 dict로 변환됩니다. 이러한 요소는 동일한 방식으로 재귀적으로 변환됩니다.
select
값은 위에서 설명한 대로 콘텐츠가 변환된 상태로 반환됩니다.- 규칙을 인스턴스화하는 동안 값이 지정되지 않았고 기본값이 계산된 속성은 결과에서 제외됩니다. 계산된 기본값은 분석 단계까지 계산할 수 없습니다.
가능하면 이 함수를 사용하지 마세요. BUILD 파일이 불안정해지고 순서에 종속됩니다. 또한 이 규칙은 내부 양식에서 Starlark로 이어지는 규칙 속성 값의 두 가지 다른 변환에 미묘하게 차이가 있습니다. 하나는 계산된 기본값에 사용되고 다른 하나는 ctx.attr.foo
에 사용됩니다.
매개변수
매개변수 | 설명 |
---|---|
name
|
필수 항목 대상 이름입니다. |
기존_규칙
unknown native.existing_rules()지금까지 이 스레드의 패키지에서 인스턴스화한 규칙을 설명하는 변경 불가능한 dict 객체를 반환합니다. dict와 유사한 객체의 각 항목은 규칙 인스턴스의 이름을
existing_rule(name)
에서 반환하는 결과에 매핑합니다.여기서 변경 불가능한 dict-like 객체는 dict와 같은 반복, len(x)
, name in x
, x[name]
, x.get(name)
, x.items()
, x.keys()
, x.values()
를 지원하는 변경 불가능한 객체 x
를 의미합니다.
--noincompatible_existing_rules_immutable_view
플래그가 설정되면 대신 동일한 콘텐츠로 변경 가능한 새 dict를 반환합니다.
참고: 가능하면 이 함수를 사용하지 마세요. BUILD 파일이 불안정해지고 순서에 종속됩니다. 또한 --noincompatible_existing_rules_immutable_view
플래그가 설정된 경우 이 함수는 특히 루프 내에서 호출되는 경우 비용이 많이 들 수 있습니다.
Export_files
None native.exports_files(srcs, visibility=None, licenses=None)이 패키지에 속한 파일 중 다른 패키지로 내보내는 파일 목록을 지정합니다.
매개변수
매개변수 | 설명 |
---|---|
srcs
|
sequence of strings ,
필수내보낼 파일 목록입니다. |
visibility
|
sequence; or None ;
default = None가시성 선언을 지정할 수 있습니다. 지정된 타겟에 파일이 표시됩니다. 공개 상태를 지정하지 않으면 파일이 모든 패키지에 표시됩니다. |
licenses
|
sequence of strings; or None ;
default = None지정할 라이선스 |
글로브
sequence native.glob(include=[], exclude=[], exclude_directories=1, allow_empty=unbound)Glob은 현재 패키지에 있는 모든 파일의 새로운 변경 가능하고 정렬된 목록을 반환합니다.
include
의 패턴과 하나 이상 일치합니다.exclude
의 패턴과 일치하지 않습니다(기본값[]
).
exclude_directories
인수가 사용 설정된 경우 (1
로 설정됨) 결과 디렉터리 유형의 파일이 결과에서 생략됩니다 (기본값 1
).
매개변수
매개변수 | 설명 |
---|---|
include
|
sequence of strings ;
default = []포함할 glob 패턴 목록입니다. |
exclude
|
sequence of strings ;
default = []제외할 glob 패턴 목록입니다. |
exclude_directories
|
default = 1 디렉터리를 제외할지 여부를 나타내는 플래그입니다. |
allow_empty
|
기본값 = 결합되지 않음 glob 패턴이 아무것도 일치되지 않도록 허용하는지 여부입니다. `allow_empty` 가 False인 경우 각 개별 포함 패턴은 무언가와 일치해야 하며 최종 결과도 비어 있지 않아야 합니다 (`exclude` 패턴과 일치하는 경우 제외). |
package_group
None native.package_group(name, packages=[], includes=[])이 함수는 패키지 집합을 정의하고 그룹에 라벨을 할당합니다. 라벨은
visibility
속성에서 참조할 수 있습니다.
매개변수
매개변수 | 설명 |
---|---|
name
|
필수 이 규칙의 고유한 이름입니다. |
packages
|
sequence of strings ;
default = []이 그룹의 전체 패키지 열거형입니다. |
includes
|
sequence of strings ,
default = []이 패키지에 포함된 다른 패키지 그룹 |
package_name
string native.package_name()평가 중인 패키지의 이름입니다. 예를 들어 BUILD 파일
some/package/BUILD
에서 값은 some/package
입니다. BUILD 파일이 .bzl 파일에 정의된 함수를 호출하면 package_name()
는 호출자 BUILD 파일 패키지와 일치합니다. 이 함수는 지원 중단된 변수 PACKAGE_NAME
와 동일합니다.
package_relative_label
Label native.package_relative_label(input)현재 초기화 중인 패키지의 컨텍스트 (즉, 현재 매크로가 실행되고 있는
BUILD
파일)에서 입력 문자열을 라벨 객체로 변환합니다. 입력이 이미 Label
이면 변경되지 않은 상태로 반환됩니다.이 함수는 BUILD 파일과 이 함수를 직접 또는 간접적으로 호출하는 매크로를 평가하는 동안에만 호출할 수 있습니다. 예를 들어 규칙 구현 함수에서는 호출할 수 없습니다.
이 함수의 결과는 BUILD 파일에 선언된 대상의 라벨 값 속성에 지정된 문자열을 전달하여 생성되는 Label
값과 동일합니다.
사용 참고사항: 이 함수와 Label()의 차이점은 Label()
는 BUILD
파일의 패키지가 아닌 호출한 .bzl
파일의 패키지 컨텍스트를 사용한다는 것입니다. 컴파일러와 같이 매크로에 하드코딩된 고정 타겟을 참조해야 하는 경우 Label()
를 사용합니다. BUILD 파일에서 Label
객체로 제공한 라벨 문자열을 정규화해야 하는 경우 package_relative_label()
를 사용합니다. (BUILD 파일 또는 호출 .bzl 파일 외의 패키지 컨텍스트에서는 문자열을 Label
로 변환할 수 없습니다. 따라서 외부 매크로는 항상 라벨 객체가 아닌 내부 매크로에 Label 객체를 전달하도록 합니다.
매개변수
매개변수 | 설명 |
---|---|
input
|
string; or Label ,
필수입력 라벨 문자열 또는 라벨 객체입니다. 라벨 객체가 전달되면 이 객체는 그대로 반환됩니다. |
저장소_이름
string native.repository_name()규칙 또는 빌드 확장 프로그램이 호출되는 저장소 이름입니다. 예를 들어 WORKSPACE 스탠자
local_repository(name='local', path=...)
에 의해 존재로 호출된 패키지에서는 @local
로 설정됩니다. 기본 저장소의 패키지에서는 @
로 설정됩니다. 이 함수는 지원 중단된 변수 REPOSITORY_NAME
와 동일합니다.
하위 패키지
sequence native.subpackages(include, exclude=[], allow_empty=False)파일 시스템 디렉터리 깊이와 관계없이 현재 패키지의 모든 직접 하위 패키지의 변경 가능한 새 목록을 반환합니다. 반환된 목록은 정렬되어 현재 패키지에 상대적인 하위 패키지의 이름이 포함됩니다. 이 함수를 직접 호출하는 대신 bazel_skylib.subpackages 모듈에서 메서드를 사용하는 것이 좋습니다.
매개변수
매개변수 | 설명 |
---|---|
include
|
sequence of strings ,
필수하위 패키지 스캔에 포함할 glob 패턴 목록입니다. |
exclude
|
sequence of strings ;
default = []하위 패키지 스캔에서 제외할 glob 패턴 목록입니다. |
allow_empty
|
default = False 호출이 빈 목록을 반환하는 경우 실패 여부를 나타냅니다. 기본적으로 빈 목록은 subpackages() 호출이 불필요하게 이루어지는 BUILD 파일에서 잠재적인 오류를 나타냅니다. true로 설정하면 이러한 경우에 이 함수가 성공할 수 있습니다. |