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("@@foo//pkg/foo:abc").name == "abc"
包裹
string Label.package
Label("@@repo//pkg/foo:abc").package == "pkg/foo"
相對
Label Label.relative(relName)
--+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
--+incompatible_enable_deprecated_label_apis
,以實驗性方式啟用此功能。欄位名稱「工作區名稱」聽起來有錯的事請改用運作方式相同的
Label.repo_name
。包含這個標籤所參照目標的存放區標準名稱,不含任何前置符號 (@
)。舉例來說:
Label("@@foo//bar:baz").workspace_name == "foo"
workspace_root
string Label.workspace_root
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"