成員
標籤
Label Label(label_string)建立參照 BUILD 目標的標籤。如果您想為規則的標籤屬性提供預設值,或是透過巨集的絕對標籤參照目標,請使用這個函式。引數必須參照絕對標籤。標籤的存放區部分 (或其不存在) 會從顯示這個 Label() 呼叫的存放區結構定義中進行解讀。範例:
Label("//tools:default")
參數
參數 | 說明 |
---|---|
label_string
|
必要 標籤字串。 |
名稱
string Label.name這個標籤在套件中的名稱。例如:
Label("//pkg/foo:abc").name == "abc"
套件
string Label.package這個標籤的套件部分。例如:
Label("//pkg/foo:abc").package == "pkg/foo"
relative
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"