插入Java编译器

我有一个后编译步骤来操作生成的类的Java字节码。 我想让图书馆消费者尽可能轻松地生活,所以我正在研究如何使这个过程自动化,并且(如果可能的话)编译器不可知。

Annotation Processing API提供了许多所需的function(自动服务发现; Eclipse支持)。 不幸的是,这是针对代码生成器, 并不支持操作现有的文物 :

该工具的初始输入被认为是由第0轮创建的; 因此,尝试创建与其中一个输入相对应的源文件或类文件将导致FilerException。

API推荐的Decorator模式不是一个选项。

我可以看到如何使用运行时代理/检测执行该步骤,但这是一个比手动构建步骤更糟糕的选择,因为它需要任何人甚至可以通过API外围触摸来以非显而易见的方式配置其JVM。

有没有办法插入或包装javac调用的编译器工具 ? 有没有人成功地颠覆了注释处理器来操纵字节码,无论文档说什么?

Groovy编译器是唯一允许挂钩到编译过程的字节码编译器(例如: 生成字节码以支持Singleton模式 )

注释处理API并不意味着更改代码。 正如您已经发现的,您所能做的就是安装一个类加载器,在运行时检查字节码并对其进行操作。 这是脑死亡,但它的工作原理。 这是一般的“我们害怕开发人员可以尝试一些愚蠢的”主题,你将在整个Java中找到它。 没有办法扩展javac。 相关的类是私有的,最终的或将随着下一版本的Java而改变。

另一种选择是编写带注释的Java,例如编写一个类“ExampleTpl.java”。 然后,使用预编译器扩展该文件中的注释以获得“Example.java”。 在其余代码中,您使用Example并忽略ExampleTpl

对于Eclipse,有一个错误报告可以自动执行此步骤 。 我不知道这方面的任何其他工作。

可以办到。

在我们的Java中查看我的博客文章Roman Numerals,其中使用注释处理器来重写代码。 限制是它只适用于Sun的javac。