标签

7.3 · 7.2 · 7.1 · 7.0 · 6.5

build 目标标识符。

对于每个 Label 实例 l,字符串表示法 str(l) 都具有 Label(str(l)) == l 属性,无论 Label() 调用发生在何处。

成员

标签

Label Label(input)

在调用 .bzl 源文件所在的软件包的上下文中,将标签字符串转换为 Label 对象。如果给定值已是 Label,则会原样返回。

对于宏,相关函数 native.package_relative_label() 会在当前构建的软件包上下文中将输入转换为 Label。使用该函数可模拟由标签值规则属性自动执行的字符串转换。

参数

参数 说明
input string;或 Label; required
输入标签字符串或标签对象。如果传递 Label 对象,系统会原封不动地将其返回。

name

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"