This is an automated email from the ASF dual-hosted git repository.

ggregory pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/commons-bcel.git

commit 867977ad016151bbacb923c373bbbeadf985f13a
Author: Gary Gregory <[email protected]>
AuthorDate: Sun Dec 3 10:41:21 2023 -0500

    Fix SpotBugs: No fall through hack
    
    [ERROR] Switch statement found in
    
org.apache.bcel.util.BCELFactory.visitAllocationInstruction(AllocationInstruction)
    where one case falls through to the next case
    [org.apache.bcel.util.BCELFactory, org.apache.bcel.util.BCELFactory] At
    BCELFactory.java:[lines 188-191]Another occurrence at
    BCELFactory.java:[lines 192-196] SF_SWITCH_FALLTHROUGH
---
 src/changes/changes.xml                              | 1 +
 src/main/java/org/apache/bcel/classfile/Utility.java | 4 +++-
 2 files changed, 4 insertions(+), 1 deletion(-)

diff --git a/src/changes/changes.xml b/src/changes/changes.xml
index dc0593e0..b597b52a 100644
--- a/src/changes/changes.xml
+++ b/src/changes/changes.xml
@@ -76,6 +76,7 @@ The <action> type attribute can be add,update,fix,remove.
       <action                  type="add" dev="ggregory" due-to="Gary 
Gregory">Add Const.MINOR_21.</action>
       <action                  type="add" dev="ggregory" due-to="nbauma109, 
Gary Gregory, Mark Roberts">[Bcelifier] stackmap support to pass JDK verifier 
#177.</action>
       <action                  type="add" dev="ggregory" due-to="Gary 
Gregory">Fix SpotBugs [ERROR] Class org.apache.bcel.util.ClassVector defines 
non-transient non-serializable instance field vec 
[org.apache.bcel.util.ClassVector] In ClassVector.java SE_BAD_FIELD.</action>
+      <action                  type="add" dev="ggregory" due-to="Gary 
Gregory">Fix SpotBugs [ERROR] Switch statement found in 
org.apache.bcel.util.BCELFactory.visitAllocationInstruction(AllocationInstruction)
 where one case falls through to the next case 
[org.apache.bcel.util.BCELFactory, org.apache.bcel.util.BCELFactory] At 
BCELFactory.java:[lines 188-191]Another occurrence at BCELFactory.java:[lines 
192-196] SF_SWITCH_FALLTHROUGH.</action>      
       <!-- FIX -->
       <action                  type="fix" dev="markt" due-to="OSS-Fuzz">When 
parsing an class with an invalid constant reference, ensure ClassParser.parse() 
throws ClassFormatException, not NullPointerException.</action>
       <action                  type="fix" dev="markt" due-to="OSS-Fuzz">Ensure 
that references to a constant pool entry with index zero trigger a 
ClassFormatException, not a NullPointerException.</action>
diff --git a/src/main/java/org/apache/bcel/classfile/Utility.java 
b/src/main/java/org/apache/bcel/classfile/Utility.java
index 415ceb27..691577e0 100644
--- a/src/main/java/org/apache/bcel/classfile/Utility.java
+++ b/src/main/java/org/apache/bcel/classfile/Utility.java
@@ -432,7 +432,9 @@ public abstract class Utility {
         case Const.NEW:
         case Const.CHECKCAST:
             buf.append("\t");
-            //$FALL-THROUGH$
+            index = bytes.readUnsignedShort();
+            buf.append("\t<").append(constantPool.constantToString(index, 
Const.CONSTANT_Class)).append(">").append(verbose ? " (" + index + ")" : "");
+            break;
         case Const.INSTANCEOF:
             index = bytes.readUnsignedShort();
             buf.append("\t<").append(constantPool.constantToString(index, 
Const.CONSTANT_Class)).append(">").append(verbose ? " (" + index + ")" : "");

Reply via email to