summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMiroslav Šulc <fordfrog@gentoo.org>2021-10-12 08:51:38 +0200
committerMiroslav Šulc <fordfrog@gentoo.org>2021-10-12 08:51:48 +0200
commit67f37a4652c157fd4e616cbb052f725d84dd3315 (patch)
tree4465870b4dae7ed3b0bc5700316817723b29968d /dev-java/commons-compress/files
parentdev-python/pooch: Bump to 1.5.2 (diff)
downloadgentoo-67f37a4652c157fd4e616cbb052f725d84dd3315.tar.gz
gentoo-67f37a4652c157fd4e616cbb052f725d84dd3315.tar.bz2
gentoo-67f37a4652c157fd4e616cbb052f725d84dd3315.zip
dev-java/commons-compress: bump to 1.21
Bug: https://bugs.gentoo.org/802078 Package-Manager: Portage-3.0.28, Repoman-3.0.3 Signed-off-by: Miroslav Šulc <fordfrog@gentoo.org>
Diffstat (limited to 'dev-java/commons-compress/files')
-rw-r--r--dev-java/commons-compress/files/commons-compress-1.21-asm7+.patch164
1 files changed, 164 insertions, 0 deletions
diff --git a/dev-java/commons-compress/files/commons-compress-1.21-asm7+.patch b/dev-java/commons-compress/files/commons-compress-1.21-asm7+.patch
new file mode 100644
index 000000000000..e20fa89787dc
--- /dev/null
+++ b/dev-java/commons-compress/files/commons-compress-1.21-asm7+.patch
@@ -0,0 +1,164 @@
+From 7709c8be97147e8d5c5d7fa42d076504931ba9e0 Mon Sep 17 00:00:00 2001
+From: Stephan Blecher <token_github@blecher.at>
+Date: Tue, 10 Aug 2021 14:39:21 +0200
+Subject: [PATCH] COMPRESS-582: update harmony to ASM >= 7.0
+
+---
+ pom.xml | 5 +--
+ .../harmony/pack200/Pack200ClassReader.java | 2 +-
+ .../compress/harmony/pack200/Segment.java | 35 +++++++++++++++----
+ .../harmony/pack200/tests/ArchiveTest.java | 0
+ 4 files changed, 32 insertions(+), 10 deletions(-)
+ mode change 100644 => 100755 src/test/java/org/apache/commons/compress/harmony/pack200/tests/ArchiveTest.java
+
+diff --git a/pom.xml b/pom.xml
+index 28f50f06a..1c6844d24 100644
+--- a/pom.xml
++++ b/pom.xml
+@@ -78,6 +78,7 @@ Brotli, Zstandard and ar, cpio, jar, tar, zip, dump, 7z, arj.
+ <commons.jacoco.version>0.8.7</commons.jacoco.version>
+ <commons.japicmp.version>0.15.3</commons.japicmp.version>
+ <commons.javadoc.version>3.3.0</commons.javadoc.version>
++ <asm.version>7.0</asm.version>
+ </properties>
+
+ <issueManagement>
+@@ -119,9 +120,9 @@ Brotli, Zstandard and ar, cpio, jar, tar, zip, dump, 7z, arj.
+
+ <!-- Pack200 -->
+ <dependency>
+- <groupId>asm</groupId>
++ <groupId>org.ow2.asm</groupId>
+ <artifactId>asm</artifactId>
+- <version>3.2</version>
++ <version>${asm.version}</version>
+ <optional>true</optional>
+ </dependency>
+
+diff --git a/src/main/java/org/apache/commons/compress/harmony/pack200/Pack200ClassReader.java b/src/main/java/org/apache/commons/compress/harmony/pack200/Pack200ClassReader.java
+index 2a017bc01..7022b7b30 100644
+--- a/src/main/java/org/apache/commons/compress/harmony/pack200/Pack200ClassReader.java
++++ b/src/main/java/org/apache/commons/compress/harmony/pack200/Pack200ClassReader.java
+@@ -40,7 +40,7 @@ public int readUnsignedShort(final int index) {
+ // Doing this to check whether last load-constant instruction was ldc (18) or ldc_w (19)
+ // TODO: Assess whether this impacts on performance
+ final int unsignedShort = super.readUnsignedShort(index);
+- if (b[index - 1] == 19) {
++ if (index > 0 && b[index - 1] == 19) {
+ lastUnsignedShort = unsignedShort;
+ } else {
+ lastUnsignedShort = Short.MIN_VALUE;
+diff --git a/src/main/java/org/apache/commons/compress/harmony/pack200/Segment.java b/src/main/java/org/apache/commons/compress/harmony/pack200/Segment.java
+index 0609aa4c2..1bc73a018 100644
+--- a/src/main/java/org/apache/commons/compress/harmony/pack200/Segment.java
++++ b/src/main/java/org/apache/commons/compress/harmony/pack200/Segment.java
+@@ -32,12 +32,20 @@
+ import org.objectweb.asm.FieldVisitor;
+ import org.objectweb.asm.Label;
+ import org.objectweb.asm.MethodVisitor;
++import org.objectweb.asm.Opcodes;
+ import org.objectweb.asm.Type;
+
++
+ /**
+ * A Pack200 archive consists of one or more Segments.
+ */
+-public class Segment implements ClassVisitor {
++public class Segment extends ClassVisitor {
++
++ public static int ASM_API = Opcodes.ASM4; /* see https://asm.ow2.io/javadoc/org/objectweb/asm/Opcodes.html#ASM4 */
++
++ public Segment() {
++ super(ASM_API);
++ }
+
+ private SegmentHeader segmentHeader;
+ private CpBands cpBands;
+@@ -255,8 +263,12 @@ public void visitEnd() {
+ *
+ * It delegates to BcBands for bytecode related visits and to ClassBands for everything else.
+ */
+- public class SegmentMethodVisitor implements MethodVisitor {
+-
++ public class SegmentMethodVisitor extends MethodVisitor {
++
++ public SegmentMethodVisitor() {
++ super(ASM_API);
++ }
++
+ @Override
+ public AnnotationVisitor visitAnnotation(final String desc, final boolean visible) {
+ return new SegmentAnnotationVisitor(MetadataBandGroup.CONTEXT_METHOD, desc, visible);
+@@ -427,7 +439,7 @@ public ClassBands getClassBands() {
+ /**
+ * SegmentAnnotationVisitor implements <code>AnnotationVisitor</code> to visit Annotations found in a class file.
+ */
+- public class SegmentAnnotationVisitor implements AnnotationVisitor {
++ public class SegmentAnnotationVisitor extends AnnotationVisitor {
+
+ private int context = -1;
+ private int parameter = -1;
+@@ -443,17 +455,20 @@ public ClassBands getClassBands() {
+ private final List nestPairN = new ArrayList();
+
+ public SegmentAnnotationVisitor(final int context, final String desc, final boolean visible) {
++ super(ASM_API);
+ this.context = context;
+ this.desc = desc;
+ this.visible = visible;
+ }
+
+ public SegmentAnnotationVisitor(final int context) {
++ super(ASM_API);
+ this.context = context;
+ }
+
+ public SegmentAnnotationVisitor(final int context, final int parameter, final String desc,
+ final boolean visible) {
++ super(ASM_API);
+ this.context = context;
+ this.parameter = parameter;
+ this.desc = desc;
+@@ -478,7 +493,7 @@ public AnnotationVisitor visitAnnotation(String name, final String desc) {
+ nameRU.add(name);
+ nestTypeRS.add(desc);
+ nestPairN.add(Integer.valueOf(0));
+- return new AnnotationVisitor() {
++ return new AnnotationVisitor(context, av) {
+ @Override
+ public void visit(final String name, final Object value) {
+ final Integer numPairs = (Integer) nestPairN.remove(nestPairN.size() - 1);
+@@ -552,7 +567,7 @@ public void visitEnum(String name, final String desc, final String value) {
+ }
+ }
+
+- public class ArrayVisitor implements AnnotationVisitor {
++ public class ArrayVisitor extends AnnotationVisitor {
+
+ private final int indexInCaseArrayN;
+ private final List caseArrayN;
+@@ -561,6 +576,8 @@ public void visitEnum(String name, final String desc, final String value) {
+ private final List T;
+
+ public ArrayVisitor(final List caseArrayN, final List T, final List nameRU, final List values) {
++ super(ASM_API);
++
+ this.caseArrayN = caseArrayN;
+ this.T = T;
+ this.nameRU = nameRU;
+@@ -612,7 +629,11 @@ public void visitEnum(final String name, final String desc, final String value)
+ * SegmentFieldVisitor implements <code>FieldVisitor</code> to visit the metadata relating to fields in a class
+ * file.
+ */
+- public class SegmentFieldVisitor implements FieldVisitor {
++ public class SegmentFieldVisitor extends FieldVisitor {
++
++ public SegmentFieldVisitor() {
++ super(ASM_API);
++ }
+
+ @Override
+ public AnnotationVisitor visitAnnotation(final String desc, final boolean visible) {
+diff --git a/src/test/java/org/apache/commons/compress/harmony/pack200/tests/ArchiveTest.java b/src/test/java/org/apache/commons/compress/harmony/pack200/tests/ArchiveTest.java
+old mode 100644
+new mode 100755