java – 检查注释处理器中是否缺少超类
发布时间:2020-12-15 00:59:25 所属栏目:Java 来源:网络整理
导读:在注释处理器中获取TypeElement时,可以使用方法getSuperClass()来请求其超类(或更具体地说,它的TypeMirror). According to the JavaDoc,一种不明确扩展任何东西的类型(换句话说,Object是超类)或者是一个接口将返回一个NONE作为TypeKind的NoType. 无视整个模
在注释处理器中获取TypeElement时,可以使用方法getSuperClass()来请求其超类(或更具体地说,它的TypeMirror).
According to the JavaDoc,一种不明确扩展任何东西的类型(换句话说,Object是超类)或者是一个接口将返回一个NONE作为TypeKind的NoType.
无视整个模型/镜像API事物似乎不顾一切地让您在每个机会中迷惑一下这一事实,我将如何可靠地检查这一点?这是一些代码提取: //Cast is safe since TypeKind is checked before this final TypeElement el = (TypeElement)annotatedElement; ... final TypeMirror parent = el.getSuperclass(); //Checking whether "nothing" is extended if(parent.getKind().equals(TypeKind.NONE) && parent instanceof NoType) { ... } 这是正确的方式吗?看起来相当笨重.由于 有没有更好的方法呢?整个javax.lang.model包及其子代在整个商店都有交叉引用,我从来都不清楚什么是最好的方法.对于某些东西有一些有用的实用方法,然后看似简单的任务需要如上所述的可疑杂技. 解决方法
我刚做了一个测试,发现我误解了文档.它为java.lang.Object和接口返回类型为NONE的NoType,而不是隐式扩展Object的内容.傻我.我不需要检查,因为较早的检查是否注释元素是严格意义上的类(不是枚举或接口),如果是,则返回.换句话说,检查规范名称是java.lang.Object还是使用Types.isSameType应该可以解决问题.
对不起,伙计们.我决定不删除,因为其他人可能会带着同样的问题到达.如果您认为合适,请随意投票删除. 编辑:这是我最终去的地方…… boolean superTypeValid = true; final TypeMirror parent = el.getSuperClass(); if(!parent.getKind().equals(TypeKind.DECLARED)) { messager.printMessage(Kind.ERROR,"May only inherit from a class; not enums,annotations or other declared kinds.",annotatedElement,mirror); superTypeValid = false; } else { final DeclaredType parentType = (DeclaredType)parent; final Element parentEl = parentType.asElement(); if(!parentEl.getKind().equals(ElementKind.CLASS)) { messager.printMessage(Kind.ERROR,mirror); superTypeValid = false; } } ... if(superTypeValid) { if(typeUtils.isSameType(parent,elUtils.getTypeElement("java.lang.Object").asType())) { messager.printMessage(Kind.ERROR,"Inherit must not be set to true if the class doesn't extend.",mirror); valid = false; } else { ... } } 如果其中一些错误消息看起来很奇怪,那是因为我留下了一些项目特定的东西. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读