build 目标标识符。
对于每个 Label
实例 l
,字符串表示法 str(l)
具有 Label(str(l)) == l
属性,无论 Label()
调用发生在何处。
成员
标签
Label Label(input)在调用
.bzl
源文件所在的软件包的上下文中,将标签字符串转换为 Label
对象。如果指定的值已经是 Label
,则原样返回。对于宏,相关函数 native.package_relative_label()
会在当前正在构建的软件包的上下文中将输入转换为 Label
。使用该函数可模拟由标签值规则属性自动完成的字符串到标签转换。
参数
参数 | 说明 |
---|---|
input
|
string;或标签;
必需 输入标签字符串或标签对象。如果传递了 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"