APT и AOP в одном проекте, используя Maven - PullRequest
3 голосов
/ 07 сентября 2010

Я должен использовать Annotation Processing (apt) и AspectJ в одном и том же проекте Maven.

Оба работают для себя, но мне нужно создавать аспекты на основе кода, созданного apt.Поэтому мне понадобится бинарное плетение (исходные файлы расширены на apt).Как я могу включить бинарное плетение в проекте maven?

Я знаю, что единственная стандартная опция - это предоставление зависимости с помощью параметра weaveDependencies , но это ужасно.Есть ли другой способ?

Хорошо, я мог бы встроить Задачи AspectJ ant , используя Плагин Maven Antrun , но я бы не хотел прибегать к этому.

Ответы [ 2 ]

8 голосов
/ 08 сентября 2010

Я, видимо, единственный, кто может ответить на мои собственные вопросы.

Я прибег к компиляции AspectJ через ant с использованием Maven Antrun Plugin . Вот мой фрагмент кода:

<plugin>
    <artifactId>maven-antrun-plugin</artifactId>
    <version>1.4</version>
    <dependencies>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjtools</artifactId>
            <version>${aspectj.version}</version>
        </dependency>
    </dependencies>
    <executions>
        <execution>
            <id>ajc-compile</id>
            <phase>process-classes</phase>
            <configuration>
                <tasks>
                    <property name="aspectj.sourcepath"
                        value="${project.basedir}/src/main/aspect" />
                    <property name="aspectj.binarypath"
                        value="${project.build.outputDirectory}" />
                    <property name="aspectj.targetpath"
                        value="${project.build.directory}/aspectj-classes" />
                    <property name="scope_classpath" refid="maven.compile.classpath" />
                    <property name="plugin_classpath" refid="maven.plugin.classpath" />
                    <ant antfile="ajc-ant.xml" />
                </tasks>
            </configuration>
            <goals>
                <goal>run</goal>
            </goals>
        </execution>
        <execution>
            <id>ajc-test-compile</id>
            <phase>process-test-classes</phase>
            <configuration>
                <tasks unless="maven.test.skip">
                    <property name="aspectj.sourcepath"
                        value="${project.basedir}/src/test/aspect;${project.basedir}/src/main/aspect" />
                    <property name="aspectj.binarypath"
                        value="${project.build.testOutputDirectory}" />
                    <property name="aspectj.targetpath"
                        value="${project.build.directory}/aspectj-test-classes" />
                    <property name="scope_classpath" refid="maven.test.classpath" />
                    <property name="plugin_classpath" refid="maven.plugin.classpath" />
                    <ant antfile="ajc-ant.xml" />
                </tasks>
            </configuration>
            <goals>
                <goal>run</goal>
            </goals>
        </execution>
    </executions>
</plugin>

Сначала я скомпилирую java-классы (и пусть APT это сделает), использую скомпилированные классы в качестве двоичного ввода для aspectj, компилирую aspectj в новую папку и перемещаю получившиеся тканые классы в исходный каталог компиляции, переписывая non-aspectj классы. Вот мой муравей XML-файл (приятно то, что я могу использовать его как для компиляции, так и для тест-компиляции):

<project basedir="." default="ajc">
    <path id="classpath">
        <pathelement path="${scope_classpath}" />
        <pathelement path="${plugin_classpath}" />
    </path>
    <taskdef
        classname="org.aspectj.tools.ant.taskdefs.AjcTask"
        name="iajc" classpathref="classpath" />
    <target name="ajc">
        <iajc
            sourceroots="${aspectj.sourcepath}"
            inpath="${aspectj.binarypath}"
            destdir="${aspectj.targetpath}"
            classpathref="classpath"
            source="1.6"
            target="1.6"
        />
        <move todir="${aspectj.binarypath}">
            <fileset dir="${aspectj.targetpath}">
                <include name="**/*.class" />
            </fileset>
        </move>
    </target>
</project>

На следующем шаге я создал плагин Maven, который выполняет весь этот муравейный вызов внутри себя. Хотя я не могу поделиться здесь кодом, я покажу, как это упростило настройку POM:

<plugin>
    <groupId>com.myclient.maven.plugins</groupId>
    <artifactId>maven-ajc-plugin</artifactId>
    <version>1.0-SNAPSHOT</version>
    <executions>
        <execution>
            <id>compile-ajc</id>
            <goals>
                <goal>compile</goal>
            </goals>
        </execution>
        <execution>
            <id>testcompile-ajc</id>
            <goals>
                <goal>test-compile</goal>
            </goals>
            <configuration>
                <aspectSourcePath>${project.basedir}/src/main/aspect</aspectSourcePath>
            </configuration>
        </execution>
    </executions>
    <configuration>

    </configuration>
</plugin>

Используя ANT / GMaven интеграция , было легко собрать параметры, объединяющие возможности Maven, Groovy и Ant.

4 голосов
/ 07 мая 2013

Вдохновленный решением, предложенным выше Шоном Патриком Флойдом, я создал Плагин Maven , который делает все это из коробки:

<plugin>
  <groupId>com.jcabi</groupId>
  <artifactId>jcabi-maven-plugin</artifactId>
  <version>0.7.18</version>
  <executions>
    <execution>
      <goals>
        <goal>ajc</goal>
      </goals>
    </execution>
  </executions>
</plugin>

Документация по целям Mojo находится на com.jcabi:jcabi-maven-plugin:ajc странице использования.

...