[Git][java-team/asm][upstream] New upstream version 9.2

Emmanuel Bourg (@ebourg) gitlab at salsa.debian.org
Sat Sep 18 08:56:40 BST 2021



Emmanuel Bourg pushed to branch upstream at Debian Java Maintainers / asm


Commits:
a390cb5b by Emmanuel Bourg at 2021-09-18T09:30:05+02:00
New upstream version 9.2
- - - - -


12 changed files:

- asm-commons/src/main/java/org/objectweb/asm/commons/ModuleHashesAttribute.java
- asm-tree/src/main/java/org/objectweb/asm/tree/LdcInsnNode.java
- asm-util/src/main/java/org/objectweb/asm/util/ASMifier.java
- asm-util/src/main/java/org/objectweb/asm/util/CheckClassAdapter.java
- asm-util/src/main/java/org/objectweb/asm/util/CheckMethodAdapter.java
- asm-util/src/test/java/org/objectweb/asm/util/CheckClassAdapterTest.java
- asm/src/main/java/org/objectweb/asm/ClassReader.java
- asm/src/main/java/org/objectweb/asm/ClassVisitor.java
- asm/src/main/java/org/objectweb/asm/ClassWriter.java
- asm/src/main/java/org/objectweb/asm/Opcodes.java
- asm/src/test/java/org/objectweb/asm/ConstantsTest.java
- build.gradle


Changes:

=====================================
asm-commons/src/main/java/org/objectweb/asm/commons/ModuleHashesAttribute.java
=====================================
@@ -103,7 +103,7 @@ public final class ModuleHashesAttribute extends Attribute {
       currentOffset += 2;
       byte[] hash = new byte[hashLength];
       for (int j = 0; j < hashLength; ++j) {
-        hash[j] = (byte) (classReader.readByte(currentOffset) & 0xFF);
+        hash[j] = (byte) classReader.readByte(currentOffset);
         currentOffset += 1;
       }
       hashList.add(hash);


=====================================
asm-tree/src/main/java/org/objectweb/asm/tree/LdcInsnNode.java
=====================================
@@ -28,8 +28,11 @@
 package org.objectweb.asm.tree;
 
 import java.util.Map;
+import org.objectweb.asm.ConstantDynamic;
+import org.objectweb.asm.Handle;
 import org.objectweb.asm.MethodVisitor;
 import org.objectweb.asm.Opcodes;
+import org.objectweb.asm.Type;
 
 /**
  * A node that represents an LDC instruction.
@@ -39,17 +42,23 @@ import org.objectweb.asm.Opcodes;
 public class LdcInsnNode extends AbstractInsnNode {
 
   /**
-   * The constant to be loaded on the stack. This parameter must be a non null {@link Integer}, a
-   * {@link Float}, a {@link Long}, a {@link Double}, a {@link String} or a {@link
-   * org.objectweb.asm.Type}.
+   * The constant to be loaded on the stack. This field must be a non null {@link Integer}, a {@link
+   * Float}, a {@link Long}, a {@link Double}, a {@link String}, a {@link Type} of OBJECT or ARRAY
+   * sort for {@code .class} constants, for classes whose version is 49, a {@link Type} of METHOD
+   * sort for MethodType, a {@link Handle} for MethodHandle constants, for classes whose version is
+   * 51 or a {@link ConstantDynamic} for a constant dynamic for classes whose version is 55.
    */
   public Object cst;
 
   /**
    * Constructs a new {@link LdcInsnNode}.
    *
-   * @param value the constant to be loaded on the stack. This parameter must be a non null {@link
-   *     Integer}, a {@link Float}, a {@link Long}, a {@link Double} or a {@link String}.
+   * @param value the constant to be loaded on the stack. This parameter mist be a non null {@link
+   *     Integer}, a {@link Float}, a {@link Long}, a {@link Double}, a {@link String}, a {@link
+   *     Type} of OBJECT or ARRAY sort for {@code .class} constants, for classes whose version is
+   *     49, a {@link Type} of METHOD sort for MethodType, a {@link Handle} for MethodHandle
+   *     constants, for classes whose version is 51 or a {@link ConstantDynamic} for a constant
+   *     dynamic for classes whose version is 55.
    */
   public LdcInsnNode(final Object value) {
     super(Opcodes.LDC);


=====================================
asm-util/src/main/java/org/objectweb/asm/util/ASMifier.java
=====================================
@@ -107,6 +107,7 @@ public class ASMifier extends Printer {
     classVersions.put(Opcodes.V15, "V15");
     classVersions.put(Opcodes.V16, "V16");
     classVersions.put(Opcodes.V17, "V17");
+    classVersions.put(Opcodes.V18, "V18");
     CLASS_VERSIONS = Collections.unmodifiableMap(classVersions);
   }
 


=====================================
asm-util/src/main/java/org/objectweb/asm/util/CheckClassAdapter.java
=====================================
@@ -430,7 +430,8 @@ public class CheckClassAdapter extends ClassVisitor {
       final String signature,
       final String[] exceptions) {
     checkState();
-    checkAccess(
+    checkMethodAccess(
+        version,
         access,
         Opcodes.ACC_PUBLIC
             | Opcodes.ACC_PRIVATE
@@ -555,6 +556,23 @@ public class CheckClassAdapter extends ClassVisitor {
     }
   }
 
+  /**
+   * Checks that the given access flags do not contain invalid flags for a method. This method also
+   * checks that mutually incompatible flags are not set simultaneously.
+   *
+   * @param version the class version.
+   * @param access the method access flags to be checked.
+   * @param possibleAccess the valid access flags.
+   */
+  private static void checkMethodAccess(
+      final int version, final int access, final int possibleAccess) {
+    checkAccess(access, possibleAccess);
+    if ((version & 0xFFFF) < Opcodes.V17
+        && Integer.bitCount(access & (Opcodes.ACC_STRICT | Opcodes.ACC_ABSTRACT)) > 1) {
+      throw new IllegalArgumentException("strictfp and abstract are mutually exclusive: " + access);
+    }
+  }
+
   /**
    * Checks that the given name is a fully qualified name, using dots.
    *
@@ -1114,7 +1132,11 @@ public class CheckClassAdapter extends ClassVisitor {
       if (name.charAt(endIndex - 1) == ';') {
         endIndex--;
       }
-      return name.substring(lastSlashIndex + 1, endIndex);
+      int lastBracketIndex = name.lastIndexOf('[');
+      if (lastBracketIndex == -1) {
+        return name.substring(lastSlashIndex + 1, endIndex);
+      }
+      return name.substring(0, lastBracketIndex + 1) + name.substring(lastSlashIndex + 1, endIndex);
     }
   }
 }


=====================================
asm-util/src/main/java/org/objectweb/asm/util/CheckMethodAdapter.java
=====================================
@@ -484,7 +484,7 @@ public class CheckMethodAdapter extends MethodVisitor {
       checkUnqualifiedName(version, name, "name");
     }
     CheckClassAdapter.checkAccess(
-        access, Opcodes.ACC_FINAL + Opcodes.ACC_MANDATED + Opcodes.ACC_SYNTHETIC);
+        access, Opcodes.ACC_FINAL | Opcodes.ACC_MANDATED | Opcodes.ACC_SYNTHETIC);
     super.visitParameter(name, access);
   }
 


=====================================
asm-util/src/test/java/org/objectweb/asm/util/CheckClassAdapterTest.java
=====================================
@@ -360,6 +360,30 @@ public class CheckClassAdapterTest extends AsmTest implements Opcodes {
     assertEquals("LC;I: error at index 3", exception.getMessage());
   }
 
+  @Test
+  public void testVisitMethod_illegalAccessFlagSet() {
+    CheckClassAdapter checkClassAdapter = new CheckClassAdapter(null);
+    checkClassAdapter.visit(V1_1, ACC_PUBLIC, "C", null, "java/lang/Object", null);
+
+    Executable visitMethod =
+        () -> checkClassAdapter.visitMethod(ACC_ABSTRACT | ACC_STRICT, "m", "()V", null, null);
+
+    Exception exception = assertThrows(IllegalArgumentException.class, visitMethod);
+    assertEquals("strictfp and abstract are mutually exclusive: 3072", exception.getMessage());
+  }
+
+  @Test
+  public void testVisitMethod_legalAccessFlagSet_V17() {
+    // Java 17 allows to mix ACC_ABSTRACT and ACC_STRICT because ACC_STRICT is ignored
+    CheckClassAdapter checkClassAdapter = new CheckClassAdapter(null);
+    checkClassAdapter.visit(V17, ACC_PUBLIC, "C", null, "java/lang/Object", null);
+
+    Executable visitMethod =
+        () -> checkClassAdapter.visitMethod(ACC_ABSTRACT | ACC_STRICT, "m", "()V", null, null);
+
+    assertDoesNotThrow(visitMethod);
+  }
+
   @Test
   public void testVisitMethod_illegalSignature() {
     CheckClassAdapter checkClassAdapter = new CheckClassAdapter(null);
@@ -549,6 +573,7 @@ public class CheckClassAdapterTest extends AsmTest implements Opcodes {
     String log = logger.toString();
     assertFalse(log.startsWith(AnalyzerException.class.getName() + ": Error at instruction"));
     assertTrue(log.contains("00000 CheckClassAdapterTest  :  :     ALOAD 0"));
+    assertTrue(log.contains("00001 CheckClassAdapterTest [Object  : [Object  :     ARETURN"));
   }
 
   @Test
@@ -578,4 +603,8 @@ public class CheckClassAdapterTest extends AsmTest implements Opcodes {
   private static Attribute[] attributes() {
     return new Attribute[] {new Comment(), new CodeComment()};
   }
+
+  Object methodWithObjectArrayArgument(final Object[] arg) {
+    return arg;
+  }
 }


=====================================
asm/src/main/java/org/objectweb/asm/ClassReader.java
=====================================
@@ -88,6 +88,9 @@ public class ClassReader {
    */
   static final int EXPAND_ASM_INSNS = 256;
 
+  /** The maximum size of array to allocate. */
+  private static final int MAX_BUFFER_SIZE = 1024 * 1024;
+
   /** The size of the temporary byte array used to read class input streams chunk by chunk. */
   private static final int INPUT_STREAM_DATA_CHUNK_SIZE = 4096;
 
@@ -191,7 +194,7 @@ public class ClassReader {
     this.b = classFileBuffer;
     // Check the class' major_version. This field is after the magic and minor_version fields, which
     // use 4 and 2 bytes respectively.
-    if (checkClassVersion && readShort(classFileOffset + 6) > Opcodes.V17) {
+    if (checkClassVersion && readShort(classFileOffset + 6) > Opcodes.V18) {
       throw new IllegalArgumentException(
           "Unsupported class file major version " + readShort(classFileOffset + 6));
     }
@@ -310,13 +313,19 @@ public class ClassReader {
     if (inputStream == null) {
       throw new IOException("Class not found");
     }
+    int bufferSize = calculateBufferSize(inputStream);
     try (ByteArrayOutputStream outputStream = new ByteArrayOutputStream()) {
-      byte[] data = new byte[INPUT_STREAM_DATA_CHUNK_SIZE];
+      byte[] data = new byte[bufferSize];
       int bytesRead;
-      while ((bytesRead = inputStream.read(data, 0, data.length)) != -1) {
+      int readCount = 0;
+      while ((bytesRead = inputStream.read(data, 0, bufferSize)) != -1) {
         outputStream.write(data, 0, bytesRead);
+        readCount++;
       }
       outputStream.flush();
+      if (readCount == 1) {
+        return data;
+      }
       return outputStream.toByteArray();
     } finally {
       if (close) {
@@ -325,6 +334,20 @@ public class ClassReader {
     }
   }
 
+  private static int calculateBufferSize(final InputStream inputStream) throws IOException {
+    int expectedLength = inputStream.available();
+    /*
+     * Some implementations can return 0 while holding available data
+     * (e.g. new FileInputStream("/proc/a_file"))
+     * Also in some pathological cases a very small number might be returned,
+     * and in this case we use default size
+     */
+    if (expectedLength < 256) {
+      return INPUT_STREAM_DATA_CHUNK_SIZE;
+    }
+    return Math.min(expectedLength, MAX_BUFFER_SIZE);
+  }
+
   // -----------------------------------------------------------------------------------------------
   // Accessors
   // -----------------------------------------------------------------------------------------------


=====================================
asm/src/main/java/org/objectweb/asm/ClassVisitor.java
=====================================
@@ -30,8 +30,8 @@ package org.objectweb.asm;
 /**
  * A visitor to visit a Java class. The methods of this class must be called in the following order:
  * {@code visit} [ {@code visitSource} ] [ {@code visitModule} ][ {@code visitNestHost} ][ {@code
- * visitPermittedSubclass} ][ {@code visitOuterClass} ] ( {@code visitAnnotation} | {@code
- * visitTypeAnnotation} | {@code visitAttribute} )* ( {@code visitNestMember} | {@code
+ * visitOuterClass} ] ( {@code visitAnnotation} | {@code visitTypeAnnotation} | {@code
+ * visitAttribute} )* ( {@code visitNestMember} | [ {@code * visitPermittedSubclass} ] | {@code
  * visitInnerClass} | {@code visitRecordComponent} | {@code visitField} | {@code visitMethod} )*
  * {@code visitEnd}.
  *


=====================================
asm/src/main/java/org/objectweb/asm/ClassWriter.java
=====================================
@@ -79,7 +79,7 @@ public class ClassWriter extends ClassVisitor {
 
   /**
    * The access_flags field of the JVMS ClassFile structure. This field can contain ASM specific
-   * access flags, such as {@link Opcodes#ACC_DEPRECATED} or {}@link Opcodes#ACC_RECORD}, which are
+   * access flags, such as {@link Opcodes#ACC_DEPRECATED} or {@link Opcodes#ACC_RECORD}, which are
    * removed when generating the ClassFile structure.
    */
   private int accessFlags;


=====================================
asm/src/main/java/org/objectweb/asm/Opcodes.java
=====================================
@@ -283,6 +283,7 @@ public interface Opcodes {
   int V15 = 0 << 16 | 59;
   int V16 = 0 << 16 | 60;
   int V17 = 0 << 16 | 61;
+  int V18 = 0 << 16 | 62;
 
   /**
    * Version flag indicating that the class is using 'preview' features.


=====================================
asm/src/test/java/org/objectweb/asm/ConstantsTest.java
=====================================
@@ -250,6 +250,7 @@ public class ConstantsTest {
       case "V15":
       case "V16":
       case "V17":
+      case "V18":
         return ConstantType.CLASS_VERSION;
       case "ACC_PUBLIC":
       case "ACC_PRIVATE":


=====================================
build.gradle
=====================================
@@ -44,7 +44,7 @@ subprojects {
   apply plugin: 'jacoco'
   def snapshotSuffix = rootProject.hasProperty('release') ? '' : '-SNAPSHOT'
   group = 'org.ow2.asm'
-  version = '9.1' + snapshotSuffix
+  version = '9.2' + snapshotSuffix
   sourceCompatibility = '1.8'
   targetCompatibility = '1.8'
   test { useJUnitPlatform() }
@@ -209,7 +209,7 @@ subprojects {
 // and uploaded to Maven with a POM, sources and Javadoc.
 configure(subprojects.findAll { it.provides }) {
   // Code coverage configuration.
-  jacoco.toolVersion = '0.8.6'
+  jacoco.toolVersion = '0.8.7'
   jacocoTestReport {
     reports { xml.enabled true }
     classDirectories.setFrom(sourceSets.main.output.classesDirs)



View it on GitLab: https://salsa.debian.org/java-team/asm/-/commit/a390cb5bcc2236c9777abc06f73b1524fef915ee

-- 
View it on GitLab: https://salsa.debian.org/java-team/asm/-/commit/a390cb5bcc2236c9777abc06f73b1524fef915ee
You're receiving this email because of your account on salsa.debian.org.


-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://alioth-lists.debian.net/pipermail/pkg-java-commits/attachments/20210918/b997dc03/attachment.htm>


More information about the pkg-java-commits mailing list