Rótulo

Reportar um problema Ver código-fonte Nightly · 7.4 . 7.3 · 7.2 · 7.1 · 7.0 · 6.5

Um identificador de destino do BUILD.

Para cada instância Label l, a representação de string str(l) tem a propriedade Label(str(l)) == l, independentemente de onde a chamada Label() ocorre.

Membros

Rótulo

Label Label(input)

Converte uma string de rótulo em um objeto Label, no contexto do pacote em que o arquivo de origem .bzl de chamada está armazenado. Se o valor fornecido já for um Label, ele será retornado inalterado.

Para macros, uma função relacionada, native.package_relative_label(), converte a entrada em um Label no contexto do pacote que está sendo criado. Use essa função para imitar a conversão de string em rótulo, que é feita automaticamente por atributos de regras com valor de rótulo.

Parâmetros

Parâmetro Descrição
input string ou Label; obrigatório
A string do rótulo de entrada ou o objeto Label. Se um objeto Rótulo for passado, será retornado no estado em que se encontra.

nome

string Label.name

O nome desse rótulo no pacote. Por exemplo:
Label("//pkg/foo:abc").name == "abc"

pacote

string Label.package

A parte do pacote deste rótulo. Por exemplo:
Label("//pkg/foo:abc").package == "pkg/foo"

relativo

Label Label.relative(relName)

Resolve um rótulo absoluto (que começa com //) ou relativo ao pacote atual. Se esse rótulo estiver em um repositório remoto, o argumento será resolvido em relação a esse repositório. Se o argumento contiver um nome de repositório, o rótulo atual será ignorado e o argumento será retornado como está, exceto se o nome do repositório for substituído se ele estiver no mapeamento atual. Os rótulos reservados também são retornados como estão.
Por exemplo:
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")

Se o mapeamento do repositório transmitido for {'@other' : '@remapped'}, o seguinte remapeamento vai ocorrer:

Label("@repo//foo/bar:baz").relative("@other//wiz:quux") == Label("@remapped//wiz:quux")

Parâmetros

Parâmetro Descrição
relName required
O rótulo que será resolvido em relação a este.

workspace_name

string Label.workspace_name

A parte do repositório deste rótulo. Por exemplo:
Label("@foo//bar:baz").workspace_name == "foo"

workspace_root

string Label.workspace_root

Retorna a raiz de execução do espaço de trabalho deste rótulo, em relação a execroot. Por exemplo:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"