Nhãn

Báo cáo vấn đề Xem nguồn Nightly · 8.4 · 8.3 · 8.2 · 8.1 · 8.0 · 7.6

Giá trị nhận dạng mục tiêu BUILD.

Đối với mọi thực thể Label l, biểu thức chuỗi str(l) có thuộc tính Label(str(l)) == l, bất kể lệnh gọi Label() xảy ra ở đâu.

Khi được truyền dưới dạng đối số vị trí đến print() hoặc fail(), Label sẽ sử dụng một chuỗi đại diện được tối ưu hoá để con người dễ đọc hơn. Biểu diễn này sử dụng tên kho lưu trữ rõ ràng theo góc độ của kho lưu trữ chính nếu có thể.

Hội viên

Hãng nhạc

Label Label(input)

Chuyển đổi một chuỗi nhãn thành đối tượng Label, trong bối cảnh của gói nơi tệp nguồn .bzl gọi tồn tại. Nếu giá trị đã cho là Label, thì giá trị đó sẽ được trả về mà không thay đổi.

Đối với macro, một hàm liên quan là native.package_relative_label() sẽ chuyển đổi dữ liệu đầu vào thành Label trong bối cảnh của gói hiện đang được tạo. Sử dụng hàm đó để mô phỏng quá trình chuyển đổi chuỗi thành nhãn được thực hiện tự động bằng các thuộc tính quy tắc có giá trị là nhãn.

Thông số

Thông số Mô tả
input string; hoặc Label; required
Chuỗi nhãn đầu vào hoặc đối tượng Nhãn. Nếu một đối tượng Nhãn được truyền, thì đối tượng đó sẽ được trả về nguyên trạng.

tên

string Label.name

Tên của đích đến mà nhãn này đề cập đến. Ví dụ:
Label("@@foo//pkg/foo:abc").name == "abc"

gói hàng

string Label.package

Tên của gói chứa mục tiêu mà nhãn này đề cập đến, không có tên kho lưu trữ. Ví dụ:
Label("@@repo//pkg/foo:abc").package == "pkg/foo"

có liên quan

Label Label.relative(relName)

Thử nghiệm. API này đang trong giai đoạn thử nghiệm và có thể thay đổi bất cứ lúc nào. Vui lòng không phụ thuộc vào thông tin này. Bạn có thể bật tính năng này theo cách thử nghiệm bằng cách đặt --+incompatible_enable_deprecated_label_apis
Không dùng nữa. Phương thức này hoạt động một cách đáng ngạc nhiên khi được dùng với một đối số chứa tên kho lưu trữ rõ ràng. Thay vào đó, hãy ưu tiên Label.same_package_label(), native.package_relative_label() hoặc Label().

Phân giải một nhãn tuyệt đối (bắt đầu bằng //) hoặc tương đối với gói hiện tại. Nếu nhãn này nằm trong một kho lưu trữ từ xa, thì đối số sẽ được phân giải tương ứng với kho lưu trữ đó. Nếu đối số chứa tên kho lưu trữ, thì nhãn hiện tại sẽ bị bỏ qua và đối số được trả về nguyên trạng, ngoại trừ việc tên kho lưu trữ được viết lại nếu tên đó nằm trong mối liên kết kho lưu trữ hiện tại. Các nhãn dành riêng cũng sẽ được trả về nguyên trạng.
Ví dụ:

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")

Nếu ánh xạ kho lưu trữ được truyền vào là {'@other' : '@remapped'}, thì quá trình ánh xạ lại sau đây sẽ diễn ra:

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

Thông số

Thông số Mô tả
relName string; required
Nhãn sẽ được phân giải tương ứng với nhãn này.

repo_name

string Label.repo_name

Tên chuẩn của kho lưu trữ chứa mục tiêu mà nhãn này đề cập đến, không có ký tự @ ở đầu (@). Ví dụ:
Label("@@foo//bar:baz").repo_name == "foo"

same_package_label

Label Label.same_package_label(target_name)

Tạo một nhãn trong cùng gói với nhãn này bằng tên đích đã cho.

Thông số

Thông số Mô tả
target_name string; required
Tên đích của nhãn mới.

workspace_name

string Label.workspace_name

Thử nghiệm. API này đang trong giai đoạn thử nghiệm và có thể thay đổi bất cứ lúc nào. Vui lòng không phụ thuộc vào thông tin này. Bạn có thể bật tính năng này theo cách thử nghiệm bằng cách đặt --+incompatible_enable_deprecated_label_apis
Không dùng nữa. Tên trường "tên vùng hoạt động" ở đây là một tên gọi sai; thay vào đó, hãy sử dụng Label.repo_name có hành vi tương tự.

Tên chuẩn của kho lưu trữ chứa mục tiêu mà nhãn này đề cập đến, không có ký tự @ ở đầu (@). Ví dụ:

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

workspace_root

string Label.workspace_root

Trả về thư mục gốc thực thi cho kho lưu trữ chứa mục tiêu mà nhãn này đề cập đến, tương ứng với execroot. Ví dụ:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"