标签

使用集合让一切井井有条 根据您的偏好保存内容并对其进行分类。
构建目标标识符。

成员

标签

Label Label(label_string)

创建引用构建目标的标签。如果您想要为规则的标签属性指定默认值,或者通过宏的绝对标签引用目标,请使用此函数。参数必须引用绝对标签。标签的代码库部分(或不存在)会在出现此 Label() 调用的代码库的上下文中解读。示例:
Label("//tools:default")

参数

参数 说明
label_string required
标签字符串。

名称

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 必需
将相对于此内容进行解析的标签。

工作区名称

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"