標籤

回報問題 查看原始碼 Nightly · 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

BUILD 目標 ID。

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

Label 以位置引數傳遞至 print()fail() 時,系統會改用字串表示法,以便人類讀取。這個表示法會盡可能從主要存放區的角度使用明顯的存放區名稱

成員

標籤

Label Label(input)

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

針對巨集,相關函式 native.package_relative_label() 會依照目前建構的套件內容,將輸入內容轉換為 Label。使用該函式模擬字串至標籤的轉換作業,這項作業會由標籤值規則屬性自動執行。

參數

參數 說明
input 字串Label; 必填
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
,以實驗性方式啟用此功能。當此方法與包含明顯存放區名稱的引數搭配使用時,會出現意想不到的行為。建議改用 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

Experimental。這個 API 仍在實驗階段,可能隨時變更。請勿依賴這項功能。您可以藉由設定 --+incompatible_enable_deprecated_label_apis
,以實驗性方式啟用此功能。欄位名稱「workspace name」在此處是個誤稱,請改用行為相同的 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"