Participantes
BootClassPathInfo
Provider java_common.BootClassPathInfoO provedor usado para fornecer as informações de bootclasspath
compile
struct java_common.compile(ctx, *, source_jars=[], source_files=[], output, output_source_jar=None, javac_opts=[], deps=[], runtime_deps=[], exports=[], plugins=[], exported_plugins=[], native_libraries=[], annotation_processor_additional_inputs=[], annotation_processor_additional_outputs=[], strict_deps='ERROR', java_toolchain, bootclasspath=None, host_javabase=None, sourcepath=[], resources=[], resource_jars=[], classpath_resources=[], neverlink=False, enable_annotation_processing=True, enable_compile_jar_action=True, add_exports=[], add_opens=[])Compila arquivos/jars de origem Java da implementação de uma regra Starlark e retorna um provedor que representa os resultados da compilação e pode ser adicionado ao conjunto de provedores emitidos por essa regra.
Parâmetros
Parâmetro | Descrição |
---|---|
ctx
|
obrigatório O contexto da regra. |
source_jars
|
sequência de Files. O padrão é [] Uma lista dos jars a serem compilados. Pelo menos um dos source_jars ou source_files deve ser especificado. |
source_files
|
sequência de Files. O padrão é [] .Uma lista dos arquivos de origem Java a serem compilados. Pelo menos um dos source_jars ou source_files deve ser especificado. |
output
|
obrigatório |
output_source_jar
|
File ou None . O padrão é None . O jar de origem de saída. Opcional. Se não for definido, o padrão será `{output_jar}-src.jar`. |
javac_opts
|
sequência de strings. O padrão é [] .Uma lista das opções javac desejadas. Opcional. |
deps
|
sequência de structs. O padrão é [] .Uma lista de dependências. Opcional. |
runtime_deps
|
sequência de structs. O padrão é [] . Uma lista de dependências de ambiente de execução. Opcional. |
exports
|
sequência de structs. O padrão é [] . Uma lista de exportações. Opcional. |
plugins
|
sequência de structs ou sequência de structs. O padrão é [] . Uma lista de plug-ins. Opcional. |
exported_plugins
|
sequência de structs ou sequência de structs. O padrão é [] . Uma lista de plug-ins exportados. Opcional. |
native_libraries
|
sequência de CcInfos. O padrão é [] CC para dependências da biblioteca nativa que são necessárias para essa biblioteca. |
annotation_processor_additional_inputs
|
sequência de Files. O padrão é [] .Uma lista de entradas que a ação de compilação em Java usará, além das fontes Java para o processamento de anotações. |
annotation_processor_additional_outputs
|
Sequence de Files; o padrão é [] Uma lista de saídas que a ação de compilação Java produzirá, além do jar da classe do processamento de anotações. |
strict_deps
|
o padrão é 'ERROR' Uma string que especifica como processar dependências rigorosas. Valores possíveis: 'OFF', 'ERROR', 'WARN' e 'DEFAULT'. Para mais detalhes, consulte /docs/user-manual#flag--strict_java_deps. Por padrão, "ERROR". |
java_toolchain
|
necessário Uma JavaToolchainInfo para ser usada nesta compilação. Obrigatório. |
bootclasspath
|
o padrão é None Um BootClassPathInfo a ser usado nesta compilação. Se estiver presente, substitui o bootclasspath associado ao java_dataset fornecido. Opcional. |
host_javabase
|
o padrão é None Descontinuado. Este parâmetro foi descontinuado e será removido em breve. Não dependa disso. Ela está desativada com o --+incompatible_java_common_parameters . Use essa sinalização para verificar se seu código é compatível com a remoção iminente. Descontinuado: você pode descartar esse parâmetro (o host_javabase é fornecido com java_dataset). |
sourcepath
|
sequência de Files. O padrão é [] |
resources
|
sequência de Files. O padrão é [] |
resource_jars
|
sequência de Files. O padrão é [] |
classpath_resources
|
sequência de Files. O padrão é [] |
neverlink
|
o padrão é False |
enable_annotation_processing
|
O padrão é True Desativa o processamento de anotações nessa compilação, fazendo com que todos os processadores de anotações fornecidos em plug-ins ou emexport_plugins de dependências sejam ignorados. |
enable_compile_jar_action
|
o padrão é True Ativa a compilação de cabeçalho ou a criação do ijar. Se definida como falsa, ela forçará o uso do jar de classe completo nos caminhos de classe de compilação de todos os dependentes. Essa ação é destinada ao uso por destinos que não são de biblioteca, como binários que não têm dependentes. |
add_exports
|
sequência de strings. O padrão é [] .Permite que essa biblioteca acesse o |
add_opens
|
sequência de strings. O padrão é [] .Permite que essa biblioteca acesse de forma reflexiva o |
JavaRuntimeInfo
Provider java_common.JavaRuntimeInfoChave usada para recuperar o provedor que contém informações sobre o ambiente de execução Java que está sendo usado.
JavaToolchainInfo
Provider java_common.JavaToolchainInfoA chave usada para recuperar o provedor que contém informações sobre o conjunto de ferramentas Java que está sendo usado.
merge
struct java_common.merge(providers)Mescla os provedores fornecidos em um único JavaInfo.
Parâmetros
Parâmetro | Descrição |
---|---|
providers
|
Sequence de structs;
obrigatório A lista de provedores a serem mesclados. |
pack_sources
File java_common.pack_sources(actions, *, output_jar=None, output_source_jar=None, sources=[], source_jars=[], java_toolchain, host_javabase=None)Empacota fontes e jars de origem em um único arquivo jar de origem. O valor de retorno normalmente é passado para
JavaInfo#source_jar
Parâmetros
Parâmetro | Descrição |
---|---|
actions
|
obrigatório ctx.actions |
output_jar
|
File ou None ;
o padrão é None Descontinuado. Este parâmetro foi descontinuado e será removido em breve. Não dependa disso. Ela está desativada com o --+incompatible_java_common_parameters . Use essa sinalização para verificar se seu código é compatível com a remoção iminente. Descontinuado: o jar de saída da regra. Usado para nomear o jar de origem resultante. O parâmetro define o parâmetro output_source_jar como `{output_jar}-src.jar`.Use o parâmetro output_source_jar diretamente. |
output_source_jar
|
File ou None . O padrão é None . O jar de origem de saída. |
sources
|
sequência de Files. O padrão é [] .Uma lista de arquivos de origem Java a serem compactados no jar de origem. |
source_jars
|
Sequence de Files.
O padrão é [] Uma lista de jars de origem a serem empacotados no jar de origem. |
java_toolchain
|
necessário Uma JavaToolchainInfo a ser usada para encontrar a ferramenta ijar. |
host_javabase
|
o padrão é None Descontinuado. Este parâmetro foi descontinuado e será removido em breve. Não dependa disso. Ela está desativada com o --+incompatible_java_common_parameters . Use essa sinalização para verificar se seu código é compatível com a remoção iminente. Descontinuado: você pode descartar esse parâmetro (o host_javabase é fornecido com java_dataset). |
run_ijar
File java_common.run_ijar(actions, *, jar, target_label=None, java_toolchain)Executa o ijar em um pote, tirando-o do corpo do método. Isso ajuda a reduzir a recompilação de jars dependentes durante qualquer recompilação que consiste apenas em mudanças simples nas implementações do método. O valor de retorno normalmente é transmitido para
JavaInfo#compile_jar
.
Parâmetros
Parâmetro | Descrição |
---|---|
actions
|
obrigatório ctx.actions |
jar
|
necessário O jar em que o ijar será executado. |
target_label
|
Label ou None (o padrão é None ) Um rótulo de destino para carimbar o jar. Usado para suporte a add_dep . Normalmente, você transmite ctx.label para marcar o jar com o rótulo da regra atual.
|
java_toolchain
|
necessário Uma JavaToolchainInfo a ser usada para encontrar a ferramenta ijar. |
stamp_jar
File java_common.stamp_jar(actions, *, jar, target_label, java_toolchain)Carrega um jar com um rótulo de destino para oferecer suporte a
add_dep
. O valor de retorno normalmente é transmitido para JavaInfo#compile_jar
. Prefira usar run_ijar
sempre que possível
Parâmetros
Parâmetro | Descrição |
---|---|
actions
|
obrigatório ctx.actions |
jar
|
necessário O jar em que o stamp_jar será executado. |
target_label
|
necessário Um rótulo de destino para carimbar o jar. Usado para suporte a add_dep . Normalmente, você transmite ctx.label para marcar o jar com o rótulo da regra atual.
|
java_toolchain
|
necessário Uma JavaToolchainInfo a ser usada para encontrar a ferramenta stamp_jar. |