Identificador

Um identificador de destino BUILD.

Participantes

Rótulo

Label Label(label_string)

Cria um rótulo que se refere a um destino BUILD. Use essa função quando quiser fornecer um valor padrão para os atributos de rótulo de uma regra ou ao se referir a um destino por meio de um rótulo absoluto de uma macro. O argumento precisa se referir a um rótulo absoluto. A parte "repositório" do rótulo (ou a ausência dela) é interpretada no contexto do repositório em que essa chamada Label() aparece. Exemplo:
Label("//tools:default")

Parâmetros

Parâmetro Descrição
label_string necessária
a string do rótulo.

name

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 nesse rótulo. Por exemplo:
Label("//pkg/foo:abc").package == "pkg/foo"

relative

Label Label.relative(relName)

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á, exceto que 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'}, vai 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.

workspace_name

string Label.workspace_name

A parte do repositório desse identificador. 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 desse rótulo, em relação ao execroot. Por exemplo:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"