기본 정보

문제 신고 소스 보기

대상의 직접 및 전환 파일에 관한 일반적인 정보를 제공하는 제공업체입니다. 이 규칙은 규칙의 구현 함수에서 명시적으로 반환되지 않더라도 모든 규칙 유형에 포함되어 있습니다. 각 DefaultInfo 인스턴스에는 다음과 같은 필드가 있습니다.
  • files
  • files_to_run
  • data_runfiles
  • default_runfiles
제공업체 사용 방법에 대한 자세한 안내는 규칙 페이지를 참조하세요.

구성원

기본 정보

DefaultInfo DefaultInfo(files=None, runfiles=None, data_runfiles=None, default_runfiles=None, executable=None)

DefaultInfo 생성자

매개변수

매개변수 설명
files depset; or None; 기본값 = None
이 타겟이 bazel 명령줄에서 지정된 경우 빌드할 기본 출력을 나타내는 File 객체의 depset입니다. 기본적으로 모든 사전 선언된 출력입니다.
runfiles runfiles; or None; default = None
runfile에 이 타겟에 필요한 파일을 설명하는 설명자입니다 (run 명령어를 통해 또는 도구 종속 항목을 통해).
data_runfiles runfiles; or None; 기본값 = 없음

이 매개변수를 사용하지 않는 것이 좋습니다 ('피해야 할 실행 파일 기능' 참고).

data 속성을 통한 종속 항목인 경우 이 타겟이 실행해야 하는 runfile을 설명하는 runfiles 설명자
default_runfiles runfiles; or None; 기본값 = 없음

이 매개변수를 사용하지 않는 것이 좋습니다 ('피해야 할 실행 파일 기능' 참고).

data 속성이 아닌 속성을 통한 종속 항목인 경우 이 타겟이 실행해야 하는 runfile을 설명하는 runfiles 설명자
executable File; or None; 기본값 = None
이 규칙을 executable 또는 test로 표시하면 대상 실행을 위해 실행되어야 하는 파일을 나타내는 File 객체입니다. 기본적으로 사전 선언된 출력 ctx.outputs.executable입니다.

데이터_실행파일

runfiles DefaultInfo.data_runfiles

data 종속 항목이라는 조건에서 실행할 때 이 대상이 필요한 파일을 설명하는 runfiles 설명자 대부분의 경우 default_runfiles 매개변수를 대신 사용합니다. 자세한 내용은 '피해야 할 실행 파일 기능'을 참고하세요. None가 반환될 수 있습니다.

default_runfiles

runfiles DefaultInfo.default_runfiles

실행 시 이 타겟이 필요한 파일을 설명하는 runfiles 설명자 (run 명령어를 통해 또는 도구 종속 항목으로 사용) None가 반환될 수 있습니다.

파일

depset DefaultInfo.files

이 대상이 bazel 명령줄에 지정된 경우 빌드할 기본 출력을 나타내는 File 객체의 depset입니다. 기본적으로 모든 사전 선언된 출력입니다. None가 반환될 수 있습니다.

실행할_파일

FilesToRunProvider DefaultInfo.files_to_run

타겟의 실행 파일 및 실행 파일에 대한 정보가 포함된 FilesToRunProvider 객체. None가 반환될 수 있습니다.

to_json

string DefaultInfo.to_json()

지원 중단됨. 이 API는 지원 중단되었으며 곧 삭제됩니다. 여기에 의존하지 마세요. ---incompatible_struct_has_no_methods에 의해 사용 중지됩니다. 이 플래그를 사용하여 코드가 곧 삭제되는 것과 호환되는지 확인합니다.
struct 매개변수에서 JSON 문자열을 만듭니다. 이 메서드는 모든 구조체 요소 (재귀적으로)가 문자열, 정수, 불리언, 기타 구조체, 이러한 유형 목록, 문자열 키 및 이러한 유형의 값을 가진 사전인 경우에만 작동합니다. 따옴표와 문자열의 새 줄은 이스케이프 처리됩니다. 예:
struct(key=123).to_json()
# {"key":123}

struct(key=True).to_json()
# {"key":true}

struct(key=[1, 2, 3]).to_json()
# {"key":[1,2,3]}

struct(key='text').to_json()
# {"key":"text"}

struct(key=struct(inner_key='text')).to_json()
# {"key":{"inner_key":"text"}}

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_json()
# {"key":[{"inner_key":1},{"inner_key":2}]}

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_json()
# {"key":{"inner_key":{"inner_inner_key":"text"}}}

지원 중단됨: 대신 json.encode(x) 또는 json.encode_indent(x)를 사용하세요. 그러면 구조체가 아닌 값에 작동하며 구조체 필드 네임스페이스가 오염되지 않습니다.

to_proto

string DefaultInfo.to_proto()

지원 중단됨. 이 API는 지원 중단되었으며 곧 삭제됩니다. 여기에 의존하지 마세요. ---incompatible_struct_has_no_methods에 의해 사용 중지됩니다. 이 플래그를 사용하여 코드가 곧 삭제되는 것과 호환되는지 확인합니다.
구조체 매개변수에서 문자 메시지를 만듭니다. 이 방법은 모든 구조체 요소 (재귀적으로)가 문자열, 정수, 불리언, 다른 구조체나 dicts 또는 이러한 유형의 목록인 경우에만 작동합니다. 따옴표와 문자열의 새 줄은 이스케이프 처리됩니다. 구조체 키는 정렬된 순서로 반복됩니다. 예:
struct(key=123).to_proto()
# key: 123

struct(key=True).to_proto()
# key: true

struct(key=[1, 2, 3]).to_proto()
# key: 1
# key: 2
# key: 3

struct(key='text').to_proto()
# key: "text"

struct(key=struct(inner_key='text')).to_proto()
# key {
#   inner_key: "text"
# }

struct(key=[struct(inner_key=1), struct(inner_key=2)]).to_proto()
# key {
#   inner_key: 1
# }
# key {
#   inner_key: 2
# }

struct(key=struct(inner_key=struct(inner_inner_key='text'))).to_proto()
# key {
#    inner_key {
#     inner_inner_key: "text"
#   }
# }

struct(foo={4: 3, 2: 1}).to_proto()
# foo: {
#   key: 4
#   value: 3
# }
# foo: {
#   key: 2
#   value: 1
# }

지원 중단됨: 대신 proto.encode_text(x)를 사용하세요.