기본 정보

문제 신고 소스 보기 Nightly · 7.4 .

타겟의 직접 및 전이 파일에 관한 일반적인 정보를 제공하는 제공자입니다. 규칙의 구현 함수에 의해 명시적으로 반환되지 않더라도 모든 규칙 유형에 이 제공자가 있습니다. 각 DefaultInfo 인스턴스에는 다음 필드가 있습니다.

  • files
  • files_to_run
  • data_runfiles
  • default_runfiles
이 제공업체를 사용하는 방법에 관한 자세한 가이드는 규칙 페이지를 참고하세요.

회원

DefaultInfo

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

DefaultInfo 생성자

매개변수

매개변수 설명
files depset 또는 None. 기본값은 None입니다.
이 대상이 bazel 명령줄에서 지정되면 빌드할 기본 출력을 나타내는 File 객체의 depset입니다. 기본적으로 모든 사전 선언된 출력입니다.
runfiles runfiles 또는 None. 기본값은 None
이며 run 명령어를 통해 또는 도구 종속 항목으로 실행할 때 이 타겟에 필요한 파일을 설명하는 None
실행 파일 설명자입니다.
data_runfiles runfiles 또는 None(기본값: None)

이 매개변수는 사용하지 않는 것이 좋습니다('사용하지 않는 runfiles 기능' 참고).

data 속성을 통해 종속 항목일 때 이 타겟이 실행해야 하는 실행 파일을 설명하는 runfiles 설명자.
default_runfiles runfiles 또는 None(기본값: None)

이 매개변수는 사용하지 않는 것이 좋습니다('사용하지 않는 runfiles 기능' 참고).

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

data_runfiles

runfiles DefaultInfo.data_runfiles

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

default_runfiles

runfiles DefaultInfo.default_runfiles

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

파일

depset DefaultInfo.files

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

files_to_run

FilesToRunProvider DefaultInfo.files_to_run

타겟의 실행 파일과 실행 파일에 관한 정보가 포함된 FilesToRunProvider 객체. None을 반환할 수 있습니다.

to_json

string DefaultInfo.to_json()

지원 중단되었습니다. 이 API는 지원 중단되었으며 곧 삭제됩니다. 이 방법을 사용하지 마세요. ---incompatible_struct_has_no_methods를 사용하면 사용 중지됩니다. 이 플래그를 사용하여 코드가 예정된 삭제와 호환되는지 확인합니다.
구조체 매개변수에서 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를 사용하면 사용 중지됩니다. 이 플래그를 사용하여 코드가 곧 삭제되는 것과 호환되는지 확인합니다.
구조체 매개변수에서 텍스트 메시지를 만듭니다. 이 메서드는 모든 구조체 요소가 (재귀적으로) 문자열, 정수, 불리언, 다른 구조체 또는 이러한 유형의 사전 또는 목록인 경우에만 작동합니다. 문자열의 따옴표와 새 줄은 이스케이프 처리됩니다. 구조체 키는 정렬된 순서로 반복됩니다. 예를 들면 다음과 같습니다.
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)를 사용하세요.