Bump ASM version, use common ASM API version everywhere, bump ASM API version to 9

This commit is contained in:
Alexey Andreev 2022-10-05 11:09:53 +02:00
parent a40c955d39
commit d097350787
7 changed files with 41 additions and 15 deletions

View File

@ -0,0 +1,25 @@
/*
* Copyright 2022 Alexey Andreev.
*
* 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 org.teavm.parsing;
import org.objectweb.asm.Opcodes;
public final class AsmUtil {
public static final int API_VERSION = Opcodes.ASM9;
private AsmUtil() {
}
}

View File

@ -71,8 +71,8 @@ public class Parser {
}
public MethodHolder parseMethod(MethodNode node, String fileName) {
MethodNode nodeWithoutJsr = new MethodNode(Opcodes.ASM7, node.access, node.name, node.desc, node.signature,
node.exceptions.toArray(new String[0]));
MethodNode nodeWithoutJsr = new MethodNode(AsmUtil.API_VERSION, node.access, node.name, node.desc,
node.signature, node.exceptions.toArray(new String[0]));
JSRInlinerAdapter adapter = new JSRInlinerAdapter(nodeWithoutJsr, node.access, node.name, node.desc,
node.signature, node.exceptions.toArray(new String[0]));
node.accept(adapter);

View File

@ -431,7 +431,7 @@ public class ProgramParser {
}
// TODO: invokedynamic support (a great task, involving not only parser, but every layer of TeaVM)
private MethodVisitor methodVisitor = new MethodVisitor(Opcodes.ASM7) {
private MethodVisitor methodVisitor = new MethodVisitor(AsmUtil.API_VERSION) {
@Override
public void visitVarInsn(int opcode, int local) {
switch (opcode) {

View File

@ -35,9 +35,9 @@ import java.util.stream.Collectors;
import org.objectweb.asm.AnnotationVisitor;
import org.objectweb.asm.ClassReader;
import org.objectweb.asm.ClassVisitor;
import org.objectweb.asm.Opcodes;
import org.objectweb.asm.Type;
import org.teavm.metaprogramming.CompileTime;
import org.teavm.parsing.AsmUtil;
import org.teavm.vm.spi.After;
import org.teavm.vm.spi.Before;
import org.teavm.vm.spi.Requires;
@ -205,8 +205,8 @@ final class TeaVMPluginReader {
static class PluginDescriptorFiller extends ClassVisitor {
PluginDescriptor descriptor;
public PluginDescriptorFiller(PluginDescriptor descriptor) {
super(Opcodes.ASM7);
PluginDescriptorFiller(PluginDescriptor descriptor) {
super(AsmUtil.API_VERSION);
this.descriptor = descriptor;
}
@ -223,12 +223,12 @@ final class TeaVMPluginReader {
}
private AnnotationVisitor readClassArray(Consumer<String[]> resultConsumer) {
return new AnnotationVisitor(Opcodes.ASM7) {
return new AnnotationVisitor(AsmUtil.API_VERSION) {
@Override
public AnnotationVisitor visitArray(String name) {
List<String> values = new ArrayList<>();
if (name.equals("value")) {
return new AnnotationVisitor(Opcodes.ASM7) {
return new AnnotationVisitor(AsmUtil.API_VERSION) {
@Override
public void visit(String name, Object value) {
values.add(((Type) value).getClassName());

View File

@ -24,9 +24,9 @@ import org.apache.commons.io.IOUtils;
import org.objectweb.asm.AnnotationVisitor;
import org.objectweb.asm.ClassReader;
import org.objectweb.asm.ClassVisitor;
import org.objectweb.asm.Opcodes;
import org.objectweb.asm.Type;
import org.teavm.metaprogramming.CompileTime;
import org.teavm.parsing.AsmUtil;
public class MetaprogrammingClassLoader extends ClassLoader {
private MetaprogrammingInstrumentation instrumentation = new MetaprogrammingInstrumentation();
@ -129,7 +129,7 @@ public class MetaprogrammingClassLoader extends ClassLoader {
boolean compileTime;
CompileTimeClassVisitor() {
super(Opcodes.ASM7, null);
super(AsmUtil.API_VERSION, null);
}
@Override

View File

@ -30,6 +30,7 @@ import org.teavm.metaprogramming.Action;
import org.teavm.metaprogramming.Computation;
import org.teavm.metaprogramming.Metaprogramming;
import org.teavm.model.MethodReference;
import org.teavm.parsing.AsmUtil;
public class MetaprogrammingInstrumentation {
private static String lambdaMetafactory = LambdaMetafactory.class.getName().replace('.', '/');
@ -44,9 +45,9 @@ public class MetaprogrammingInstrumentation {
return writer.toByteArray();
}
class ClassTransformer extends ClassVisitor {
static class ClassTransformer extends ClassVisitor {
ClassTransformer(ClassVisitor cv) {
super(Opcodes.ASM7, cv);
super(AsmUtil.API_VERSION, cv);
}
@Override
@ -56,11 +57,11 @@ public class MetaprogrammingInstrumentation {
}
}
class MethodTransformer extends MethodVisitor {
static class MethodTransformer extends MethodVisitor {
private boolean instrumented;
MethodTransformer(MethodVisitor mv) {
super(Opcodes.ASM7, mv);
super(AsmUtil.API_VERSION, mv);
}
@Override

View File

@ -68,7 +68,7 @@
<html4j.version>1.5</html4j.version>
<slf4j.version>1.7.30</slf4j.version>
<asm.version>9.1</asm.version>
<asm.version>9.4</asm.version>
<java.version>1.8</java.version>
<java-tests.version>17</java-tests.version>