對於每個 Label 執行個體 l,字串表示法 str(l) 都有 Label(str(l)) == l 屬性,無論 Label() 呼叫發生在何處。
成員
標籤
Label Label(input)
.bzl 來源檔案所在的套件中,將標籤字串轉換為 Label 物件。如果指定值已是 Label,則會原封不動地傳回。如果是巨集,相關函式 native.package_relative_label() 會在目前建構的套件環境中,將輸入內容轉換為 Label。使用該函式模擬標籤值規則屬性自動執行的字串到標籤轉換。
參數
| 參數 | 說明 |
|---|---|
input
|
string;或 Label;必要 輸入標籤字串或 Label 物件。如果傳遞的是 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
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"