网上关于基于lombok源码生成注解的方式资料比较少,这里记录一下lombok源码扩展生成自定义注解的开发过程。
需求
重构至springCloud体系开发时,为了规范接口和方便客户端调用,避免接口文档交付的繁杂流程,计划由provider另起工程定义api接口(RequestMapping等注解)和AO、VO之后,再实现接口的方式进行服务端开发,consumer直接引入api工程,即可调用服务。可是部分consumer并不在微服务体系内,并有自己的sdk请求注解,所以打算使用lombok方式,扫描RequestMapping等spring注解,加入相对应的自定义sdk注解。这样服务端只需要写自己需要的RequestMapping等spring注解,编译后自动加上其他sdk的自定义注解,达到一边定义两边使用的效果。
步骤
- 引入lombok源码:https://github.com/rzwitserloot/lombok ,执行ant的compile 和intellij (忘了。。)。
- 为了识别spring注解需要引入注解包。将spring-web-4.1.9.RELEASE.jar 包放入lib目录,右键add as library。
- src.core.lombok.javac.handlers里加入自定义注解。
@ProviderFor(JavacAnnotationHandler.class)
public class HandleRequestMapping extends JavacAnnotationHandler<RequestMapping> {
@Override
public void handle(AnnotationValues<RequestMapping> annotation, JCAnnotation ast, JavacNode type) {
//获取maker,节点创建必须由相应node的getTreeMaker方法返回的maker创建
JavacTreeMaker maker = type.getTreeMaker();
//定义JCModifiers,装载注解标志处的JCModifiers,从里面获取注解
JCTree.JCModifiers mods;
//判断节点类型,类或者方法
if (type.up().get() instanceof JCMethodDecl) {
mods = (