Membros
Rótulo
Label Label(label_string)Cria um rótulo que se refere a um destino do BUILD. Use essa função quando quiser atribuir um valor padrão aos atributos de rótulo de uma regra ou ao se referir a um destino usando um rótulo absoluto de uma macro. O argumento precisa se referir a um rótulo absoluto. A parte do repositório do rótulo (ou a ausência dele) é interpretada no contexto do repositório em que a chamada Label() aparece. Exemplo:
Label("//tools:default")
Parâmetros
Parâmetro | Descrição |
---|---|
label_string
|
required a string do rótulo. |
nome
string Label.nameO nome desse rótulo no pacote. Por exemplo:
Label("//pkg/foo:abc").name == "abc"
pacote
string Label.packageA 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 o rótulo estiver em um repositório remoto, o argumento será resolvido em relação a ele. 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_nameA parte do repositório deste rótulo. Por exemplo,
Label("@foo//bar:baz").workspace_name == "foo"
workspace_root
string Label.workspace_rootRetorna a raiz de execução para o espaço de trabalho deste rótulo, em relação a execroot. Por exemplo:
Label("@repo//pkg/foo:abc").workspace_root == "external/repo"