首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用AspectJ编译器而不是Javac进行编译时出错

使用AspectJ编译器而不是Javac进行编译时出错
EN

Stack Overflow用户
提问于 2014-06-13 21:34:33
回答 2查看 1.6K关注 0票数 15

我有一个多模块的项目。这个方面目前被添加到“核心”项目中。在这里执行mvn clean install时,它可以正常工作。但是,尝试在父项目上执行mvn clean install时会失败,并在编译其他项目之一时出现以下错误:

无法解析类型org.hibernate.annotations.CacheConcurrencyStrategy

。它是从所需的.class文件间接引用的

如果我在该项目中添加Hibernate核心依赖项,它也可以工作,但是将依赖项添加到不应该有依赖项的项目中是没有意义的-所以它不是一个解决方案。当使用javac编译时,它工作得很好。

原因何在?我如何修复它,以便可以使用AspectJ编译器,而不会泄漏对不应该具有依赖关系的项目?

我在父POM中有以下配置:

 <build>
    <plugins>
        <plugin>
            <groupId>org.codehaus.mojo</groupId>
            <artifactId>aspectj-maven-plugin</artifactId>
            <version>1.5</version>
            <configuration>
                <source>1.6</source>
                <target>1.6</target>
                <complianceLevel>1.6</complianceLevel>
            </configuration>
            <executions>
                <execution>
                    <goals>
                        <goal>compile</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

更新

我刚发现。每次运行mvn clean install都会失败。但是,运行一次mvn [clean] install会失败。然后在不使用clean的情况下运行mvn install。我看到目标文件夹中的builddef.lst是它工作和失败的原因,这取决于您是否干净地运行。所以现在我的问题是:如何自动生成此文件?

父POM-文件:

    <?xml version="1.0" encoding="UTF-8"?>
<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/maven-v4_0_0.xsd">

    <modelVersion>4.0.0</modelVersion>
    <groupId>com.mycompany</groupId>
    <artifactId>core-lib</artifactId>
    <name>core-lib</name>
    <packaging>pom</packaging>

    <build>
        <plugins>
            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>aspectj-maven-plugin</artifactId>
                <version>1.5</version>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                    <complianceLevel>1.6</complianceLevel>
                </configuration>
                <executions>
                    <execution>
                        <goals>
                            <goal>compile</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>

    <dependencies>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjrt</artifactId>
            <version>1.7.4</version>
        </dependency>
    </dependencies>

    <modules>
        <module>core-xyz</module>
        <module>core-xyz2</module>
    </modules>
</project>
EN

回答 2

Stack Overflow用户

发布于 2014-06-17 03:54:00

在maven调用上启用debug以深入挖掘。您应该注意到,aspectj编译器仅在第一次使用clean调用maven时被调用。由于builddef.lst在第一次调用后就已经存在,所以在不使用clean的情况下调用会跳过aspectj编译。

这个aspectj编译插件的行为之前已经被观察到了,并在这里进行了描述:

http://out-println.blogspot.com/2007/08/compile-time-checks-with-aspectj-part-2.html?m=1

您需要更深入地研究以解决底层问题,但正如一位评论者已经建议的那样,aspectj编译器应该只在需要它的模块中启用。

否则,正如您已经观察到的,aspectj编译需要额外的依赖项。我已经将aspectj编译合并到我自己的工作中,只将它限制在需要它的模块中,而没有问题。

票数 3
EN

Stack Overflow用户

发布于 2014-06-18 14:53:39

根据AspectJ compiler Maven plugin,您可以设置argumentFileName来定位现有的builddef.lst

因此,您可以生成builddef.lst并将其复制到您的资源文件夹,并指示AspectJ Maven插件使用该文件。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24206634

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档