ข้อมูลโปรโต

สรุปข้อมูลจาก proto_library

โปรดพิจารณาใช้ "load("@rules_proto//proto:defs.bzl", "ProtoInfo")` เพื่อโหลดสัญลักษณ์นี้จาก rules_proto

สมาชิก

check_deps_sources

depset ProtoInfo.check_deps_sources

แหล่งที่มาของ Proto จากแอตทริบิวต์ "srcs" หากไลบรารีเป็นไลบรารีพร็อกซีที่ไม่มีแหล่งที่มา จะมี check_deps_sources จาก Dep โดยตรงของไลบรารีนี้

direct_descriptor_set

File ProtoInfo.direct_descriptor_set

FileDescriptorSet ของแหล่งที่มาโดยตรง หากไม่มี srcs แสดงว่าไฟล์ว่างเปล่า

direct_sources

list ProtoInfo.direct_sources

แหล่งที่มาของ Proto จากแอตทริบิวต์ "srcs"

proto_source_root

string ProtoInfo.proto_source_root

ไดเรกทอรีที่เกี่ยวข้องกับไฟล์ .proto ที่กำหนดไว้ใน proto_library ตัวอย่างเช่น หากเป็น "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 เมธอดนี้จะใช้งานได้ก็ต่อเมื่อองค์ประกอบ Struct ทั้งหมด (แสดงซ้ำๆ) เป็นสตริง, ints, บูลีน, Struct อื่นๆ รายการประเภทเหล่านี้ หรือพจนานุกรมที่มีคีย์สตริงและค่าประเภทดังกล่าว เครื่องหมายคำพูดและบรรทัดใหม่ในสตริงจะใช้อักขระหลีก ตัวอย่าง:
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) แทน ซึ่งใช้ได้กับค่าอื่นๆ ที่ไม่ใช่ Struct และไม่ทำให้เนมสเปซของช่อง Struct เสียหาย

to_proto

string ProtoInfo.to_proto()

เลิกใช้งานแล้ว API นี้เลิกใช้งานแล้วและจะถูกนำออกเร็วๆ นี้ โปรดอย่าพึ่งพาสิ่งนี้ ถูกปิดใช้กับ ---incompatible_struct_has_no_methods ใช้แฟล็กนี้เพื่อยืนยันว่าโค้ดเข้ากันได้กับการนําออกที่กำลังจะเกิดขึ้น
สร้าง SMS จากพารามิเตอร์ Struct วิธีการนี้จะใช้งานได้ก็ต่อเมื่อองค์ประกอบ Struct ทั้งหมด (แบบเรียกซ้ำ) เป็นสตริง, ints, บูลีน, Struct หรือคำสั่งอื่นๆ หรือรายการประเภทเหล่านี้ เครื่องหมายคำพูดและบรรทัดใหม่ในสตริงจะใช้อักขระหลีก คีย์โครงสร้างจะทำซ้ำตามลำดับที่จัดเรียง ตัวอย่าง:
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

ชุดของไฟล์ FileDescriptorSet ของกฎ proto_library ทั้งหมดที่อ้างอิงกันทั้งหมด และเป็นของอันนี้ ซึ่งไม่เหมือนกับการส่ง --include_imports ไปยัง proto-Composer จะว่างเปล่าหากไม่มีทรัพยากร Dependency

transitive_imports

depset ProtoInfo.transitive_imports

การนำเข้าทางอ้อมรวมถึงทรัพยากร Dependency ที่อ่อน

transitive_proto_path

depset ProtoInfo.transitive_proto_path

ชุดรากต้นทางของ Proto ที่รวบรวมจากการปิดแบบสับเปลี่ยนของกฎนี้

transitive_sources

depset ProtoInfo.transitive_sources

แหล่งที่มาของ Proto สำหรับกฎนี้และกฎบัฟเฟอร์โปรโตคอลที่เกี่ยวข้องทั้งหมด