ข้อมูลโปรโต

สรุปข้อมูลที่ได้รับจาก prod_library

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

check_deps_sources

depset ProtoInfo.check_deps_sources

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

direct_descriptor_set

File ProtoInfo.direct_descriptor_set

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

direct_sources

list ProtoInfo.direct_sources

แหล่งที่มาของ Proto จาก "srcs"

proto_source_root

string ProtoInfo.proto_source_root

ไดเรกทอรีที่สัมพันธ์กับไฟล์ .prod ที่ระบุไว้ใน protocol_library ได้รับการกำหนด ตัวอย่างเช่น หากนี่เป็น 'a/b' และกฎมีไฟล์ "a/b/c/d.protocol" เป็นแหล่งที่มา ไฟล์แหล่งที่มาดังกล่าวจะถูกนำเข้าเป็น "นำเข้า c/d.protocol"

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 อื่นๆ หรือ dicts หรือรายการในประเภทเหล่านี้ ระบบจะใช้อักขระหลีกกับเครื่องหมายคำพูดและบรรทัดใหม่ในสตริง คีย์โครงสร้างจะทำซ้ำตามลำดับที่จัดเรียง ตัวอย่าง:
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
# }

เลิกใช้งานแล้ว: ใช้ protocol.encode_text(x) แทน

transitive_descriptor_sets

depset ProtoInfo.transitive_descriptor_sets

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

transitive_imports

depset ProtoInfo.transitive_imports

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

transitive_proto_path

depset ProtoInfo.transitive_proto_path

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

transitive_sources

depset ProtoInfo.transitive_sources

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