mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2024-12-22 08:14:09 -08:00
Bump ASM version, use common ASM API version everywhere, bump ASM API version to 9
This commit is contained in:
parent
a40c955d39
commit
d097350787
25
core/src/main/java/org/teavm/parsing/AsmUtil.java
Normal file
25
core/src/main/java/org/teavm/parsing/AsmUtil.java
Normal 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() {
|
||||||
|
}
|
||||||
|
}
|
|
@ -71,8 +71,8 @@ public class Parser {
|
||||||
}
|
}
|
||||||
|
|
||||||
public MethodHolder parseMethod(MethodNode node, String fileName) {
|
public MethodHolder parseMethod(MethodNode node, String fileName) {
|
||||||
MethodNode nodeWithoutJsr = new MethodNode(Opcodes.ASM7, node.access, node.name, node.desc, node.signature,
|
MethodNode nodeWithoutJsr = new MethodNode(AsmUtil.API_VERSION, node.access, node.name, node.desc,
|
||||||
node.exceptions.toArray(new String[0]));
|
node.signature, node.exceptions.toArray(new String[0]));
|
||||||
JSRInlinerAdapter adapter = new JSRInlinerAdapter(nodeWithoutJsr, node.access, node.name, node.desc,
|
JSRInlinerAdapter adapter = new JSRInlinerAdapter(nodeWithoutJsr, node.access, node.name, node.desc,
|
||||||
node.signature, node.exceptions.toArray(new String[0]));
|
node.signature, node.exceptions.toArray(new String[0]));
|
||||||
node.accept(adapter);
|
node.accept(adapter);
|
||||||
|
|
|
@ -431,7 +431,7 @@ public class ProgramParser {
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: invokedynamic support (a great task, involving not only parser, but every layer of TeaVM)
|
// 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
|
@Override
|
||||||
public void visitVarInsn(int opcode, int local) {
|
public void visitVarInsn(int opcode, int local) {
|
||||||
switch (opcode) {
|
switch (opcode) {
|
||||||
|
|
|
@ -35,9 +35,9 @@ import java.util.stream.Collectors;
|
||||||
import org.objectweb.asm.AnnotationVisitor;
|
import org.objectweb.asm.AnnotationVisitor;
|
||||||
import org.objectweb.asm.ClassReader;
|
import org.objectweb.asm.ClassReader;
|
||||||
import org.objectweb.asm.ClassVisitor;
|
import org.objectweb.asm.ClassVisitor;
|
||||||
import org.objectweb.asm.Opcodes;
|
|
||||||
import org.objectweb.asm.Type;
|
import org.objectweb.asm.Type;
|
||||||
import org.teavm.metaprogramming.CompileTime;
|
import org.teavm.metaprogramming.CompileTime;
|
||||||
|
import org.teavm.parsing.AsmUtil;
|
||||||
import org.teavm.vm.spi.After;
|
import org.teavm.vm.spi.After;
|
||||||
import org.teavm.vm.spi.Before;
|
import org.teavm.vm.spi.Before;
|
||||||
import org.teavm.vm.spi.Requires;
|
import org.teavm.vm.spi.Requires;
|
||||||
|
@ -205,8 +205,8 @@ final class TeaVMPluginReader {
|
||||||
static class PluginDescriptorFiller extends ClassVisitor {
|
static class PluginDescriptorFiller extends ClassVisitor {
|
||||||
PluginDescriptor descriptor;
|
PluginDescriptor descriptor;
|
||||||
|
|
||||||
public PluginDescriptorFiller(PluginDescriptor descriptor) {
|
PluginDescriptorFiller(PluginDescriptor descriptor) {
|
||||||
super(Opcodes.ASM7);
|
super(AsmUtil.API_VERSION);
|
||||||
this.descriptor = descriptor;
|
this.descriptor = descriptor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -223,12 +223,12 @@ final class TeaVMPluginReader {
|
||||||
}
|
}
|
||||||
|
|
||||||
private AnnotationVisitor readClassArray(Consumer<String[]> resultConsumer) {
|
private AnnotationVisitor readClassArray(Consumer<String[]> resultConsumer) {
|
||||||
return new AnnotationVisitor(Opcodes.ASM7) {
|
return new AnnotationVisitor(AsmUtil.API_VERSION) {
|
||||||
@Override
|
@Override
|
||||||
public AnnotationVisitor visitArray(String name) {
|
public AnnotationVisitor visitArray(String name) {
|
||||||
List<String> values = new ArrayList<>();
|
List<String> values = new ArrayList<>();
|
||||||
if (name.equals("value")) {
|
if (name.equals("value")) {
|
||||||
return new AnnotationVisitor(Opcodes.ASM7) {
|
return new AnnotationVisitor(AsmUtil.API_VERSION) {
|
||||||
@Override
|
@Override
|
||||||
public void visit(String name, Object value) {
|
public void visit(String name, Object value) {
|
||||||
values.add(((Type) value).getClassName());
|
values.add(((Type) value).getClassName());
|
||||||
|
|
|
@ -24,9 +24,9 @@ import org.apache.commons.io.IOUtils;
|
||||||
import org.objectweb.asm.AnnotationVisitor;
|
import org.objectweb.asm.AnnotationVisitor;
|
||||||
import org.objectweb.asm.ClassReader;
|
import org.objectweb.asm.ClassReader;
|
||||||
import org.objectweb.asm.ClassVisitor;
|
import org.objectweb.asm.ClassVisitor;
|
||||||
import org.objectweb.asm.Opcodes;
|
|
||||||
import org.objectweb.asm.Type;
|
import org.objectweb.asm.Type;
|
||||||
import org.teavm.metaprogramming.CompileTime;
|
import org.teavm.metaprogramming.CompileTime;
|
||||||
|
import org.teavm.parsing.AsmUtil;
|
||||||
|
|
||||||
public class MetaprogrammingClassLoader extends ClassLoader {
|
public class MetaprogrammingClassLoader extends ClassLoader {
|
||||||
private MetaprogrammingInstrumentation instrumentation = new MetaprogrammingInstrumentation();
|
private MetaprogrammingInstrumentation instrumentation = new MetaprogrammingInstrumentation();
|
||||||
|
@ -129,7 +129,7 @@ public class MetaprogrammingClassLoader extends ClassLoader {
|
||||||
boolean compileTime;
|
boolean compileTime;
|
||||||
|
|
||||||
CompileTimeClassVisitor() {
|
CompileTimeClassVisitor() {
|
||||||
super(Opcodes.ASM7, null);
|
super(AsmUtil.API_VERSION, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -30,6 +30,7 @@ import org.teavm.metaprogramming.Action;
|
||||||
import org.teavm.metaprogramming.Computation;
|
import org.teavm.metaprogramming.Computation;
|
||||||
import org.teavm.metaprogramming.Metaprogramming;
|
import org.teavm.metaprogramming.Metaprogramming;
|
||||||
import org.teavm.model.MethodReference;
|
import org.teavm.model.MethodReference;
|
||||||
|
import org.teavm.parsing.AsmUtil;
|
||||||
|
|
||||||
public class MetaprogrammingInstrumentation {
|
public class MetaprogrammingInstrumentation {
|
||||||
private static String lambdaMetafactory = LambdaMetafactory.class.getName().replace('.', '/');
|
private static String lambdaMetafactory = LambdaMetafactory.class.getName().replace('.', '/');
|
||||||
|
@ -44,9 +45,9 @@ public class MetaprogrammingInstrumentation {
|
||||||
return writer.toByteArray();
|
return writer.toByteArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
class ClassTransformer extends ClassVisitor {
|
static class ClassTransformer extends ClassVisitor {
|
||||||
ClassTransformer(ClassVisitor cv) {
|
ClassTransformer(ClassVisitor cv) {
|
||||||
super(Opcodes.ASM7, cv);
|
super(AsmUtil.API_VERSION, cv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -56,11 +57,11 @@ public class MetaprogrammingInstrumentation {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
class MethodTransformer extends MethodVisitor {
|
static class MethodTransformer extends MethodVisitor {
|
||||||
private boolean instrumented;
|
private boolean instrumented;
|
||||||
|
|
||||||
MethodTransformer(MethodVisitor mv) {
|
MethodTransformer(MethodVisitor mv) {
|
||||||
super(Opcodes.ASM7, mv);
|
super(AsmUtil.API_VERSION, mv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
2
pom.xml
2
pom.xml
|
@ -68,7 +68,7 @@
|
||||||
|
|
||||||
<html4j.version>1.5</html4j.version>
|
<html4j.version>1.5</html4j.version>
|
||||||
<slf4j.version>1.7.30</slf4j.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.version>1.8</java.version>
|
||||||
<java-tests.version>17</java-tests.version>
|
<java-tests.version>17</java-tests.version>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user