com.dragome.methodlogger.serverside.MethodLoggerAdapter Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of dragome-method-logger Show documentation
Show all versions of dragome-method-logger Show documentation
Dragome SDK module: method logger
/*
* Copyright (c) 2011-2014 Fernando Petrola
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.dragome.methodlogger.serverside;
import org.objectweb.asm.ClassVisitor;
import org.objectweb.asm.Label;
import org.objectweb.asm.MethodVisitor;
import org.objectweb.asm.Opcodes;
import org.objectweb.asm.commons.AdviceAdapter;
public class MethodLoggerAdapter extends ClassVisitor
{
private String className;
public MethodLoggerAdapter(ClassVisitor cv)
{
super(Opcodes.ASM5, cv);
}
@Override
public MethodVisitor visitMethod(int access, String name, String desc, String signature, String[] exceptions)
{
MethodVisitor mv;
mv= cv.visitMethod(access, name, desc, signature, exceptions);
mv= new MethodReturnAdapter(Opcodes.ASM5, className, access, name, desc, mv);
return mv;
}
public void visit(int version, int access, String name, String signature, String superName, String[] interfaces)
{
className= name;
super.visit(version, access, name, signature, superName, interfaces);
}
}
class MethodReturnAdapter extends AdviceAdapter
{
private String name;
private String owner;
protected Label l0;
public MethodReturnAdapter(int api, String owner, int access, String name, String desc, MethodVisitor mv)
{
super(Opcodes.ASM5, mv, access, name, desc);
this.owner= owner;
this.name= name;
}
public MethodReturnAdapter(MethodVisitor mv, int access, String name, String desc)
{
super(Opcodes.ASM5, mv, access, name, desc);
this.name= name;
}
protected void onMethodEnter()
{
if (!isStatic())
{
l0= new Label();
super.visitLabel(l0);
super.visitVarInsn(Opcodes.ALOAD, 0);
super.visitLdcInsn(name);
super.visitMethodInsn(Opcodes.INVOKESTATIC, "com/dragome/methodlogger/enhancers/MethodInvocationLogger", "onMethodEnter", "(Ljava/lang/Object;Ljava/lang/String;)V", false);
}
super.onMethodEnter();
}
public void visitLocalVariable(String name, String desc, String signature, Label start, Label end, int index)
{
if (!isStatic())
start= l0;
super.visitLocalVariable(name, desc, signature, start, end, index);
}
private boolean isStatic()
{
return (methodAccess & Opcodes.ACC_STATIC) != 0 || name.equals("");
}
protected void onMethodExit(int opcode)
{
if (!isStatic())
{
super.visitVarInsn(Opcodes.ALOAD, 0);
super.visitLdcInsn(name);
super.visitMethodInsn(Opcodes.INVOKESTATIC, "com/dragome/methodlogger/enhancers/MethodInvocationLogger", "onMethodExit", "(Ljava/lang/Object;Ljava/lang/String;)V", false);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy