第一篇只是介绍了bytex,及其相关的一些知识.本文将更详细地介绍,基于bytex项目开发插件,深入插件的源码
经过前几篇文章的内容介绍,相信已经了解了asm的基本操作与bytex插件开发了.
选建立一个简单的日志插件
MethodTracePlugin
@PluginConfig("bytex.method_trace")
class MethodTracePlugin : CommonPlugin<MethodTraceExtension, MethodTraceContext>() {
override fun getContext(
project: Project,
android: AppExtension,
extension: MethodTraceExtension
): MethodTraceContext {
return MethodTraceContext(project, android, extension)
}
override fun transform(relativePath: String, chain: ClassVisitorChain): Boolean {
//这里连接上
chain.connect(MethodTraceVisitor(context))
return super.transform(relativePath, chain)
}
}
到了主角visitMethod方法了
var mv: MethodVisitor
mv = super.visitMethod(access, name, desc, signature, exceptions)
if ("hello" == name || "hello2" == name) {
val sb = StringBuilder();
sb.append("name:").append(name)
.append(" desc;").append(desc);
mv.visitFieldInsn(
Opcodes.GETSTATIC,
"java/lang/System",
"out",
"Ljava/io/PrintStream;"
);
mv.visitLdcInsn("-------trace-------$sb");
mv.visitMethodInsn(
Opcodes.INVOKEVIRTUAL,
"java/io/PrintStream",
"println",
"(Ljava/lang/String;)V",
false
);
context.logger.i("MethodTraceVisitor", "----插桩----className: $desc methodName: ${name}------")
}
return mv
在这里,把前面两篇文章的内容用上.就可以了.
先运行插件的uploadArchives.再运行项目的assembleDebug,结果输出在example/build/下面看到日志