標籤

回報問題 敬上 查看原始碼 。 。 。 。 夜間7.37.2 。 。 7.17.06.5

BUILD 目標 ID。

對於每個 Label 例項 l,無論 Label() 呼叫發生位置為何,代表 str(l) 字串的字串都具有 Label(str(l)) == l 屬性。

成員

標籤

Label Label(input)

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

針對巨集,相關函式 native.package_relative_label() 會依照目前建構的套件內容,將輸入內容轉換為 Label。此時,您可以使用該函式,模仿由標籤值規則屬性自動完成的字串與標籤轉換。

參數

參數 說明
input string;或標籤; 必要
輸入標籤字串或標籤物件。如果傳遞 Label 物件,系統會依原樣傳回該物件。

名稱

string Label.name

套件中此標籤的名稱。例如:
Label("//pkg/foo:abc").name == "abc"

包裹

string Label.package

這個標籤的套件部分。例如:
Label("//pkg/foo:abc").package == "pkg/foo"

相對

Label Label.relative(relName)

解析絕對 (開頭為 //) 或相對於目前套件的標籤。如果這個標籤位於遠端存放區,系統會根據該存放區解析引數。如果引數包含存放區名稱,系統會忽略目前的標籤並依原樣傳回引數,但假如存放區名稱位於目前存放區對應中,則會改寫。保留的標籤也會依原樣傳回。
例如:
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 必要
要按照這個標籤解析的標籤。

workspace_name

string Label.workspace_name

這個標籤的存放區部分。舉例來說,
Label("@foo//bar:baz").workspace_name == "foo"

workspace_root

string Label.workspace_root

傳回這個標籤相對於 execroot 的工作區的執行根目錄。例如:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"