Upgrade to version 6.5.0
This commit is contained in:
parent
fe67ceeba5
commit
db6d4e1e82
@ -5,81 +5,80 @@ Subject: [PATCH] 8285407: Improve Xalan supports
|
|||||||
|
|
||||||
Refer: https://github.com/openjdk/jdk11u/commit/13bf52c8d876528a43be7cb77a1f452d29a21492
|
Refer: https://github.com/openjdk/jdk11u/commit/13bf52c8d876528a43be7cb77a1f452d29a21492
|
||||||
---
|
---
|
||||||
.../org/apache/bcel/classfile/ConstantPool.java | 12 ++++++++++--
|
.../java/org/apache/bcel/classfile/ConstantPool.java | 12 ++++++++++--
|
||||||
.../org/apache/bcel/generic/ConstantPoolGen.java | 14 ++++++++++++--
|
.../org/apache/bcel/generic/ConstantPoolGen.java | 12 +++++++++++-
|
||||||
2 files changed, 22 insertions(+), 4 deletions(-)
|
2 files changed, 21 insertions(+), 3 deletions(-)
|
||||||
|
|
||||||
diff --git a/src/main/java/org/apache/bcel/classfile/ConstantPool.java b/src/main/java/org/apache/bcel/classfile/ConstantPool.java
|
diff --git a/src/main/java/org/apache/bcel/classfile/ConstantPool.java b/src/main/java/org/apache/bcel/classfile/ConstantPool.java
|
||||||
index c8bc32a..9e465c6 100644
|
index c2926c0..cb38cbc 100644
|
||||||
--- a/src/main/java/org/apache/bcel/classfile/ConstantPool.java
|
--- a/src/main/java/org/apache/bcel/classfile/ConstantPool.java
|
||||||
+++ b/src/main/java/org/apache/bcel/classfile/ConstantPool.java
|
+++ b/src/main/java/org/apache/bcel/classfile/ConstantPool.java
|
||||||
@@ -22,6 +22,7 @@ import java.io.DataOutputStream;
|
@@ -22,6 +22,7 @@ import java.io.DataOutputStream;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
import org.apache.bcel.Const;
|
import org.apache.bcel.Const;
|
||||||
+import org.apache.bcel.generic.ConstantPoolGen;
|
+import org.apache.bcel.generic.ConstantPoolGen;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class represents the constant pool, i.e., a table of constants, of
|
* This class represents the constant pool, i.e., a table of constants, of
|
||||||
@@ -218,8 +219,15 @@ public class ConstantPool implements Cloneable, Node {
|
@@ -218,8 +219,15 @@ public class ConstantPool implements Cloneable, Node {
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public void dump( final DataOutputStream file ) throws IOException {
|
public void dump( final DataOutputStream file ) throws IOException {
|
||||||
- file.writeShort(constant_pool.length);
|
- file.writeShort(constantPool.length);
|
||||||
- for (int i = 1; i < constant_pool.length; i++) {
|
- for (int i = 1; i < constantPool.length; i++) {
|
||||||
+ /*
|
+ /*
|
||||||
+ * Constants over the size of the constant pool shall not be written out.
|
+ * Constants over the size of the constant pool shall not be written out.
|
||||||
+ * This is a redundant measure as the ConstantPoolGen should have already
|
+ * This is a redundant measure as the ConstantPoolGen should have already
|
||||||
+ * reported an error back in the situation.
|
+ * reported an error back in the situation.
|
||||||
+ */
|
+ */
|
||||||
+ int size = constant_pool.length < ConstantPoolGen.CONSTANT_POOL_SIZE - 1 ?
|
+ int size = constantPool.length < ConstantPoolGen.CONSTANT_POOL_SIZE - 1 ?
|
||||||
+ constant_pool.length : ConstantPoolGen.CONSTANT_POOL_SIZE - 1;
|
+ constantPool.length : ConstantPoolGen.CONSTANT_POOL_SIZE - 1;
|
||||||
+ file.writeShort(size);
|
+ file.writeShort(size);
|
||||||
+ for (int i = 1; i < size; i++) {
|
+ for (int i = 1; i < size; i++) {
|
||||||
if (constant_pool[i] != null) {
|
if (constantPool[i] != null) {
|
||||||
constant_pool[i].dump(file);
|
constantPool[i].dump(file);
|
||||||
}
|
}
|
||||||
diff --git a/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java b/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java
|
diff --git a/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java b/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java
|
||||||
index f3a766e..9c7f252 100644
|
index 5a09e0d..6f3d508 100644
|
||||||
--- a/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java
|
--- a/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java
|
||||||
+++ b/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java
|
+++ b/src/main/java/org/apache/bcel/generic/ConstantPoolGen.java
|
||||||
@@ -52,6 +52,7 @@ import org.apache.bcel.classfile.ConstantUtf8;
|
@@ -52,6 +52,7 @@ import org.apache.bcel.classfile.ConstantUtf8;
|
||||||
public class ConstantPoolGen {
|
public class ConstantPoolGen {
|
||||||
|
|
||||||
private static final int DEFAULT_BUFFER_SIZE = 256;
|
private static final int DEFAULT_BUFFER_SIZE = 256;
|
||||||
+ public static final int CONSTANT_POOL_SIZE = 65536;
|
+ public static final int CONSTANT_POOL_SIZE = 65536;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @deprecated (since 6.0) will be made private; do not access directly, use getter/setter
|
* @deprecated (since 6.0) will be made private; do not access directly, use getter/setter
|
||||||
@@ -95,7 +96,7 @@ public class ConstantPoolGen {
|
@@ -95,7 +96,7 @@ public class ConstantPoolGen {
|
||||||
public ConstantPoolGen(final Constant[] cs) {
|
public ConstantPoolGen(final Constant[] cs) {
|
||||||
final StringBuilder sb = new StringBuilder(DEFAULT_BUFFER_SIZE);
|
final StringBuilder sb = new StringBuilder(DEFAULT_BUFFER_SIZE);
|
||||||
|
|
||||||
- size = Math.max(DEFAULT_BUFFER_SIZE, cs.length + 64);
|
- size = Math.max(DEFAULT_BUFFER_SIZE, cs.length + 64);
|
||||||
+ size = Math.min(cs.length, CONSTANT_POOL_SIZE);
|
+ size = Math.min(cs.length, CONSTANT_POOL_SIZE);
|
||||||
constants = new Constant[size];
|
constants = new Constant[size];
|
||||||
|
|
||||||
System.arraycopy(cs, 0, constants, 0, cs.length);
|
System.arraycopy(cs, 0, constants, 0, cs.length);
|
||||||
@@ -224,9 +225,18 @@ public class ConstantPoolGen {
|
@@ -224,9 +225,18 @@ public class ConstantPoolGen {
|
||||||
/** Resize internal array of constants.
|
/** Resize internal array of constants.
|
||||||
*/
|
*/
|
||||||
protected void adjustSize() {
|
protected void adjustSize() {
|
||||||
- if (index + 3 >= size) {
|
+ // 3 extra spaces are needed as some entries may take 3 slots
|
||||||
+ // 3 extra spaces are needed as some entries may take 3 slots
|
+ if (index + 3 >= CONSTANT_POOL_SIZE) {
|
||||||
+ if (index + 3 >= CONSTANT_POOL_SIZE) {
|
+ throw new RuntimeException("The number of constants " + (index + 3)
|
||||||
+ throw new RuntimeException("The number of constants " + (index + 3)
|
+ + " is over the size of the constant pool: "
|
||||||
+ + " is over the size of the constant pool: "
|
+ + (CONSTANT_POOL_SIZE - 1));
|
||||||
+ + (CONSTANT_POOL_SIZE - 1));
|
+ }
|
||||||
+ }
|
+
|
||||||
+
|
if (index + 3 >= size) {
|
||||||
+ if (index + 3 >= size) {
|
final Constant[] cs = constants;
|
||||||
final Constant[] cs = constants;
|
size *= 2;
|
||||||
size *= 2;
|
+ // the constant array shall not exceed the size of the constant pool
|
||||||
+ // the constant array shall not exceed the size of the constant pool
|
+ size = Math.min(size, CONSTANT_POOL_SIZE);
|
||||||
+ size = Math.min(size, CONSTANT_POOL_SIZE);
|
constants = new Constant[size];
|
||||||
constants = new Constant[size];
|
System.arraycopy(cs, 0, constants, 0, index);
|
||||||
System.arraycopy(cs, 0, constants, 0, index);
|
}
|
||||||
}
|
|
||||||
--
|
--
|
||||||
2.27.0
|
2.27.0
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
BIN
bcel-6.5.0-src.tar.gz
Normal file
BIN
bcel-6.5.0-src.tar.gz
Normal file
Binary file not shown.
11
bcel.spec
11
bcel.spec
@ -1,8 +1,8 @@
|
|||||||
Name: bcel
|
Name: bcel
|
||||||
Version: 6.4.1
|
Version: 6.5.0
|
||||||
Release: 2
|
Release: 1
|
||||||
Summary: Byte Code Engineering Library
|
Summary: Byte Code Engineering Library
|
||||||
License: ASL 2.0
|
License: Apache-2.0
|
||||||
URL: http://commons.apache.org/proper/commons-bcel/
|
URL: http://commons.apache.org/proper/commons-bcel/
|
||||||
Source0: http://archive.apache.org/dist/commons/bcel/source/bcel-%{version}-src.tar.gz
|
Source0: http://archive.apache.org/dist/commons/bcel/source/bcel-%{version}-src.tar.gz
|
||||||
Patch0: CVE-2022-34169.patch
|
Patch0: CVE-2022-34169.patch
|
||||||
@ -17,7 +17,7 @@ give users a convenient possibility to analyze, create, and manipulate (binary)
|
|||||||
Java class files (those ending with .class).
|
Java class files (those ending with .class).
|
||||||
|
|
||||||
%prep
|
%prep
|
||||||
%autosetup -p1 -n %{name}-%{version}-src
|
%autosetup -n %{name}-%{version}-src -p1
|
||||||
%pom_remove_plugin :maven-source-plugin
|
%pom_remove_plugin :maven-source-plugin
|
||||||
%pom_remove_plugin :spotbugs-maven-plugin
|
%pom_remove_plugin :spotbugs-maven-plugin
|
||||||
%mvn_alias : bcel: apache:
|
%mvn_alias : bcel: apache:
|
||||||
@ -38,6 +38,9 @@ Java class files (those ending with .class).
|
|||||||
%{_javadocdir}/%{name}
|
%{_javadocdir}/%{name}
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Thu Oct 20 2022 yaoxin <yaoxin30@h-partners.com> - 6.5.0-1
|
||||||
|
- Upgrade to version 6.5.0
|
||||||
|
|
||||||
* Fri Sep 23 2022 wangkai <wangkai385@h-partners.com> -6.4.1-2
|
* Fri Sep 23 2022 wangkai <wangkai385@h-partners.com> -6.4.1-2
|
||||||
- Fix CVE-2022-34169 for xalan-j2
|
- Fix CVE-2022-34169 for xalan-j2
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user