Запуск AspectJ вызывает NoSuchMethodError: Aspect.aspectOf

У меня есть очень простой аспект AspectJ (с использованием @AspectJ), который просто распечатывает сообщение журнала. Моя цель состоит в том, чтобы советовать код в моем приложении для Android. Теперь этот аспект работает отлично, пока у меня есть исходный класс приложения в моем исходном коде.Как только я перемещаю аспект в другой модуль (либо java -> .jar, либо android lib -> .aar), я получаю следующее исключение во время выполнения при запуске рекомендованного кода в моем приложении:

java.lang.NoSuchMethodError: com.xxx.xxx.TraceAspect.aspectOf

В основном моя структура такова:

Root
 + app (com.android.application)
   - MainActivity (with annotation to be adviced)
 + library (android-library)
   - TraceAspect (aspect definition)

Из компилятора ajc я вижу, что компилятор ajc выбирает мои классы и правильно их советует, поэтому я действительно не знаю, почему он работает, если у меня есть класс @AspectJ в моем исходном коде, но он перестает работать после перемещения это к банке архива.

Я использую Gradle. Buildscript для моего приложения очень прост. Я следовал инструкциям вhttp://fernandocejas.com/2014/08/03/aspect-oriented-programming-in-android/

import com.android.build.gradle.LibraryPlugin
import org.aspectj.bridge.IMessage
import org.aspectj.bridge.MessageHandler
import org.aspectj.tools.ajc.Main

buildscript {
  repositories {
    mavenCentral()
  }
  dependencies {
    classpath 'com.android.tools.build:gradle:0.12.+'
    classpath 'org.aspectj:aspectjtools:1.8.1'
  }
}

apply plugin: 'com.android.application'

repositories {
  mavenCentral()
}

dependencies {
  compile 'org.aspectj:aspectjrt:1.8.1'
  compile project (':library')
}


android.applicationVariants.all { variant ->
    AppPlugin plugin = project.plugins.getPlugin(AppPlugin)
    JavaCompile javaCompile = variant.javaCompile
    javaCompile.doLast {
        String[] args = ["-showWeaveInfo",
                         "-1.5",
                         "-XnoInline",
                         "-inpath", javaCompile.destinationDir.toString(),
                         "-aspectpath", javaCompile.classpath.asPath,
                         "-d", javaCompile.destinationDir.toString(),
                         "-classpath", javaCompile.classpath.asPath,
                         "-bootclasspath", plugin.project.android.bootClasspath.join(File.pathSeparator)]

        MessageHandler handler = new MessageHandler(true);
        new Main().run(args, handler)

        def log = project.logger
        for (IMessage message : handler.getMessages(null, true)) {
            switch (message.getKind()) {
                case IMessage.ABORT:
                case IMessage.ERROR:
                case IMessage.FAIL:
                    log.error message.message, message.thrown
                    break;
                case IMessage.WARNING:
                    log.warn message.message, message.thrown
                    break;
                case IMessage.INFO:
                    log.info message.message, message.thrown
                    break;
                case IMessage.DEBUG:
                    log.debug message.message, message.thrown
                    break;
            }
        }
    }
}

Не уверен, если важно, но на всякий случай, код моего аспекта:

@Aspect
public class TraceAspect {
  private static final String POINTCUT_METHOD = "execution(@com.xxx.TraceAspect * *(..))";

  @Pointcut(POINTCUT_METHOD)
  public void annotatedMethod() {}

  @Around("annotatedMethod()")
  public Object weaveJoinPoint(ProceedingJoinPoint joinPoint) throws Throwable {
    System.out.println("Aspect works...");
    return joinPoint.proceed();
  }
}

Classpath

Я также проверилjavaCompile.classPath и он правильно содержит какlibrary-classes.jar и мойapp-classes.jar, Добавление-log file кajc Задачи также показывают, что файлы правильно сплетены.

Есть идеи?

Минимальный пример для воспроизведения этой проблемы

https://github.com/fschoellhammer/test-aspectj

Ответы на вопрос(2)

Ваш ответ на вопрос