BUILD 目標 ID。
對於每個 Label
例項 l
,無論 Label()
呼叫發生在何處,字串表示法 str(l)
都會具有 Label(str(l)) == l
屬性。
當 Label
以位置引數傳遞至 print()
或 fail()
時,會改用針對人類可讀性最佳化的字串表示法。這個表示法會盡可能從主要存放區的角度使用明顯的存放區名稱。
成員
標籤
Label Label(input)在呼叫
.bzl
來源檔案所在的套件內容中,將標籤字串轉換為 Label
物件。如果指定的值已是 Label
,則會以原樣傳回。針對巨集,相關函式 native.package_relative_label()
會將輸入內容轉換為目前正在建構的套件內容中的 Label
。使用該函式模擬字串至標籤的轉換作業,這項作業會由標籤值規則屬性自動執行。
參數
參數 | 說明 |
---|---|
input
|
字串或 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)Experimental。這個 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
|
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_nameExperimental。這個 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"