`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 소스 속성의 값을 제공합니다. 라이브러리가 소스가 없는 프록시 라이브러리인 경우 라이브러리에 이 라이브러리의 직접 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이 규칙과 모든 종속 프로토콜 버퍼 규칙의 Proto 소스입니다.