Плагин Maven Aspectj снова вызывает генератор модели JPA

У меня есть проект Maven, в котором я создаю метамодель JPA с помощью генератора метамодели Hibernate.

<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>
    <parent>
        <groupId>xxx</groupId>
        <artifactId>xxx</artifactId>
        <version>1.0.0-SNAPSHOT</version>
    </parent>
    <artifactId>xxx</artifactId>
    <dependencies>
        <dependency>
            <groupId>org.hibernate.javax.persistence</groupId>
            <artifactId>hibernate-jpa-2.1-api</artifactId>
            <version>1.0.0.Final</version>
        </dependency>

        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
        </dependency>

        <dependency>
            <!-- needed for meta model generation (see also compiler plugin config) -->
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-jpamodelgen</artifactId>
            <version>4.3.8.Final</version>
        </dependency>
    </dependencies>
</project>

Компилятор AspectJ настроен в родительском проекте. Когда я запускаю Maven, подключаемый модуль компилятора Java вызывается первым и правильно генерирует исходники для target/generated-sources/generated-sources/annotations. Затем выполняется плагин AspectJ, который снова генерирует исходники, теперь уже в корневую папку моего проекта, и выдает следующие ошибки:

D:\xxx\git\xxx>mvn clean install
[INFO] Scanning for projects...
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building xxx 1.0.0-SNAPSHOT
[INFO] ------------------------------------------------------------------------
[INFO]
[INFO] --- maven-clean-plugin:2.5:clean (default-clean) @ xxx ---
[INFO] Deleting D:\...
[INFO]
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ xxx ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO]
[INFO] --- maven-compiler-plugin:3.2:compile (default-compile) @ xxx ---
[INFO] Changes detected - recompiling the module!
[INFO] Compiling 63 source files to D:\xxx\git\xxx\target\classes
[INFO]
[INFO] --- aspectj-maven-plugin:1.7:compile (default) @ xxx ---
[INFO] Showing AJC message detail for messages of types: [error, warning, fail]
[WARNING] Hibernate JPA 2 Static-Metamodel Generator 4.3.8.Final
        <unknown source file>:<no line information>

[ERROR] The type Category_ is already defined
        D:\xxx\git\xxx\Category_.java:10
public abstract class Category_ extends com.xxx.AbstractEntity_ {
                      ^^^^^^^^

[ERROR] The type Attachment_Message_ is already defined
         D:\xxx\git\xxx\Attachment_Message_.java:9
public abstract class Attachment_Message_ extends com.xxx.AbstractEntity_ {
                      ^^^^^^^^^^^^^^^^^^

[ERROR] The type AbstractNamedEntity_ is already defined
         D:\xxx\git\xxx\AbstractNamedEntity_.java:9
public abstract class AbstractNamedEntity_ extends com.xxx.AbstractEntity_ {

...

Как я могу помешать компилятору AspectJ выполнить генератор модели во второй раз?


person Jens Baitinger    schedule 19.01.2015    source источник
comment
Какую версию AspectJ вы используете? (Я не прошу версию aspectj-maven-plugin, потому что вижу, что это 1.7)   -  person Ralph    schedule 18.02.2015


Ответы (2)


Дело в том, что AspectJ 1.8.2 — это первая версия, включающая обработку аннотаций. Функция, вызывающая генерацию.

Есть два способа отключить генерацию:

  • 1) Обновите Maven-AspectJ-Plugin версии 1.8, у него есть новый параметр: proc, установите для него значение none, чтобы отключить генерацию. см. GitHub Issue #5,

    <plugin>
        <groupId>org.codehaus.mojo</groupId>
        <artifactId>aspectj-maven-plugin</artifactId>
        <version>1.8</version>
        ...
        <configuration>
            ...
           <proc>none</proc>
       </configuration>
    </plugin>
    

    or

  • 2) Еще одним «решением» будет использование AspectJ версии 1.8.1, но не 1.8.2+.

person Ralph    schedule 18.02.2015

Я исключил классы моделей из компилятора аспектов. Это отключает Аспекты для классов моделей (в настоящее время не нужны), а также двойное создание классов метамоделей:

<build>
    <plugins>
        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>aspectj-maven-plugin</artifactId>
            <configuration>
                <sources>
                    <source>
                        <basedir>src/main/java</basedir>
                        <excludes>
                            <exclude>**/domain/*</exclude>
                        </excludes>
                    </source>
                </sources>
            </configuration>
            <executions>
                <execution>
                    <goals>
                        <goal>compile</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>

    </plugins>
</build>
person Jens Baitinger    schedule 19.01.2015
comment
Это похоже на обходной путь, а не на решение, которое вы искали. Если вы все еще заинтересованы в решении, которое также будет работать, если вашим классам моделей потребуется переплетение аспектов, обновите свой вопрос и покажите фактический родительский POM. Я хотел бы понять, как и где компилятор вообще будет генерировать исходники (я не пользователь Hibernate). Как только я это сделаю, я смогу предложить решение. - person kriegaex; 19.01.2015
comment
На самом деле, это обходной путь, исключающий доменные классы из плетения (на самом деле в настоящее время нет аспектов, касающихся модельных классов). Генератор метамодели Hibernate (hibernate.org/orm/tooling) использует аннотации JPA и генерирует метаданные. модельные классы. Он работает как плагин к компилятору. Когда он находится в зависимостях, он генерирует классы. Я никогда не пытался понять, как это работает, но это может быть интересно узнать. - person Jens Baitinger; 20.01.2015
comment
Вы видели отчет об ошибке, в котором более подробно описана проблема здесь? Мои подсказки о параметрах AspectJ Maven Xset или argumentFileName могут привести к жизнеспособным обходным путям, но это всего лишь дикая догадка. Есть ли у вас SSCCE для проверки? - person kriegaex; 20.01.2015
comment
Отчет об ошибке теперь можно найти здесь: github.com/mojohaus/aspectj-maven- плагин/вопросы/5 - person HDave; 25.08.2015