From 9d7dd030e8cb8985a4a645546236532674ca346c Mon Sep 17 00:00:00 2001 From: Sanne Grinovero Date: Mon, 22 Apr 2024 22:20:27 +0100 Subject: [PATCH] VertxCoreProcessor and HibernateValidatorProcessor bytecode transformers are safe to be cached --- .../HibernateValidatorProcessor.java | 51 ++++--- .../core/deployment/VertxCoreProcessor.java | 140 +++++++++--------- 2 files changed, 102 insertions(+), 89 deletions(-) diff --git a/extensions/hibernate-validator/deployment/src/main/java/io/quarkus/hibernate/validator/deployment/HibernateValidatorProcessor.java b/extensions/hibernate-validator/deployment/src/main/java/io/quarkus/hibernate/validator/deployment/HibernateValidatorProcessor.java index 67a6731423239..a2be59f4ba30f 100644 --- a/extensions/hibernate-validator/deployment/src/main/java/io/quarkus/hibernate/validator/deployment/HibernateValidatorProcessor.java +++ b/extensions/hibernate-validator/deployment/src/main/java/io/quarkus/hibernate/validator/deployment/HibernateValidatorProcessor.java @@ -566,32 +566,37 @@ void exceptionMapper(BuildProducer exceptionMapperProd // from Arc @BuildStep void overrideStandardValidationFactoryResolution(BuildProducer transformer) { - BytecodeTransformerBuildItem transformation = new BytecodeTransformerBuildItem(Validation.class.getName(), - (className, classVisitor) -> new ClassVisitor(Gizmo.ASM_API_VERSION, classVisitor) { - @Override - public MethodVisitor visitMethod(int access, String name, String descriptor, String signature, - String[] exceptions) { - MethodVisitor visitor = super.visitMethod(access, name, descriptor, signature, exceptions); - - if (name.equals("buildDefaultValidatorFactory")) { - return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { - @Override - public void visitCode() { - super.visitCode(); - visitMethodInsn(Opcodes.INVOKESTATIC, - ValidationSupport.class.getName().replace(".", "/"), - "buildDefaultValidatorFactory", - String.format("()L%s;", ValidatorFactory.class.getName().replace(".", "/")), false); - visitInsn(Opcodes.ARETURN); + BytecodeTransformerBuildItem transformation = new BytecodeTransformerBuildItem.Builder() + .setClassToTransform(Validation.class.getName()) + .setCacheable(true) + .setVisitorFunction( + (className, classVisitor) -> new ClassVisitor(Gizmo.ASM_API_VERSION, classVisitor) { + @Override + public MethodVisitor visitMethod(int access, String name, String descriptor, String signature, + String[] exceptions) { + MethodVisitor visitor = super.visitMethod(access, name, descriptor, signature, exceptions); + + if (name.equals("buildDefaultValidatorFactory")) { + return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { + @Override + public void visitCode() { + super.visitCode(); + visitMethodInsn(Opcodes.INVOKESTATIC, + ValidationSupport.class.getName().replace('.', '/'), + "buildDefaultValidatorFactory", + String.format("()L%s;", ValidatorFactory.class.getName().replace('.', '/')), + false); + visitInsn(Opcodes.ARETURN); + } + }; } - }; - } - // TODO: should intercept the other methods and throw an exception to indicate they are unsupported? + // TODO: should intercept the other methods and throw an exception to indicate they are unsupported? - return visitor; - } - }); + return visitor; + } + }) + .build(); transformer.produce(transformation); } diff --git a/extensions/vertx/deployment/src/main/java/io/quarkus/vertx/core/deployment/VertxCoreProcessor.java b/extensions/vertx/deployment/src/main/java/io/quarkus/vertx/core/deployment/VertxCoreProcessor.java index 474b2efb25934..d376eb44e13ef 100644 --- a/extensions/vertx/deployment/src/main/java/io/quarkus/vertx/core/deployment/VertxCoreProcessor.java +++ b/extensions/vertx/deployment/src/main/java/io/quarkus/vertx/core/deployment/VertxCoreProcessor.java @@ -118,77 +118,85 @@ void overrideContextInternalInterfaceToAddSafeGuards(BuildProducer new ClassVisitor(Gizmo.ASM_API_VERSION, classVisitor) { - @Override - public MethodVisitor visitMethod(int access, String name, String descriptor, String signature, - String[] exceptions) { - MethodVisitor visitor = super.visitMethod(access, name, descriptor, signature, exceptions); - - if (name.equals("get") || name.equals("put") || name.equals("remove")) { - return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { - @Override - public void visitCode() { - super.visitCode(); - visitMethodInsn(Opcodes.INVOKESTATIC, - VertxLocalsHelper.class.getName().replace(".", "/"), - "throwOnRootContextAccess", - "()V", false); + final BytecodeTransformerBuildItem transformation = new BytecodeTransformerBuildItem.Builder() + .setClassToTransform(name) + .setCacheable(true) + .setVisitorFunction( + (className, classVisitor) -> new ClassVisitor(Gizmo.ASM_API_VERSION, classVisitor) { + @Override + public MethodVisitor visitMethod(int access, String name, String descriptor, + String signature, + String[] exceptions) { + MethodVisitor visitor = super.visitMethod(access, name, descriptor, signature, + exceptions); + + if (name.equals("get") || name.equals("put") || name.equals("remove")) { + return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { + @Override + public void visitCode() { + super.visitCode(); + visitMethodInsn(Opcodes.INVOKESTATIC, + VertxLocalsHelper.class.getName().replace('.', '/'), + "throwOnRootContextAccess", + "()V", false); + } + }; } - }; - } - - if (name.equals("getLocal") && descriptor.equals("(Ljava/lang/Object;)Ljava/lang/Object;")) { - return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { - @Override - public void visitCode() { - super.visitCode(); - visitVarInsn(Opcodes.ALOAD, 0); // this - visitVarInsn(Opcodes.ALOAD, 1); // first param (object) - visitMethodInsn(Opcodes.INVOKESTATIC, - VertxLocalsHelper.class.getName().replace(".", "/"), "getLocal", - "(Lio/vertx/core/impl/ContextInternal;Ljava/lang/Object;)Ljava/lang/Object;", - false); - visitInsn(Opcodes.ARETURN); + + if (name.equals("getLocal") + && descriptor.equals("(Ljava/lang/Object;)Ljava/lang/Object;")) { + return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { + @Override + public void visitCode() { + super.visitCode(); + visitVarInsn(Opcodes.ALOAD, 0); // this + visitVarInsn(Opcodes.ALOAD, 1); // first param (object) + visitMethodInsn(Opcodes.INVOKESTATIC, + VertxLocalsHelper.class.getName().replace('.', '/'), "getLocal", + "(Lio/vertx/core/impl/ContextInternal;Ljava/lang/Object;)Ljava/lang/Object;", + false); + visitInsn(Opcodes.ARETURN); + } + }; } - }; - } - - if (name.equals("putLocal") && descriptor.equals("(Ljava/lang/Object;Ljava/lang/Object;)V")) { - return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { - @Override - public void visitCode() { - super.visitCode(); - visitVarInsn(Opcodes.ALOAD, 0); // this - visitVarInsn(Opcodes.ALOAD, 1); // first param (object) - visitVarInsn(Opcodes.ALOAD, 2); // second param (object) - visitMethodInsn(Opcodes.INVOKESTATIC, - VertxLocalsHelper.class.getName().replace(".", "/"), "putLocal", - "(Lio/vertx/core/impl/ContextInternal;Ljava/lang/Object;Ljava/lang/Object;)V", - false); - visitInsn(Opcodes.RETURN); + + if (name.equals("putLocal") + && descriptor.equals("(Ljava/lang/Object;Ljava/lang/Object;)V")) { + return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { + @Override + public void visitCode() { + super.visitCode(); + visitVarInsn(Opcodes.ALOAD, 0); // this + visitVarInsn(Opcodes.ALOAD, 1); // first param (object) + visitVarInsn(Opcodes.ALOAD, 2); // second param (object) + visitMethodInsn(Opcodes.INVOKESTATIC, + VertxLocalsHelper.class.getName().replace('.', '/'), "putLocal", + "(Lio/vertx/core/impl/ContextInternal;Ljava/lang/Object;Ljava/lang/Object;)V", + false); + visitInsn(Opcodes.RETURN); + } + }; } - }; - } - - if (name.equals("removeLocal") && descriptor.equals("(Ljava/lang/Object;)Z")) { - return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { - @Override - public void visitCode() { - super.visitCode(); - visitVarInsn(Opcodes.ALOAD, 0); // this - visitVarInsn(Opcodes.ALOAD, 1); // first param (object) - visitMethodInsn(Opcodes.INVOKESTATIC, - VertxLocalsHelper.class.getName().replace(".", "/"), "removeLocal", - "(Lio/vertx/core/impl/ContextInternal;Ljava/lang/Object;)Z", false); - visitInsn(Type.getType(Boolean.TYPE).getOpcode(Opcodes.IRETURN)); + + if (name.equals("removeLocal") && descriptor.equals("(Ljava/lang/Object;)Z")) { + return new MethodVisitor(Gizmo.ASM_API_VERSION, visitor) { + @Override + public void visitCode() { + super.visitCode(); + visitVarInsn(Opcodes.ALOAD, 0); // this + visitVarInsn(Opcodes.ALOAD, 1); // first param (object) + visitMethodInsn(Opcodes.INVOKESTATIC, + VertxLocalsHelper.class.getName().replace('.', '/'), "removeLocal", + "(Lio/vertx/core/impl/ContextInternal;Ljava/lang/Object;)Z", false); + visitInsn(Type.getType(Boolean.TYPE).getOpcode(Opcodes.IRETURN)); + } + }; } - }; - } - return visitor; - } - }); + return visitor; + } + }) + .build(); transformer.produce(transformation); } }