標籤

回報問題 查看來源 Nightly · 8.4 · 8.3 · 8.2 · 8.1 · 8.0 · 7.6

BUILD 目標 ID。

對於每個 Label 執行個體 l,字串表示法 str(l) 都有 Label(str(l)) == l 屬性,無論 Label() 呼叫發生在何處。

當做位置引數傳遞至 print()fail() 時,Label 請改用經過最佳化處理的字串表示法,方便使用者閱讀。如果可以,這個表示法會從主要存放區的角度使用顯示的存放區名稱

成員

標籤

Label Label(input)

在呼叫 .bzl 來源檔案所在的套件中,將標籤字串轉換為 Label 物件。如果指定值已是 Label,則會原封不動地傳回。

如果是巨集,相關函式 native.package_relative_label() 會在目前建構的套件環境中,將輸入內容轉換為 Label。使用該函式模擬標籤值規則屬性自動執行的字串到標籤轉換。

參數

參數 說明
input string;或 Label;必要
輸入標籤字串或 Label 物件。如果傳遞的是 Label 物件,則會原封不動地傳回該物件。

名稱

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)

實驗功能。這項 API 仍在實驗階段,因此隨時可能變更。因此請勿依賴這項功能。您可以設定 --+incompatible_enable_deprecated_label_apis
Deprecated.,以實驗性質啟用這項功能。如果搭配包含明顯存放區名稱的引數使用,這個方法會出現令人意外的行為。請改用 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 string;必要
相對於這個標籤解析的標籤。

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 string;必要
新標籤的目標名稱。

workspace_name

string Label.workspace_name

實驗功能。這項 API 仍在實驗階段,因此隨時可能變更。因此請勿依賴這項功能。您可以設定 --+incompatible_enable_deprecated_label_apis
Deprecated.,以實驗性質啟用這項功能。此處的欄位名稱「工作區名稱」是誤稱,請改用行為相同的 Label.repo_name

這個標籤所參照目標的存放區標準名稱,開頭不含任何「@」符號 (@)。舉例來說,

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

workspace_root

string Label.workspace_root

傳回存放區的執行根目錄,其中包含這個標籤參照的目標,相對於 execroot。例如:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"