使用注释处理器替换代码
我正在尝试编写一个注释处理器来在类上插入方法和字段...文档非常稀疏。我没有走远,我不知道我是否正确地接近了它。
处理环境提供了一个 Filer
对象,该对象具有用于创建新的源文件和类文件的便捷方法。这些工作正常,但后来我试图弄清楚如何读取现有的源文件,它提供的只是“getResource”。因此,在我的处理器实现中,我完成了此操作:
@Override
public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
try {
for (TypeElement te : annotations) {
for (Element element : roundEnv.getElementsAnnotatedWith(te)) {
FileObject in_file = processingEnv.getFiler().getResource(
StandardLocation.SOURCE_PATH, "",
element.asType().toString().replace(".", "/") + ".java");
FileObject out_file = processingEnv.getFiler().getResource(
StandardLocation.SOURCE_OUTPUT, "",
element.asType().toString().replace(".", "/") + ".java");
//if (out_file.getLastModified() >= in_file.getLastModified()) continue;
CharSequence data = in_file.getCharContent(false);
data = transform(data); // run the macro processor
JavaFileObject out_file2 = processingEnv.getFiler().createSourceFile(
element.asType().toString(), element);
Writer w = out_file2.openWriter();
w.append(data);
w.close();
}
}
} catch (Exception e) {
e.printStackTrace();
processingEnv.getMessager().printMessage(Diagnostic.Kind.ERROR, e.getMessage());
}
return true;
}
我的第一个困境是,我不禁觉得(获取限定的类型名称并将其转换为包和源文件路径)不是解决问题的好方法。API的其余部分过于复杂,但似乎没有一种方便的方法来检索原始源代码。element.asType().toString().replace(".", "/") + ".java"
真正的问题是,然后编译器被输出目录中的第二个源文件(“error:duplicate class”)自发地弄乱,现在我被困住了。
我已经写了剩下的部分 - 一个宏词法分析器和解析器,以及用于计算一些数据和插入字段值和方法的东西 - 但它作为编译器外部的初始步骤运行。除了原始文件不能具有.java扩展名(以防止编译器看到它们)之外,这工作得很好。然后我听说注释可以进行代码生成,我认为这会更合适,更方便,但我找不到太多的指导。