我使用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
命令编译上述测试类,我只是得到版本警告而没有来自我的流程方法的消息。
答案 0 :(得分:1)
你是如何通过Maven调用javac的?我认为你需要启用调试日志记录(将-X
附加到你的Maven调用中)以便查看类型的诊断。注意。
您还可以使用编译器选项-XprintProcessorInfo
和-XprintRounds
来查看处理器是否启动。