Identificador

Informar um problema Acessar fonte

Um identificador de destino BUILD.

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

Participantes

Identificador

Label Label(input)

Converte uma string de rótulo em um objeto Label no contexto do pacote em que reside o arquivo de origem .bzl de chamada. Se o valor informado já for um Label, ele vai ser retornado sem mudanças.

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 feita automaticamente pelos 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 "Label" for passado, ele será retornado no estado em que se encontra.

name

string Label.name

O nome do destino referenciado por este rótulo. Por exemplo:
Label("@@foo//pkg/foo:abc").name == "abc"

pacote

string Label.package

O nome do pacote que contém o destino mencionado por este marcador, sem o nome do repositório. Por exemplo:
Label("@@repo//pkg/foo:abc").package == "pkg/foo"

relative

Label Label.relative(relName)

Experimental. Essa API é experimental e pode mudar a qualquer momento. Não dependa disso. Ela pode ser ativada de forma experimental ao definir --+incompatible_enable_deprecated_label_apis como
Descontinuado. Esse método se comporta de maneira surpreendente quando usado com um argumento que contém um nome de repositório aparente. Use Label.same_package_label(), native.package_relative_label() ou Label().

Resolve um rótulo que é absoluto (começa com //) ou relativo ao pacote atual. Se esse marcador 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á. No entanto, o nome do repositório será reescrito se estiver no mapeamento do repositório atual. Os rótulos reservados também serão retornados no estado em que se encontram.
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'}, ocorrerá o seguinte remapeamento:

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

Parâmetros

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

repo_name

string Label.repo_name

O nome canônico do repositório que contém o destino referido por este rótulo, sem nenhum arroba no início (@). Por exemplo,
Label("@@foo//bar:baz").repo_name == "foo"
.

same_package_label

Label Label.same_package_label(target_name)

Cria um rótulo no mesmo pacote com o nome de destino especificado.

Parâmetros

Parâmetro Descrição
target_name obrigatório
O nome do destino do novo rótulo.

workspace_name

string Label.workspace_name

Experimental. Essa API é experimental e pode mudar a qualquer momento. Não dependa disso. Ela pode ser ativada de forma experimental ao definir --+incompatible_enable_deprecated_label_apis como
Descontinuado. O nome do campo "nome do espaço de trabalho" não está correto. Use Label.repo_name, que tem um comportamento idêntico.

O nome canônico do repositório que contém o destino referido por este rótulo, sem nenhum arroba no início (@). Por exemplo,

Label("@@foo//bar:baz").workspace_name == "foo"
.

workspace_root

string Label.workspace_root

Retorna a raiz de execução do repositório que contém o destino referido por este rótulo, em relação ao execroot. Por exemplo:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"