ป้ายกำกับ

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

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

เมื่อส่งผ่านเป็นอาร์กิวเมนต์ตำแหน่งไปยัง print() หรือ fail() Label จะใช้การแสดงสตริงที่ปรับให้เหมาะกับการอ่านของมนุษย์แทน การแสดงนี้จะใช้ชื่อที่เก็บที่เห็นได้ชัดจากมุมมองของที่เก็บหลักหากเป็นไปได้

สมาชิก

ป้ายกำกับ

Label Label(input)

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

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

พารามิเตอร์

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

name

string Label.name

ชื่อของเป้าหมายที่ป้ายกำกับนี้อ้างถึง เช่น
Label("@@foo//pkg/foo:abc").name == "abc"

package

string Label.package

ชื่อของแพ็กเกจที่มีเป้าหมายที่ป้ายกำกับนี้อ้างถึง โดยไม่มีชื่อที่เก็บ เช่น
Label("@@repo//pkg/foo:abc").package == "pkg/foo"

relative

Label Label.relative(relName)

ทดลอง API นี้ยังอยู่ในขั้นทดลองและอาจมีการเปลี่ยนแปลงได้ทุกเมื่อ โปรดอย่าใช้ API นี้ คุณอาจเปิดใช้ API นี้ในระดับทดลองได้โดยตั้งค่า --+incompatible_enable_deprecated_label_apis
เลิกใช้งานแล้ว เมธอดนี้จะทำงานอย่างไม่คาดคิดเมื่อใช้กับอาร์กิวเมนต์ที่มีชื่อที่เก็บที่เห็นได้ชัด โปรดใช้ Label.same_package_label(), native.package_relative_label(), ctx.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

ชื่อ Canonical ของที่เก็บที่มีเป้าหมายที่ป้ายกำกับนี้อ้างถึง โดยไม่มีเครื่องหมายแอด (@) นำหน้า เช่น
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

ทดลอง API นี้ยังอยู่ในขั้นทดลองและอาจมีการเปลี่ยนแปลงได้ทุกเมื่อ โปรดอย่าใช้ API นี้ คุณอาจเปิดใช้ API นี้ในระดับทดลองได้โดยตั้งค่า --+incompatible_enable_deprecated_label_apis
เลิกใช้งานแล้ว ชื่อฟิลด์ "ชื่อเวิร์กสเปซ" เป็นชื่อที่ไม่ถูกต้องในที่นี้ โปรดใช้ Label.repo_name แทน ซึ่งทำงานเหมือนกัน

ชื่อ Canonical ของที่เก็บที่มีเป้าหมายที่ป้ายกำกับนี้อ้างถึง โดยไม่มีเครื่องหมายแอด (@) นำหน้า เช่น

Label("@@foo//bar:baz").workspace_name == "foo"

workspace_root

string Label.workspace_root

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