ошибка компиляции maven: повторяющиеся классы - PullRequest
15 голосов
/ 19 мая 2009

В моем проекте maven2 у меня есть каталог ${basedir}/autogen, который содержит некоторые автоматически сгенерированные файлы исходного кода, созданные wsdl2java.

При запуске mvn compile я получаю ошибку компиляции из-за дублирующихся классов, которые живут в ${basedir}/autogen. Это правда. Но что делает фаза компиляции в ${basedir}/autogen? Я не сказал maven добавить этот каталог в качестве исходного каталога. И, похоже, нет способа сказать maven игнорировать каталог.

Ответы [ 8 ]

25 голосов
/ 19 сентября 2011

У меня была такая же проблема при использовании плагина maven-processor-plugin, и я обнаружил, что решение было настроить плагин maven-compiler следующим образом:

        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.1</version>
            <configuration>
                <source>1.6</source>
                <target>1.6</target>
                <compilerArgument>-proc:none</compilerArgument>
            </configuration>
        </plugin>

-proc: none означает, что компиляция происходит без обработки аннотации и, следовательно, нет повторяющихся классов (которые обычно создаются на этапе создания источников)

Надеюсь, это поможет.

4 голосов
/ 23 мая 2009

Я видел это несколько раз. Почти во всех случаях это происходит из-за того, что сгенерированные классы добавляются в основное дерево src, а затем проверяются в системе контроля версий.

1 голос
/ 12 июня 2018

У меня была точно такая же проблема. В моем случае проблема была в том, что я позвонил maven с -f=./pom.xml. Я понятия не имею, почему это приводит к другому результату (было бы хорошо, если бы кто-то мог объяснить), но, возможно, было бы полезно узнать, если у кого-то еще есть такая же проблема.

1 голос
/ 24 мая 2016

Я разрешаю это, убирая generateAsync из моего pom.xml, плагин GWT будет выглядеть так:

                <groupId>org.codehaus.mojo</groupId>
                <artifactId>gwt-maven-plugin</artifactId>
                <version>${gwtVersion}</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>compile</goal>
                            <goal>test</goal>
                            <!-- <goal>i18n</goal> -->

                        </goals>
                    </execution>
                </executions>
1 голос
/ 19 ноября 2010

У меня была похожая проблема с генератором моделей JPA. Это произошло по этой зависимости:

<dependency>
    <groupId>org.eclipse.persistence</groupId>
    <artifactId>org.eclipse.persistence.jpa.modelgen</artifactId>
    <version>2.1.1</version>
</dependency>

Я неправильно добавил сферу = предоставлено, и это привело к:

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:2.3.1:compile (default-compile) on project mocker: Compilation failure: Compilation failure:
[ERROR] \Projects\entity\MockVehicle_.java:[10,7] duplicate class: entity.MockVehicle_
0 голосов
/ 03 мая 2019

Мне мой случай помог в этом:

<!-- https://mvnrepository.com/artifact/javax.annotation/javax.annotation-api -->
<dependency>
    <groupId>javax.annotation</groupId>
    <artifactId>javax.annotation-api</artifactId>
    <version>1.3.2</version>
</dependency>
0 голосов
/ 01 апреля 2016

Я решаю ту же проблему

  1. Проект очистки Maven: - mvn clean
  2. удалить папку com из src, затем скомпилировать
  3. копировать com из сгенерированного в src-> main -> java
  4. снова скомпилировать

Надеюсь, что эта помощь ..

0 голосов
/ 19 мая 2009

Трудно изменить поведение maven по умолчанию, я думаю, что лучше пойти с ним - вы можете сгенерировать эти файлы с помощью maven wsdl2java-maven-plugin

...