kanela.agent.api.advisor.AdviceExceptionHandler Maven / Gradle / Ivy
/*
* =========================================================================================
* Copyright © 2013-2021 the kamon project
*
* 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 kanela.agent.api.advisor;
import lombok.EqualsAndHashCode;
import lombok.Value;
import lombok.val;
import net.bytebuddy.asm.Advice;
import net.bytebuddy.implementation.Implementation;
import net.bytebuddy.implementation.bytecode.StackManipulation;
import net.bytebuddy.jar.asm.Label;
import net.bytebuddy.jar.asm.MethodVisitor;
import net.bytebuddy.jar.asm.Opcodes;
import static net.bytebuddy.jar.asm.Opcodes.*;
@Value
@EqualsAndHashCode(callSuper = false)
public class AdviceExceptionHandler extends Advice.ExceptionHandler.Simple {
private static final AdviceExceptionHandler Instance = new AdviceExceptionHandler(getStackManipulation());
private AdviceExceptionHandler(StackManipulation getStackForErrorManipulation) {
super(getStackForErrorManipulation);
}
public static AdviceExceptionHandler instance() {
return Instance;
}
/**
* Produces the following bytecode:
*
*
* } catch(Throwable throwable) {
* kanela.agent.bootstrap.log.LoggerHandler.error("An error occurred while trying to apply an advisor", throwable)
* }
*
*/
private static StackManipulation getStackManipulation() {
return new StackManipulation() {
@Override
public boolean isValid() {
return true;
}
@Override
public Size apply(MethodVisitor methodVisitor, Implementation.Context implementationContext) {
val endCatchBlock = new Label();
//message
methodVisitor.visitLdcInsn("An error occurred while trying to apply an advisor");
// logger, message, throwable => throwable, message, logger
methodVisitor.visitInsn(Opcodes.SWAP);
methodVisitor.visitMethodInsn(INVOKESTATIC, "kanela/agent/bootstrap/log/LoggerHandler", "error", "(Ljava/lang/String;Ljava/lang/Throwable;)V", false);
methodVisitor.visitJumpInsn(GOTO, endCatchBlock);
// ending catch block
methodVisitor.visitLabel(endCatchBlock);
methodVisitor.visitFrame(Opcodes.F_SAME, 0, null, 0, null);
return new StackManipulation.Size(-1, 1);
}
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy