标签:annotations xtend java android
我正在通过编写一个简单的“已记录”来尝试Xtend的活动注释
注释,用于在调用方法时进行跟踪.基本上我想用Xtend编写:
@Logged
override onCreate()
{
sampleFuncCall()
}
并在Java中获得如下内容:
@Override void onCreate()
{
Log.d("TAG", "onCreate started");
sampleFuncCall();
Log.d("TAG", "onCreate ended");
}
这是我的第一次尝试:
@Active(LoggedAnnotationProcessor)
@Target(ElementType.METHOD)
annotation Logged {
}
class LoggedAnnotationProcessor extends AbstractMethodProcessor
{
override doTransform(MutableMethodDeclaration method, extension TransformationContext context)
{
val prefix = "wrapped_"
method.declaringType.addMethod(prefix + method.simpleName) [ m |
m.static = method.static
m.visibility = Visibility.PRIVATE
m.docComment = method.docComment
m.exceptions = method.exceptions
method.parameters.forEach[ p | m.addParameter(p.simpleName, p.type) ]
m.body = method.body
m.primarySourceElement = method
m.returnType = method.returnType
]
val voidMethod = method.returnType === null || method.returnType.void
method.body = [ '''
try {
android.util.Log.d("TAG", "«method.simpleName» start");
«IF (!voidMethod) method.returnType» ret = «ENDIF»
«prefix + method.simpleName»(«method.parameters.map[simpleName].join(", ")»);
android.util.Log.d("TAG", "«method.simpleName» end");
«IF (!voidMethod)»return ret;«ENDIF»
}
catch(RuntimeException e) {
android.util.Log.d("TAG", "«method.simpleName» ended with exception "
+ e.getClass().getSimpleName() + "\n" + e.getMessage());
throw e;
}
''']
}
}
(请注意,我找不到修改method.body的方法,而不得不创建带有“ wrapped_”前缀的新私有方法.我想这对性能不利,因此,如果您知道如何直接修改方法的主体,请分享).
在处理返回void的方法时,我遇到了问题.
如果未明确声明该方法的返回类型,则会出现以下错误:
Cannot call method ‘isVoid’ on a inferred type reference before the
compilation phase. Check isInferred() before calling any methods.
好的,我可以添加对method.returnType.inferred的检查,但是要怎么做-似乎在这个阶段我们仍然不知道它是否将是无效的,但是知道这对于转发方法的关键返回值.
请告诉我编写这种注释的正确方法是什么,谢谢!
解决方法:
也许您应该推迟计算.到关闭
method.body = [
val voidMethod = method.returnType === null || method.returnType.void
'''
try {
android.util.Log.d("TAG", "«method.simpleName» start");
«IF (!voidMethod)»«method.returnType» ret = «ENDIF»
«prefix + method.simpleName»(«method.parameters.map[simpleName].join(", ")»);
android.util.Log.d("TAG", "«method.simpleName» end");
«IF (!voidMethod)»return ret;«ENDIF»
}
catch(RuntimeException e) {
android.util.Log.d("TAG", "«method.simpleName» ended with exception "
+ e.getClass().getSimpleName() + "\n" + e.getMessage());
throw e;
}
''']
标签:annotations,xtend,java,android 来源: https://codeday.me/bug/20191120/2041587.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。