Por que o Maven me avisa sobre a codificação?

94

Meu objetivo é criar um arquétipo a partir de um projeto.

Quando executo uma meta que não envolve o plugin maven-archetype, não consigo ver nenhum aviso:

[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ maven-archetype-base ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 1 resource
[INFO] 
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ maven-archetype-base ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 0 resource
[INFO]

Por outro lado, quando executo archetype: create-from-project, recebo alguns:

[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ maven-archetype-base-archetype ---
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] Copying 10 resources
[INFO] 
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ maven-archetype-base-archetype ---
[WARNING] Using platform encoding (Cp1252 actually) to copy filtered resources, i.e. build is platform dependent!
[INFO] Copying 2 resources

Eu sei que a maneira "padrão" do maven é usar a project.build.sourceEncodingpropriedade. Tentei adicionar mais algumas propriedades ao pom para resolver esse problema, mas nenhuma delas funcionou.

Alguma ideia? Obrigado.

Eu tenho o seguinte pom.xml:

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>my.group.id</groupId>
<artifactId>my-artifact</artifactId>
<version>0.0.1</version>
<packaging>maven-archetype</packaging>

<properties>

    <!-- Compiler properties -->
    <maven.compiler.target>1.7</maven.compiler.target>
    <maven.compiler.source>1.7</maven.compiler.source>
    <encoding>UTF-8</encoding>
    <project.build.sourceEncoding>${encoding}</project.build.sourceEncoding>
    <project.reporting.outputEncoding>${encoding}</project.reporting.outputEncoding>
    <project.resources.sourceEncoding>${encoding}</project.resources.sourceEncoding>
    <archetype.encoding>${encoding}</archetype.encoding>

    <!-- Maven plugins version -->
    <maven-archetype-plugin-version>2.2</maven-archetype-plugin-version>
    <maven-resources-plugin-version>2.6</maven-resources-plugin-version>

    <!-- Maven extentions version -->
    <maven-archetype-packaging-extension-version>2.2</maven-archetype-packaging-extension-version>
</properties>
<dependencies>
[...]
</dependencies>

<build>
    <extensions>
        <extension>
            <groupId>org.apache.maven.archetype</groupId>
            <artifactId>archetype-packaging</artifactId>
            <version>${maven-archetype-packaging-extension-version}</version>
        </extension>
    </extensions>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-resources-plugin</artifactId>
            <version>${maven-resources-plugin-version}</version>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-archetype-plugin</artifactId>
            <version>${maven-archetype-plugin-version}</version>
            <extensions>true</extensions>
        </plugin>

    </plugins>

    <resources>
        <resource>
            <directory>src/main/resources</directory>
            <filtering>true</filtering>
        </resource>
    </resources>
</build>

Marco ferrari
fonte

Respostas:

18

Quando você executa a meta archetype:create-from-project, o Maven gera um arquivo POM para construir o arquétipo target/generated-sources/archetype/pom.xmle, em seguida, executa a packagemeta (por padrão) neste POM.

O arquivo POM gerado não tem project.build.sourceEncodingnenhuma outra codificação de definição de propriedade e é por isso que você recebe o aviso.

O POM é gerada a partir deste protótipo por org.apache.maven.archetype.creator.FilesetArchetypeCreator#createArchetypeProjectPom, e para que o código não parece ser uma maneira de adicionar propriedades para o arquivo POM resultante.

izstas
fonte
140

Você não definiu a propriedade padrão de codificação desta forma:

<project>
  ...
  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  </properties>
  ...
</project>

Esta abordagem é melhor do que definir a codificação manualmente para cada plug-in, pois todos os plug-ins têm valores padrão para codificação, por exemplo, o maven-resources-plugin :

encoding:

The character encoding scheme to be applied when filtering resources.
Type: java.lang.String
Required: No
User Property: encoding
Default: ${project.build.sourceEncoding}

Portanto, isso significa que você só precisa definir essa propriedade e o plugin usará automaticamente essa codificação.

Khmarbaise
fonte
1
Eu armei. Olhe meu pom. Obrigado
Marco Ferrari de
1
Você pode remover as entradas nas configurações do plugin <encoding>${encoding}</encoding>.
khmarbaise
1
Está bem. Eu adicionei essas entradas para ver se isso resolveu o problema, mas sem sorte
Marco Ferrari
Não entendo por que o fallback está usando codificação de plataforma em vez de UTF-8. Suporte a legado?
msa
@msa porque nem todas as plataformas têm UTF-8 como padrão. Exemplo mais simples do Windows.
khmarbaise
33

Fiquei aborrecido ao ver que o maven continuou reclamando após a entrada acima

Então percebi que é o plug-in à prova de falhas e precisa de sua própria propriedade

Então aqui vai

<properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
</properties>
Kalpesh Soni
fonte