自定义注释处理器 - Java

时间:2016-10-13 20:31:05

标签: java annotations annotation-processing

我使用Abstract Processor创建了一个自定义注释和注释处理器。这意味着我想在编译之前进行注释处理。 我将自定义注释和处理器导出为Jar并尝试将其与简单的java测试程序一起使用。 我确信在编译时它会找到我的java处理器类但不知何故我没有得到我期望在控制台上的o / p。 下面是我处理器中处理方法的代码。

另外,我故意使用@SupportedSourceVersion(SourceVersion.RELEASE_6)以便我得到一个版本警告,确认当我执行测试类时它会找到我的注释处理器。

这是我的完整项目的GitHub link,它还包含我创建的打包Jar。

public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
    // TODO Auto-generated method stub

    processingEnv.getMessager().printMessage(Kind.NOTE, "Hello compile time message");

    for (Element elem : roundEnv.getElementsAnnotatedWith(Contract.class)) {
        if(elem.getKind() != ElementKind.METHOD)
        {
            processingEnv.getMessager().printMessage(Kind.NOTE, "Error");
            return true;
        }

        System.out.println("Hello ... Inside for ");
        Contract contract = elem.getAnnotation(Contract.class);
        String message = "annotation found in " + elem.getSimpleName()
                       + " with complexity " + contract.pre_cond();
        processingEnv.getMessager().printMessage(Kind.NOTE, message);
    }
    return true; // no further processing of this annotation type
}  

以下是我正在使用的测试类

import annotations.Contract;

public class AnnotationTest {


public AnnotationTest()
{
    super();
}

@Contract(pre_cond = { "var > 0" })
public static void testMethod(int var)
{
    System.out.println("hello1");
}

public static void main(String args[])
{
    testMethod(1);
    System.out.println("hello");
}

我正在使用javac -cp newcontractlib.jar AnnotationTest.java命令编译上述测试类,我只是得到版本警告而没有来自我的流程方法的消息。

1 个答案:

答案 0 :(得分:1)

你是如何通过Maven调用javac的?我认为你需要启用调试日志记录(将-X附加到你的Maven调用中)以便查看类型的诊断。注意。

您还可以使用编译器选项-XprintProcessorInfo-XprintRounds来查看处理器是否启动。