ป้ายกำกับ

วันที่ รายงานปัญหา ดูแหล่งที่มา ตอนกลางคืน · 7.3 · 7.2 · 7.1 · 7.0 · 6.5

ตัวระบุเป้าหมายของ BUILD

สำหรับทุกๆ อินสแตนซ์ Label l ตัวแทนสตริง str(l) จะมีพร็อพเพอร์ตี้ที่ Label(str(l)) == l ไม่ว่าการเรียก Label() จะเกิดขึ้นที่ใด

สมาชิก

ป้ายกำกับ

Label Label(input)

แปลงสตริงป้ายกำกับเป็นออบเจ็กต์ Label ในบริบทของแพ็กเกจที่มีไฟล์ต้นฉบับการเรียกใช้ .bzl หากค่าที่ระบุเป็น Label อยู่แล้ว จะส่งกลับโดยไม่เปลี่ยนแปลง

สำหรับมาโคร native.package_relative_label() ซึ่งเป็นฟังก์ชันที่เกี่ยวข้องจะแปลงอินพุตเป็น Label ในบริบทของแพ็กเกจที่กำลังสร้างอยู่ ใช้ฟังก์ชันดังกล่าวเพื่อเลียนแบบการแปลงสตริงเป็นป้ายกำกับที่ดำเนินการโดยแอตทริบิวต์กฎที่มีค่าป้ายกำกับโดยอัตโนมัติ

พารามิเตอร์

พารามิเตอร์ คำอธิบาย
input string; หรือ ป้ายกำกับ จำเป็น
สตริงป้ายกำกับอินพุตหรือออบเจ็กต์ป้ายกำกับ หากมีการส่งผ่านออบเจ็กต์ป้ายกำกับ จะส่งกลับตามที่เป็น

ชื่อ

string Label.name

ชื่อของป้ายกำกับนี้ภายในแพ็กเกจ ตัวอย่างเช่น:
Label("//pkg/foo:abc").name == "abc"

พัสดุ

string Label.package

ส่วนแพ็กเกจของป้ายกำกับนี้ ตัวอย่างเช่น:
Label("//pkg/foo:abc").package == "pkg/foo"

ที่เกี่ยวข้อง

Label Label.relative(relName)

แก้ป้ายกำกับที่เป็นค่าสัมบูรณ์ (ขึ้นต้นด้วย //) หรือสัมพันธ์กับแพ็กเกจปัจจุบัน หากป้ายกำกับนี้อยู่ในที่เก็บระยะไกล อาร์กิวเมนต์จะได้รับการแก้ไขที่เกี่ยวข้องกับที่เก็บนั้น หากอาร์กิวเมนต์มีชื่อที่เก็บ ระบบจะไม่สนใจป้ายกำกับปัจจุบันและระบบจะแสดงผลอาร์กิวเมนต์ตามที่เป็นอยู่ ยกเว้นว่าชื่อที่เก็บจะถูกเขียนใหม่หากอยู่ในการแมปที่เก็บปัจจุบัน ป้ายกำกับที่สงวนไว้ก็จะแสดงเหมือนเดิมด้วย
ตัวอย่างเช่น
Label("//foo/bar:baz").relative(":quux") == Label("//foo/bar:quux")
Label("//foo/bar:baz").relative("//wiz:quux") == Label("//wiz:quux")
Label("@repo//foo/bar:baz").relative("//wiz:quux") == Label("@repo//wiz:quux")
Label("@repo//foo/bar:baz").relative("//visibility:public") == Label("//visibility:public")
Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@other//wiz:quux")

หากมีการส่งการแมปที่เก็บคือ {'@other' : '@remapped'} ระบบจะรีแมปต่อไปนี้

Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@remapped//wiz:quux")

พารามิเตอร์

พารามิเตอร์ คำอธิบาย
relName ต้องระบุ
ป้ายกำกับที่จะแก้ปัญหาที่เกี่ยวข้องกับรายการนี้

workspace_name

string Label.workspace_name

ส่วนที่เก็บของป้ายกำกับนี้ ตัวอย่างเช่น
Label("@foo//bar:baz").workspace_name == "foo"

workspace_root

string Label.workspace_root

แสดงผลรูทการดำเนินการสำหรับพื้นที่ทำงานของป้ายกำกับนี้ ซึ่งสัมพันธ์กับ execroot ตัวอย่างเช่น:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"