`load("@rules_proto//proto:defs.bzl", "ProtoInfo")` 를 사용하여 rules_proto에서 이 기호를 로드하세요.
구성원
- check_deps_sources
- direct_descriptor_set
- direct_sources
- proto_source_root
- to_json
- to_proto
- transitive_descriptor_sets
- transitive_imports
- transitive_proto_path
- transitive_sources
check_deps_sources
depset ProtoInfo.check_deps_sources'srcs' 속성의 Proto 소스. 라이브러리가 소스가 없는 프록시 라이브러리인 경우 이 라이브러리의 direct 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_rootproto_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이 규칙과 모든 종속 프로토콜 버퍼 규칙의 프로토 소스입니다.