Java 如何让AspectJ负载编织在Gradle上工作(特别是libgdx构建)

Java 如何让AspectJ负载编织在Gradle上工作(特别是libgdx构建),java,gradle,libgdx,aspectj,Java,Gradle,Libgdx,Aspectj,所以我想在我的libgdx游戏中注入一些测试和日志功能 因此,我在主桌面gradle依赖项中添加了以下内容 compile 'org.aspectj:aspectjweaver:1.8.2' compile "org.aspectj:aspectjrt:1.8.2" 起初它没有找到依赖项,但通过关闭脱机模式和关闭并重新打开IntelliJ项目(Gradle sync按钮不起作用)解决了这个问题 我的理解是aspectjweaver必须作为java代理加载。所以我找到了它出现的地

所以我想在我的libgdx游戏中注入一些测试和日志功能

因此,我在主桌面gradle依赖项中添加了以下内容

    compile 'org.aspectj:aspectjweaver:1.8.2'
    compile "org.aspectj:aspectjrt:1.8.2"
起初它没有找到依赖项,但通过关闭脱机模式和关闭并重新打开IntelliJ项目(Gradle sync按钮不起作用)解决了这个问题

我的理解是aspectjweaver必须作为java代理加载。所以我找到了它出现的地方,gradle下载了它,并在我的VM运行时配置选项中添加了以下内容

-javaagent:/Users/daniel/.gradle/caches/modules-2/files-2.1/org.aspectj/aspectjweaver/1.8.2/4963c0bef4748d5ad039cc26c1ac32a082eb755e/aspectjweaver-1.8.2.jar
令人惊讶的是,这给了我以下警告信息

objc[66447]: Class JavaLaunchHelper is implemented in both /Library/Java/JavaVirtualMachines/jdk1.8.0_05.jdk/Contents/Home/bin/java and /Library/Java/JavaVirtualMachines/jdk1.8.0_05.jdk/Contents/Home/jre/lib/libinstrument.dylib. One of the two will be used. Which one is undefined.
如果没有-javaagent行,则不存在该消息

我试着按照这个例子来做一个负载编织的例子。

但是,我不需要一个单独的可重用方面,因此我只是在src目录中创建了一个基本的aop.xml文件,其中包含以下内容

<aspectj>
    <weaver options="-verbose"/>
</aspectj>


…但不太熟悉教程中提到的iajc,知道如何在libgdx构建脚本中使用它似乎也很复杂。

我不会提供gradle实现,而是使用AspectJ提供Maven实现。显然,您必须定制/调整以满足您的需求。 下面是
bar.foo
方法的一个方面,该方法采用两个参数
(字符串,布尔值)
,带有
@环绕
建议和
处理连接点
。 显然,任何建议或切入点都可以实现

JAVA

@Aspect
@ajcPrivileged
public class MyAspect {
    @Pointcut("execution(* bar.foo(String, Boolean)) && args(string, bool)")
    void foo(String string, Boolean bool) {}

    @Around(value = "loadFile(filePathName, toGray)", argNames = "filePathName, toGray")
    public MyReturnType foo(final ProceedingJoinPoint joinPoint, final String string, final Boolean bool) throws MyEx {
        //impl
    }
}
POM

请参见Weave third party dependency comment以定义要编织的第三方库

<project ..>
    ..
    <properties>
        <aspectj-maven-plugin.version>1.7</aspectj-maven-plugin.version>
        <aspectjrt.version>1.8.2</aspectjrt.version>
        ..
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjrt</artifactId>
            <version>${aspectjrt.version}</version>
        </dependency>
        ..
    </dependencies>
    <build>
        ..
        <plugins>
            <plugin>
                <groupId>org.codehaus.mojo</groupId>
                <artifactId>aspectj-maven-plugin</artifactId>
                <version>${aspectj-maven-plugin.version}</version>
                <configuration>
                    <complianceLevel>${java.version}</complianceLevel>
                    <source>${java.version}</source>
                    <target>${java.version}</target>
                    <!-- Weave third party dependency -->
                    <weaveDependencies>
                        <weaveDependency>
                            <groupId>yourThirdPartyDepGroupId</groupId>
                            <artifactId>yourThirdPartyDepGroupIdArtifactId</artifactId>
                        </weaveDependency>
                    </weaveDependencies>
                </configuration>
                <!-- Weave on compile -->
                <executions>
                    <execution>
                        <goals>
                            <goal>compile</goal>
                            <goal>test-compile</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
        <pluginManagement>
            <plugins>
                <!--This plugin's configuration is used to store Eclipse m2e settings only. It has no influence on the Maven build itself.-->
                <plugin>
                    <groupId>org.eclipse.m2e</groupId>
                    <artifactId>lifecycle-mapping</artifactId>
                    <version>${lifecycle-mapping.version}</version>
                    <configuration>
                        <lifecycleMappingMetadata>
                            <pluginExecutions>
                                <pluginExecution>
                                    <pluginExecutionFilter>
                                        <groupId>org.codehaus.mojo</groupId>
                                        <artifactId>aspectj-maven-plugin</artifactId>
                                        <versionRange>[1.7,)</versionRange>
                                        <goals>
                                            <goal>compile</goal>
                                        </goals>
                                    </pluginExecutionFilter>
                                    <action>
                                        <ignore></ignore>
                                    </action>
                                </pluginExecution>
                            </pluginExecutions>
                        </lifecycleMappingMetadata>
                    </configuration>
                </plugin>
            </plugins>
        </pluginManagement>
    </build>
</project>

..
1.7
1.8.2
..
org.aspectj
aspectjrt
${aspectjrt.version}
..
..
org.codehaus.mojo
aspectj maven插件
${aspectj maven plugin.version}
${java.version}
${java.version}
${java.version}
您的第三方分组ID
您的第三方PGROUPIDARTIFACTID
编译
测试编译
org.eclipse.m2e
生命周期映射
${lifecycle mapping.version}
org.codehaus.mojo
aspectj maven插件
[1.7,)
编译

您能否在gradle中成功加载时间编织?