Proto정보

proto_library.

`load("@rules_proto//proto:defs.bzl", "ProtoInfo")` 를 사용하여 rules_proto에서 이 기호를 로드해 보세요.

회원

check_deps_sources

depset ProtoInfo.check_deps_sources

'srcs'의 Proto 소스 속성의 값을 제공합니다. 라이브러리가 소스가 없는 프록시 라이브러리인 경우 라이브러리에 이 라이브러리의 직접 deps에 있는 check_deps_sources가 포함됩니다.

direct_descriptor_set

File ProtoInfo.direct_descriptor_set

직접 소스의 FileDescriptorSet입니다. src가 없으면 빈 파일이 포함됩니다.

direct_sources

list ProtoInfo.direct_sources

'srcs'의 Proto 소스 속성의 값을 제공합니다.

proto_source_root

string ProtoInfo.proto_source_root

proto_library에 정의된 .proto 파일이 정의된 상대 디렉터리입니다. 예를 들어 'a/b'인 경우 규칙에 'a/b/c/d.proto' 파일이 포함되어 있습니다. 해당 파일을 'import c/d.proto'로 가져옵니다.

to_json

string ProtoInfo.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 ProtoInfo.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)를 사용하세요.

transitive_descriptor_sets

depset ProtoInfo.transitive_descriptor_sets

모든 종속 proto_library 규칙의 FileDescriptorSet 파일 집합 및 이 파일의 집합입니다. 이는 --include_imports를 proto-compiler에 전달하는 것과는 다릅니다. 종속 항목이 없으면 비어 있습니다.

transitive_imports

depset ProtoInfo.transitive_imports

약한 종속 항목을 포함한 임시 가져오기

transitive_proto_path

depset ProtoInfo.transitive_proto_path

이 규칙의 임시 폐쇄에서 수집된 proto 소스 루트의 집합입니다.

transitive_sources

depset ProtoInfo.transitive_sources

이 규칙과 모든 종속 프로토콜 버퍼 규칙의 Proto 소스입니다.