สำหรับอินสแตนซ์ Label ทุกรายการ l การแสดงสตริง str(l) มีพร็อพเพอร์ตี้ที่ Label(str(l)) == l ไม่ว่าการเรียก Label() จะเกิดขึ้นที่ใดก็ตาม
เมื่อส่งเป็นอาร์กิวเมนต์ตำแหน่งไปยัง print() หรือ fail() Label จะใช้การแสดงสตริงที่เพิ่มประสิทธิภาพเพื่อให้อ่านได้ง่ายแทน การแสดงนี้ใช้ชื่อที่เก็บที่เห็นจากมุมมองของที่เก็บหลักหากเป็นไปได้
สมาชิก
ป้ายกำกับ
Label Label(input)
Label ในบริบทของแพ็กเกจที่มีไฟล์ต้นฉบับ .bzl ที่เรียกใช้ หากค่าที่ระบุเป็น Label อยู่แล้ว ระบบจะแสดงผลค่าดังกล่าวโดยไม่มีการเปลี่ยนแปลงสำหรับมาโคร ฟังก์ชันที่เกี่ยวข้องอย่าง native.package_relative_label() จะแปลงอินพุตเป็น Label ในบริบทของแพ็กเกจที่กำลังสร้าง ใช้ฟังก์ชันดังกล่าวเพื่อจำลองการแปลงสตริงเป็นป้ายกำกับซึ่งแอตทริบิวต์กฎที่มีค่าป้ายกำกับจะดำเนินการโดยอัตโนมัติ
พารามิเตอร์
| พารามิเตอร์ | คำอธิบาย |
|---|---|
input
|
สตริงหรือป้ายกำกับ
ต้องระบุ สตริงป้ายกำกับอินพุตหรือออบเจ็กต์ป้ายกำกับ หากมีการส่งออบเจ็กต์ป้ายกำกับ ระบบจะแสดงผลออบเจ็กต์ดังกล่าวตามที่ส่ง |
ชื่อ
string Label.name
Label("@@foo//pkg/foo:abc").name == "abc"พัสดุ
string Label.package
Label("@@repo//pkg/foo:abc").package == "pkg/foo"ที่เกี่ยวข้อง
Label Label.relative(relName)
--+incompatible_enable_deprecated_label_apis เลิกใช้งานแล้ว วิธีนี้จะทำงานอย่างน่าประหลาดใจเมื่อใช้กับอาร์กิวเมนต์ที่มีชื่อที่ชัดเจนของที่เก็บ โปรดใช้
Label.same_package_label(), native.package_relative_label() หรือ Label() แทนแก้ไขป้ายกำกับที่เป็นแบบสัมบูรณ์ (ขึ้นต้นด้วย //) หรือสัมพันธ์กับแพ็กเกจปัจจุบัน หากป้ายกำกับนี้อยู่ในที่เก็บข้อมูลระยะไกล ระบบจะแก้ไขอาร์กิวเมนต์ที่เกี่ยวข้องกับที่เก็บข้อมูลนั้น หากอาร์กิวเมนต์มีชื่อที่เก็บ ระบบจะไม่สนใจป้ายกำกับปัจจุบันและจะแสดงอาร์กิวเมนต์ตามเดิม ยกเว้นในกรณีที่ชื่อที่เก็บมีการเขียนใหม่หากอยู่ในการแมปที่เก็บปัจจุบัน ระบบจะแสดงป้ายกำกับที่สงวนไว้ตามเดิมด้วย
เช่น
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
|
สตริง
ต้องระบุ ป้ายกำกับที่จะได้รับการแก้ไขที่เกี่ยวข้องกับป้ายกำกับนี้ |
repo_name
string Label.repo_name
@) เช่น Label("@@foo//bar:baz").repo_name == "foo"same_package_label
Label Label.same_package_label(target_name)
พารามิเตอร์
| พารามิเตอร์ | คำอธิบาย |
|---|---|
target_name
|
สตริง
ต้องระบุ ชื่อเป้าหมายของป้ายกำกับใหม่ |
workspace_name
string Label.workspace_name
--+incompatible_enable_deprecated_label_apis เลิกใช้งานแล้ว ชื่อฟิลด์ "ชื่อพื้นที่ทำงาน" ไม่ถูกต้องในที่นี้ ให้ใช้
Label.repo_name ที่ทำงานเหมือนกันแทนชื่อที่แน่นอนของที่เก็บที่มีเป้าหมายซึ่งป้ายกำกับนี้อ้างอิงถึง โดยไม่มีเครื่องหมาย @ นำหน้า (@) เช่น
Label("@@foo//bar:baz").workspace_name == "foo"workspace_root
string Label.workspace_root
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"