[prev in list] [next in list] [prev in thread] [next in thread] 

List:       xalan-cvs
Subject:    [xalan-java] branch xalan-j_2_7_1_maint updated: xalanj commit : integer truncation fix, for xsltc
From:       mukulg () apache ! org
Date:       2022-09-16 12:53:39
Message-ID: 166333281962.1647966.11267163000559387129 () gitbox2-he-fi ! apache ! org
[Download RAW message or body]

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

mukulg pushed a commit to branch xalan-j_2_7_1_maint
in repository https://gitbox.apache.org/repos/asf/xalan-java.git


The following commit(s) were added to refs/heads/xalan-j_2_7_1_maint by this push:
     new da3e0d06 xalanj commit : integer truncation fix, for xsltc
da3e0d06 is described below

commit da3e0d06b467247643ce04e88d3346739d119f21
Author: Mukul Gandhi <gandhi.mukul@gmail.com>
AuthorDate: Fri Sep 16 18:23:16 2022 +0530

    xalanj commit : integer truncation fix, for xsltc
---
 .settings/org.eclipse.jdt.core.prefs               |   15 +-
 build.xml                                          |   19 +-
 src/org/apache/bcel/Const.java                     | 2438 ++++++++++++++++
 src/org/apache/bcel/Constants.java                 | 1697 +++++++++++
 src/org/apache/bcel/ExceptionConst.java            |  135 +
 src/org/apache/bcel/ExceptionConstants.java        |   87 +
 src/org/apache/bcel/Repository.java                |  266 ++
 src/org/apache/bcel/classfile/AccessFlags.java     |  218 ++
 .../apache/bcel/classfile/AnnotationDefault.java   |   93 +
 .../bcel/classfile/AnnotationElementValue.java     |   65 +
 src/org/apache/bcel/classfile/AnnotationEntry.java |  167 ++
 src/org/apache/bcel/classfile/Annotations.java     |  113 +
 .../apache/bcel/classfile/ArrayElementValue.java   |   92 +
 src/org/apache/bcel/classfile/Attribute.java       |  389 +++
 src/org/apache/bcel/classfile/AttributeReader.java |   59 +
 src/org/apache/bcel/classfile/BootstrapMethod.java |  169 ++
 .../apache/bcel/classfile/BootstrapMethods.java    |  151 +
 .../apache/bcel/classfile/ClassElementValue.java   |   67 +
 .../bcel/classfile/ClassFormatException.java       |   45 +
 src/org/apache/bcel/classfile/ClassParser.java     |  307 ++
 src/org/apache/bcel/classfile/Code.java            |  355 +++
 src/org/apache/bcel/classfile/CodeException.java   |  217 ++
 src/org/apache/bcel/classfile/Constant.java        |  206 ++
 src/org/apache/bcel/classfile/ConstantCP.java      |  150 +
 src/org/apache/bcel/classfile/ConstantClass.java   |  131 +
 src/org/apache/bcel/classfile/ConstantDouble.java  |  122 +
 src/org/apache/bcel/classfile/ConstantDynamic.java |   90 +
 .../apache/bcel/classfile/ConstantFieldref.java    |   70 +
 src/org/apache/bcel/classfile/ConstantFloat.java   |  123 +
 src/org/apache/bcel/classfile/ConstantInteger.java |  122 +
 .../bcel/classfile/ConstantInterfaceMethodref.java |   70 +
 .../bcel/classfile/ConstantInvokeDynamic.java      |   90 +
 src/org/apache/bcel/classfile/ConstantLong.java    |  122 +
 .../bcel/classfile/ConstantMethodHandle.java       |  120 +
 .../apache/bcel/classfile/ConstantMethodType.java  |  106 +
 .../apache/bcel/classfile/ConstantMethodref.java   |   70 +
 src/org/apache/bcel/classfile/ConstantModule.java  |  134 +
 .../apache/bcel/classfile/ConstantNameAndType.java |  150 +
 src/org/apache/bcel/classfile/ConstantObject.java  |   31 +
 src/org/apache/bcel/classfile/ConstantPackage.java |  134 +
 src/org/apache/bcel/classfile/ConstantPool.java    |  376 +++
 src/org/apache/bcel/classfile/ConstantString.java  |  130 +
 src/org/apache/bcel/classfile/ConstantUtf8.java    |  267 ++
 src/org/apache/bcel/classfile/ConstantValue.java   |  159 ++
 src/org/apache/bcel/classfile/Deprecated.java      |  145 +
 .../apache/bcel/classfile/DescendingVisitor.java   |  656 +++++
 src/org/apache/bcel/classfile/ElementValue.java    |  130 +
 .../apache/bcel/classfile/ElementValuePair.java    |   75 +
 src/org/apache/bcel/classfile/EmptyVisitor.java    |  372 +++
 src/org/apache/bcel/classfile/EnclosingMethod.java |  106 +
 .../apache/bcel/classfile/EnumElementValue.java    |   86 +
 src/org/apache/bcel/classfile/ExceptionTable.java  |  181 ++
 src/org/apache/bcel/classfile/Field.java           |  199 ++
 src/org/apache/bcel/classfile/FieldOrMethod.java   |  294 ++
 src/org/apache/bcel/classfile/InnerClass.java      |  216 ++
 src/org/apache/bcel/classfile/InnerClasses.java    |  156 ++
 src/org/apache/bcel/classfile/JavaClass.java       |  929 ++++++
 src/org/apache/bcel/classfile/LineNumber.java      |  147 +
 src/org/apache/bcel/classfile/LineNumberTable.java |  215 ++
 src/org/apache/bcel/classfile/LocalVariable.java   |  303 ++
 .../apache/bcel/classfile/LocalVariableTable.java  |  196 ++
 .../bcel/classfile/LocalVariableTypeTable.java     |  150 +
 src/org/apache/bcel/classfile/Method.java          |  270 ++
 src/org/apache/bcel/classfile/MethodParameter.java |  120 +
 .../apache/bcel/classfile/MethodParameters.java    |   86 +
 src/org/apache/bcel/classfile/Module.java          |  257 ++
 src/org/apache/bcel/classfile/ModuleExports.java   |  125 +
 src/org/apache/bcel/classfile/ModuleMainClass.java |  137 +
 src/org/apache/bcel/classfile/ModuleOpens.java     |  125 +
 src/org/apache/bcel/classfile/ModulePackages.java  |  175 ++
 src/org/apache/bcel/classfile/ModuleProvides.java  |  121 +
 src/org/apache/bcel/classfile/ModuleRequires.java  |  114 +
 src/org/apache/bcel/classfile/NestHost.java        |  138 +
 src/org/apache/bcel/classfile/NestMembers.java     |  176 ++
 src/org/apache/bcel/classfile/Node.java            |   27 +
 src/org/apache/bcel/classfile/PMGClass.java        |  172 ++
 .../bcel/classfile/ParameterAnnotationEntry.java   |   91 +
 .../bcel/classfile/ParameterAnnotations.java       |  122 +
 .../classfile/RuntimeInvisibleAnnotations.java     |   65 +
 .../RuntimeInvisibleParameterAnnotations.java      |   43 +
 .../bcel/classfile/RuntimeVisibleAnnotations.java  |   64 +
 .../RuntimeVisibleParameterAnnotations.java        |   43 +
 src/org/apache/bcel/classfile/Signature.java       |  269 ++
 .../apache/bcel/classfile/SimpleElementValue.java  |  225 ++
 src/org/apache/bcel/classfile/SourceFile.java      |  149 +
 src/org/apache/bcel/classfile/StackMap.java        |  160 ++
 src/org/apache/bcel/classfile/StackMapEntry.java   |  435 +++
 src/org/apache/bcel/classfile/StackMapType.java    |  166 ++
 src/org/apache/bcel/classfile/Synthetic.java       |  155 +
 src/org/apache/bcel/classfile/Unknown.java         |  188 ++
 .../bcel/classfile/UnknownAttributeReader.java     |   49 +
 src/org/apache/bcel/classfile/Utility.java         | 1655 +++++++++++
 src/org/apache/bcel/classfile/Visitor.java         |  235 ++
 src/org/apache/bcel/generic/AALOAD.java            |   50 +
 src/org/apache/bcel/generic/AASTORE.java           |   50 +
 src/org/apache/bcel/generic/ACONST_NULL.java       |   58 +
 src/org/apache/bcel/generic/ALOAD.java             |   57 +
 src/org/apache/bcel/generic/ANEWARRAY.java         |   78 +
 src/org/apache/bcel/generic/ARETURN.java           |   51 +
 src/org/apache/bcel/generic/ARRAYLENGTH.java       |   60 +
 src/org/apache/bcel/generic/ASTORE.java            |   57 +
 src/org/apache/bcel/generic/ATHROW.java            |   61 +
 .../apache/bcel/generic/AllocationInstruction.java |   25 +
 .../bcel/generic/AnnotationElementValueGen.java    |   86 +
 .../apache/bcel/generic/AnnotationEntryGen.java    |  355 +++
 .../apache/bcel/generic/ArithmeticInstruction.java |   95 +
 .../apache/bcel/generic/ArrayElementValueGen.java  |  127 +
 src/org/apache/bcel/generic/ArrayInstruction.java  |   85 +
 src/org/apache/bcel/generic/ArrayType.java         |  128 +
 src/org/apache/bcel/generic/BALOAD.java            |   50 +
 src/org/apache/bcel/generic/BASTORE.java           |   50 +
 src/org/apache/bcel/generic/BIPUSH.java            |  111 +
 src/org/apache/bcel/generic/BREAKPOINT.java        |   43 +
 src/org/apache/bcel/generic/BasicType.java         |   83 +
 src/org/apache/bcel/generic/BranchHandle.java      |  111 +
 src/org/apache/bcel/generic/BranchInstruction.java |  283 ++
 src/org/apache/bcel/generic/CALOAD.java            |   50 +
 src/org/apache/bcel/generic/CASTORE.java           |   50 +
 src/org/apache/bcel/generic/CHECKCAST.java         |   83 +
 src/org/apache/bcel/generic/CPInstruction.java     |  149 +
 .../apache/bcel/generic/ClassElementValueGen.java  |  103 +
 src/org/apache/bcel/generic/ClassGen.java          |  607 ++++
 src/org/apache/bcel/generic/ClassGenException.java |   41 +
 src/org/apache/bcel/generic/ClassObserver.java     |   28 +
 src/org/apache/bcel/generic/CodeExceptionGen.java  |  186 ++
 .../apache/bcel/generic/CompoundInstruction.java   |   37 +
 src/org/apache/bcel/generic/ConstantPoolGen.java   |  862 ++++++
 .../bcel/generic/ConstantPushInstruction.java      |   31 +
 .../apache/bcel/generic/ConversionInstruction.java |   77 +
 src/org/apache/bcel/generic/D2F.java               |   50 +
 src/org/apache/bcel/generic/D2I.java               |   50 +
 src/org/apache/bcel/generic/D2L.java               |   50 +
 src/org/apache/bcel/generic/DADD.java              |   51 +
 src/org/apache/bcel/generic/DALOAD.java            |   50 +
 src/org/apache/bcel/generic/DASTORE.java           |   50 +
 src/org/apache/bcel/generic/DCMPG.java             |   53 +
 src/org/apache/bcel/generic/DCMPL.java             |   53 +
 src/org/apache/bcel/generic/DCONST.java            |   82 +
 src/org/apache/bcel/generic/DDIV.java              |   51 +
 src/org/apache/bcel/generic/DLOAD.java             |   57 +
 src/org/apache/bcel/generic/DMUL.java              |   51 +
 src/org/apache/bcel/generic/DNEG.java              |   48 +
 src/org/apache/bcel/generic/DREM.java              |   51 +
 src/org/apache/bcel/generic/DRETURN.java           |   50 +
 src/org/apache/bcel/generic/DSTORE.java            |   57 +
 src/org/apache/bcel/generic/DSUB.java              |   51 +
 src/org/apache/bcel/generic/DUP.java               |   47 +
 src/org/apache/bcel/generic/DUP2.java              |   47 +
 src/org/apache/bcel/generic/DUP2_X1.java           |   45 +
 src/org/apache/bcel/generic/DUP2_X2.java           |   45 +
 src/org/apache/bcel/generic/DUP_X1.java            |   45 +
 src/org/apache/bcel/generic/DUP_X2.java            |   45 +
 src/org/apache/bcel/generic/ElementValueGen.java   |  194 ++
 .../apache/bcel/generic/ElementValuePairGen.java   |  115 +
 src/org/apache/bcel/generic/EmptyVisitor.java      |  931 ++++++
 .../apache/bcel/generic/EnumElementValueGen.java   |  142 +
 src/org/apache/bcel/generic/ExceptionThrower.java  |   41 +
 src/org/apache/bcel/generic/F2D.java               |   50 +
 src/org/apache/bcel/generic/F2I.java               |   50 +
 src/org/apache/bcel/generic/F2L.java               |   50 +
 src/org/apache/bcel/generic/FADD.java              |   50 +
 src/org/apache/bcel/generic/FALOAD.java            |   50 +
 src/org/apache/bcel/generic/FASTORE.java           |   50 +
 src/org/apache/bcel/generic/FCMPG.java             |   55 +
 src/org/apache/bcel/generic/FCMPL.java             |   55 +
 src/org/apache/bcel/generic/FCONST.java            |   84 +
 src/org/apache/bcel/generic/FDIV.java              |   50 +
 src/org/apache/bcel/generic/FLOAD.java             |   57 +
 src/org/apache/bcel/generic/FMUL.java              |   50 +
 src/org/apache/bcel/generic/FNEG.java              |   48 +
 src/org/apache/bcel/generic/FREM.java              |   50 +
 src/org/apache/bcel/generic/FRETURN.java           |   50 +
 src/org/apache/bcel/generic/FSTORE.java            |   57 +
 src/org/apache/bcel/generic/FSUB.java              |   50 +
 src/org/apache/bcel/generic/FieldGen.java          |  381 +++
 .../apache/bcel/generic/FieldGenOrMethodGen.java   |  190 ++
 src/org/apache/bcel/generic/FieldInstruction.java  |   81 +
 src/org/apache/bcel/generic/FieldObserver.java     |   28 +
 src/org/apache/bcel/generic/FieldOrMethod.java     |  140 +
 src/org/apache/bcel/generic/GETFIELD.java          |   80 +
 src/org/apache/bcel/generic/GETSTATIC.java         |   78 +
 src/org/apache/bcel/generic/GOTO.java              |   98 +
 src/org/apache/bcel/generic/GOTO_W.java            |   82 +
 src/org/apache/bcel/generic/GotoInstruction.java   |   37 +
 src/org/apache/bcel/generic/I2B.java               |   50 +
 src/org/apache/bcel/generic/I2C.java               |   50 +
 src/org/apache/bcel/generic/I2D.java               |   50 +
 src/org/apache/bcel/generic/I2F.java               |   50 +
 src/org/apache/bcel/generic/I2L.java               |   50 +
 src/org/apache/bcel/generic/I2S.java               |   48 +
 src/org/apache/bcel/generic/IADD.java              |   50 +
 src/org/apache/bcel/generic/IALOAD.java            |   51 +
 src/org/apache/bcel/generic/IAND.java              |   48 +
 src/org/apache/bcel/generic/IASTORE.java           |   51 +
 src/org/apache/bcel/generic/ICONST.java            |   80 +
 src/org/apache/bcel/generic/IDIV.java              |   63 +
 src/org/apache/bcel/generic/IFEQ.java              |   65 +
 src/org/apache/bcel/generic/IFGE.java              |   65 +
 src/org/apache/bcel/generic/IFGT.java              |   65 +
 src/org/apache/bcel/generic/IFLE.java              |   65 +
 src/org/apache/bcel/generic/IFLT.java              |   65 +
 src/org/apache/bcel/generic/IFNE.java              |   65 +
 src/org/apache/bcel/generic/IFNONNULL.java         |   65 +
 src/org/apache/bcel/generic/IFNULL.java            |   65 +
 src/org/apache/bcel/generic/IF_ACMPEQ.java         |   65 +
 src/org/apache/bcel/generic/IF_ACMPNE.java         |   65 +
 src/org/apache/bcel/generic/IF_ICMPEQ.java         |   65 +
 src/org/apache/bcel/generic/IF_ICMPGE.java         |   65 +
 src/org/apache/bcel/generic/IF_ICMPGT.java         |   65 +
 src/org/apache/bcel/generic/IF_ICMPLE.java         |   65 +
 src/org/apache/bcel/generic/IF_ICMPLT.java         |   65 +
 src/org/apache/bcel/generic/IF_ICMPNE.java         |   65 +
 src/org/apache/bcel/generic/IINC.java              |  169 ++
 src/org/apache/bcel/generic/ILOAD.java             |   57 +
 src/org/apache/bcel/generic/IMPDEP1.java           |   43 +
 src/org/apache/bcel/generic/IMPDEP2.java           |   43 +
 src/org/apache/bcel/generic/IMUL.java              |   50 +
 src/org/apache/bcel/generic/INEG.java              |   48 +
 src/org/apache/bcel/generic/INSTANCEOF.java        |   77 +
 src/org/apache/bcel/generic/INVOKEDYNAMIC.java     |  144 +
 src/org/apache/bcel/generic/INVOKEINTERFACE.java   |  138 +
 src/org/apache/bcel/generic/INVOKESPECIAL.java     |   91 +
 src/org/apache/bcel/generic/INVOKESTATIC.java      |   88 +
 src/org/apache/bcel/generic/INVOKEVIRTUAL.java     |   90 +
 src/org/apache/bcel/generic/IOR.java               |   48 +
 src/org/apache/bcel/generic/IREM.java              |   63 +
 src/org/apache/bcel/generic/IRETURN.java           |   50 +
 src/org/apache/bcel/generic/ISHL.java              |   48 +
 src/org/apache/bcel/generic/ISHR.java              |   48 +
 src/org/apache/bcel/generic/ISTORE.java            |   57 +
 src/org/apache/bcel/generic/ISUB.java              |   50 +
 src/org/apache/bcel/generic/IUSHR.java             |   48 +
 src/org/apache/bcel/generic/IXOR.java              |   48 +
 src/org/apache/bcel/generic/IfInstruction.java     |   47 +
 .../apache/bcel/generic/IndexedInstruction.java    |   31 +
 src/org/apache/bcel/generic/Instruction.java       |  608 ++++
 .../apache/bcel/generic/InstructionComparator.java |   60 +
 src/org/apache/bcel/generic/InstructionConst.java  |  296 ++
 .../apache/bcel/generic/InstructionConstants.java  |  291 ++
 .../apache/bcel/generic/InstructionFactory.java    |  800 ++++++
 src/org/apache/bcel/generic/InstructionHandle.java |  315 +++
 src/org/apache/bcel/generic/InstructionList.java   | 1258 +++++++++
 .../bcel/generic/InstructionListObserver.java      |   28 +
 .../apache/bcel/generic/InstructionTargeter.java   |   44 +
 src/org/apache/bcel/generic/InvokeInstruction.java |  147 +
 src/org/apache/bcel/generic/JSR.java               |   89 +
 src/org/apache/bcel/generic/JSR_W.java             |   82 +
 src/org/apache/bcel/generic/JsrInstruction.java    |   79 +
 src/org/apache/bcel/generic/L2D.java               |   48 +
 src/org/apache/bcel/generic/L2F.java               |   48 +
 src/org/apache/bcel/generic/L2I.java               |   48 +
 src/org/apache/bcel/generic/LADD.java              |   49 +
 src/org/apache/bcel/generic/LALOAD.java            |   50 +
 src/org/apache/bcel/generic/LAND.java              |   49 +
 src/org/apache/bcel/generic/LASTORE.java           |   50 +
 src/org/apache/bcel/generic/LCMP.java              |   56 +
 src/org/apache/bcel/generic/LCONST.java            |   82 +
 src/org/apache/bcel/generic/LDC.java               |  156 ++
 src/org/apache/bcel/generic/LDC2_W.java            |   83 +
 src/org/apache/bcel/generic/LDC_W.java             |   55 +
 src/org/apache/bcel/generic/LDIV.java              |   60 +
 src/org/apache/bcel/generic/LLOAD.java             |   54 +
 src/org/apache/bcel/generic/LMUL.java              |   49 +
 src/org/apache/bcel/generic/LNEG.java              |   48 +
 src/org/apache/bcel/generic/LOOKUPSWITCH.java      |  103 +
 src/org/apache/bcel/generic/LOR.java               |   48 +
 src/org/apache/bcel/generic/LREM.java              |   59 +
 src/org/apache/bcel/generic/LRETURN.java           |   48 +
 src/org/apache/bcel/generic/LSHL.java              |   48 +
 src/org/apache/bcel/generic/LSHR.java              |   48 +
 src/org/apache/bcel/generic/LSTORE.java            |   54 +
 src/org/apache/bcel/generic/LSUB.java              |   49 +
 src/org/apache/bcel/generic/LUSHR.java             |   48 +
 src/org/apache/bcel/generic/LXOR.java              |   48 +
 src/org/apache/bcel/generic/LineNumberGen.java     |  110 +
 src/org/apache/bcel/generic/LoadClass.java         |   49 +
 src/org/apache/bcel/generic/LoadInstruction.java   |   63 +
 src/org/apache/bcel/generic/LocalVariableGen.java  |  262 ++
 .../bcel/generic/LocalVariableInstruction.java     |  231 ++
 src/org/apache/bcel/generic/MONITORENTER.java      |   56 +
 src/org/apache/bcel/generic/MONITOREXIT.java       |   56 +
 src/org/apache/bcel/generic/MULTIANEWARRAY.java    |  151 +
 src/org/apache/bcel/generic/MethodGen.java         | 1315 +++++++++
 src/org/apache/bcel/generic/MethodObserver.java    |   28 +
 src/org/apache/bcel/generic/NEW.java               |   75 +
 src/org/apache/bcel/generic/NEWARRAY.java          |  126 +
 src/org/apache/bcel/generic/NOP.java               |   43 +
 .../bcel/generic/NameSignatureInstruction.java     |   62 +
 src/org/apache/bcel/generic/NamedAndTyped.java     |   37 +
 src/org/apache/bcel/generic/ObjectType.java        |  163 ++
 src/org/apache/bcel/generic/POP.java               |   48 +
 src/org/apache/bcel/generic/POP2.java              |   48 +
 src/org/apache/bcel/generic/PUSH.java              |  191 ++
 src/org/apache/bcel/generic/PUTFIELD.java          |   79 +
 src/org/apache/bcel/generic/PUTSTATIC.java         |   78 +
 src/org/apache/bcel/generic/PopInstruction.java    |   28 +
 src/org/apache/bcel/generic/PushInstruction.java   |   33 +
 src/org/apache/bcel/generic/RET.java               |  146 +
 src/org/apache/bcel/generic/RETURN.java            |   48 +
 src/org/apache/bcel/generic/ReferenceType.java     |  329 +++
 src/org/apache/bcel/generic/ReturnInstruction.java |   81 +
 src/org/apache/bcel/generic/ReturnaddressType.java |   83 +
 src/org/apache/bcel/generic/SALOAD.java            |   48 +
 src/org/apache/bcel/generic/SASTORE.java           |   48 +
 src/org/apache/bcel/generic/SIPUSH.java            |  109 +
 src/org/apache/bcel/generic/SWAP.java              |   47 +
 src/org/apache/bcel/generic/SWITCH.java            |  155 +
 src/org/apache/bcel/generic/Select.java            |  392 +++
 .../apache/bcel/generic/SimpleElementValueGen.java |  269 ++
 src/org/apache/bcel/generic/StackConsumer.java     |   29 +
 src/org/apache/bcel/generic/StackInstruction.java  |   47 +
 src/org/apache/bcel/generic/StackProducer.java     |   30 +
 src/org/apache/bcel/generic/StoreInstruction.java  |   63 +
 src/org/apache/bcel/generic/TABLESWITCH.java       |  112 +
 .../apache/bcel/generic/TargetLostException.java   |   65 +
 src/org/apache/bcel/generic/Type.java              |  404 +++
 src/org/apache/bcel/generic/TypedInstruction.java  |   28 +
 .../apache/bcel/generic/UnconditionalBranch.java   |   28 +
 .../bcel/generic/VariableLengthInstruction.java    |   31 +
 src/org/apache/bcel/generic/Visitor.java           |  573 ++++
 .../bcel/util/AbstractClassPathRepository.java     |  138 +
 src/org/apache/bcel/util/AttributeHTML.java        |  212 ++
 src/org/apache/bcel/util/BCELComparator.java       |   44 +
 src/org/apache/bcel/util/BCELFactory.java          |  346 +++
 src/org/apache/bcel/util/BCELifier.java            |  302 ++
 src/org/apache/bcel/util/ByteSequence.java         |   66 +
 src/org/apache/bcel/util/Class2HTML.java           |  237 ++
 src/org/apache/bcel/util/ClassLoader.java          |  192 ++
 .../apache/bcel/util/ClassLoaderRepository.java    |  122 +
 src/org/apache/bcel/util/ClassPath.java            |  806 ++++++
 src/org/apache/bcel/util/ClassPathRepository.java  |   71 +
 src/org/apache/bcel/util/ClassQueue.java           |   57 +
 src/org/apache/bcel/util/ClassSet.java             |   69 +
 src/org/apache/bcel/util/ClassStack.java           |   52 +
 src/org/apache/bcel/util/ClassVector.java          |   60 +
 src/org/apache/bcel/util/CodeHTML.java             |  582 ++++
 src/org/apache/bcel/util/ConstantHTML.java         |  232 ++
 src/org/apache/bcel/util/InstructionFinder.java    |  419 +++
 src/org/apache/bcel/util/JavaWrapper.java          |  113 +
 .../bcel/util/LruCacheClassPathRepository.java     |   79 +
 .../util/MemorySensitiveClassPathRepository.java   |   78 +
 src/org/apache/bcel/util/MethodHTML.java           |  158 ++
 src/org/apache/bcel/util/ModularRuntimeImage.java  |  152 +
 src/org/apache/bcel/util/Repository.java           |   64 +
 src/org/apache/bcel/util/SyntheticRepository.java  |   55 +
 .../apache/bcel/verifier/GraphicalVerifier.java    |   72 +
 src/org/apache/bcel/verifier/NativeVerifier.java   |   72 +
 src/org/apache/bcel/verifier/PassVerifier.java     |  104 +
 src/org/apache/bcel/verifier/TransitiveHull.java   |  104 +
 .../apache/bcel/verifier/VerificationResult.java   |  126 +
 src/org/apache/bcel/verifier/Verifier.java         |  246 ++
 src/org/apache/bcel/verifier/VerifierAppFrame.java |  384 +++
 src/org/apache/bcel/verifier/VerifierFactory.java  |  106 +
 .../bcel/verifier/VerifierFactoryListModel.java    |   76 +
 .../bcel/verifier/VerifierFactoryObserver.java     |   38 +
 src/org/apache/bcel/verifier/VerifyDialog.java     |  563 ++++
 .../verifier/exc/AssertionViolatedException.java   |   86 +
 .../verifier/exc/ClassConstraintException.java     |   51 +
 .../bcel/verifier/exc/CodeConstraintException.java |   40 +
 .../bcel/verifier/exc/InvalidMethodException.java  |   33 +
 .../verifier/exc/LinkingConstraintException.java   |   38 +
 .../apache/bcel/verifier/exc/LoadingException.java |   43 +
 .../LocalVariableInfoInconsistentException.java    |   45 +
 .../exc/StaticCodeConstraintException.java         |   35 +
 .../StaticCodeInstructionConstraintException.java  |   38 +
 ...cCodeInstructionOperandConstraintException.java |   38 +
 .../exc/StructuralCodeConstraintException.java     |   45 +
 src/org/apache/bcel/verifier/exc/Utility.java      |   39 +
 .../bcel/verifier/exc/VerificationException.java   |   53 +
 .../exc/VerifierConstraintViolatedException.java   |   84 +
 .../apache/bcel/verifier/statics/DOUBLE_Upper.java |   45 +
 src/org/apache/bcel/verifier/statics/IntList.java  |   50 +
 .../apache/bcel/verifier/statics/LONG_Upper.java   |   45 +
 .../bcel/verifier/statics/LocalVariableInfo.java   |  120 +
 .../bcel/verifier/statics/LocalVariablesInfo.java  |   82 +
 .../bcel/verifier/statics/Pass1Verifier.java       |  199 ++
 .../bcel/verifier/statics/Pass2Verifier.java       | 1574 +++++++++++
 .../bcel/verifier/statics/Pass3aVerifier.java      | 1342 +++++++++
 .../verifier/statics/StringRepresentation.java     |  416 +++
 .../verifier/structurals/ControlFlowGraph.java     |  476 ++++
 .../verifier/structurals/ExceptionHandler.java     |   56 +
 .../verifier/structurals/ExceptionHandlers.java    |   73 +
 .../verifier/structurals/ExecutionVisitor.java     | 1273 +++++++++
 .../apache/bcel/verifier/structurals/Frame.java    |  141 +
 .../bcel/verifier/structurals/GenericArray.java    |   35 +
 .../structurals/InstConstraintVisitor.java         | 2961 ++++++++++++++++++++
 .../verifier/structurals/InstructionContext.java   |  106 +
 .../bcel/verifier/structurals/LocalVariables.java  |  232 ++
 .../bcel/verifier/structurals/OperandStack.java    |  273 ++
 .../bcel/verifier/structurals/Pass3bVerifier.java  |  446 +++
 .../bcel/verifier/structurals/Subroutine.java      |   90 +
 .../bcel/verifier/structurals/Subroutines.java     |  682 +++++
 .../structurals/UninitializedObjectType.java       |   69 +
 393 files changed, 63432 insertions(+), 19 deletions(-)

diff --git a/.settings/org.eclipse.jdt.core.prefs \
b/.settings/org.eclipse.jdt.core.prefs index bfab4f07..5917cfb9 100644
--- a/.settings/org.eclipse.jdt.core.prefs
+++ b/.settings/org.eclipse.jdt.core.prefs
@@ -1,15 +1,18 @@
-#Thu Feb 19 19:22:46 EST 2009
 eclipse.preferences.version=1
 org.eclipse.jdt.core.compiler.codegen.inlineJsrBytecode=enabled
-org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.1
+org.eclipse.jdt.core.compiler.codegen.methodParameters=do not generate
+org.eclipse.jdt.core.compiler.codegen.targetPlatform=1.8
 org.eclipse.jdt.core.compiler.codegen.unusedLocal=preserve
-org.eclipse.jdt.core.compiler.compliance=1.3
+org.eclipse.jdt.core.compiler.compliance=1.8
 org.eclipse.jdt.core.compiler.debug.lineNumber=generate
 org.eclipse.jdt.core.compiler.debug.localVariable=generate
 org.eclipse.jdt.core.compiler.debug.sourceFile=generate
-org.eclipse.jdt.core.compiler.problem.assertIdentifier=ignore
-org.eclipse.jdt.core.compiler.problem.enumIdentifier=ignore
-org.eclipse.jdt.core.compiler.source=1.3
+org.eclipse.jdt.core.compiler.problem.assertIdentifier=error
+org.eclipse.jdt.core.compiler.problem.enablePreviewFeatures=disabled
+org.eclipse.jdt.core.compiler.problem.enumIdentifier=error
+org.eclipse.jdt.core.compiler.problem.reportPreviewFeatures=warning
+org.eclipse.jdt.core.compiler.release=disabled
+org.eclipse.jdt.core.compiler.source=1.8
 org.eclipse.jdt.core.formatter.align_type_members_on_columns=false
 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_allocation_expression=16
 org.eclipse.jdt.core.formatter.alignment_for_arguments_in_enum_constant=16
diff --git a/build.xml b/build.xml
index 7b93569d..6c9b9ce7 100644
--- a/build.xml
+++ b/build.xml
@@ -102,8 +102,6 @@ $Id$
   <property name="xmlapis.jar"            \
value="${endorsed.dir}/${xmlapis.jar.name}"/>  <property name="parser.jar.name"       \
value="xercesImpl.jar"/>  <property name="parser.jar"             \
                value="${endorsed.dir}/${parser.jar.name}"/>
-  <property name="bcel.jar.name"          value="BCEL.jar"/>
-  <property name="bcel.jar"               value="${lib.dir}/${bcel.jar.name}"/>
   <property name="runtime.jar.name"       value="runtime.jar"/>
   <property name="runtime.jar"            value="${lib.dir}/${runtime.jar.name}"/>
   <property name="regexp.jar.name"        value="regexp.jar"/>
@@ -209,7 +207,6 @@ $Id$
   <path id="docs.class.path">
     <pathelement location="${xmlapis.jar}" />
     <pathelement location="${parser.jar}" />
-    <pathelement location="${bcel.jar}" />
     <pathelement location="${runtime.jar}" />
     <pathelement location="${stylebook.jar}" />
     <pathelement location="${doclet.jar}" />
@@ -310,8 +307,7 @@ $Id$
   </patternset>
 
   <!-- XSLTC engine dependency .jar files -->    
-  <patternset id="xsltc-deps-jars" >
-    <include name="${dist.file}/lib/${bcel.jar.name}"/>
+  <patternset id="xsltc-deps-jars">
     <include name="${dist.file}/tools/${java_cup.jar.name}"/>
     <include name="${dist.file}/tools/${jlex.jar.name}"/>
     <include name="${dist.file}/lib/${runtime.jar.name}"/>
@@ -440,7 +436,6 @@ $Id$
   <path id="xsltc.class.path">
     <pathelement location="${xmlapis.jar}" />
     <pathelement location="${build.serializer.jar}" />
-    <pathelement location="${bcel.jar}" />
     <pathelement location="${jlex.jar}" />
     <pathelement location="${java_cup.jar}" />
     <pathelement location="${runtime.jar}" />
@@ -475,8 +470,7 @@ $Id$
       <srcfiles dir="${src.dir}/${xsltc.reldir}/compiler" includes="xpath.lex" />
     </uptodate> 
     
-    <!-- Determine whether the support jars are already expanded -->
-    <available file="${build.classes}/org/apache/bcel"     type="dir" \
property="xsltc.bcel_jar.not_needed" /> +    <!-- Determine whether the support jars \
                are already expanded -->    
     <available file="${build.classes}/JLex"                type="dir" \
                property="xsltc.jlex_jar.not_needed" />
     <available file="${build.classes}/java_cup/Main.class" type="file" \
                property="xsltc.java_cup_jar.not_needed" />
     <available file="${build.classes}/java_cup/runtime"    type="dir" \
property="xsltc.runtime_jar.not_needed" /> @@ -580,10 +574,10 @@ $Id$
   <target name="xsltc.copy-deps-jars" depends="xsltc.copy-licenses">
     <echo message="Copying XSLTC support jars" />
     <!-- copy the 3rd party support jar files -->
-    <antcall target="xsltc.copy-deps-jar">
+    <!--<antcall target="xsltc.copy-deps-jar">
       <param name="param_unless" value="xsltc.bcel_jar.not_needed" />
       <param name="param_jar_name" value="${bcel.jar.name}" />
-    </antcall>
+    </antcall>-->
 
 <!-- We don't need to package the JLex or java_cup jars in the xalan.jar.
      These are only required for building XSLTC, not for using XSLTC.
@@ -617,7 +611,7 @@ $Id$
   <!-- Creates the xsltc jar including all support jars                    -->
   <!-- =================================================================== -->
   <target name="xsltc.jar" depends="xsltc.compile,xsltc.copy-deps-jars"
-     description="Jar xsltc,xml,BCEL,JLex,java_cup,runtime and jakarta regexp">
+     description="Jar xsltc,xml,JLex,java_cup,runtime and jakarta regexp">
 
     <!-- create new META-INF dir w/ transformer factory default -->
     <!-- GTM: comment this out so that bundled xsltc.jar does not have
@@ -643,7 +637,6 @@ $Id$
       </fileset>
       <fileset dir="${build.classes}" includes="org/apache/xml/**" 
                                       excludes="${serializer.reldir}/**" />
-      <fileset dir="${build.classes}" includes="org/apache/bcel/**" />
       <fileset dir="${build.classes}" includes="JLex/**" />
       <fileset dir="${build.classes}" includes="java_cup/**" />
       <fileset dir="${build.classes}" includes="org/apache/regexp/**" />
@@ -892,7 +885,7 @@ $Id$
   <!-- =================================================================== -->
   <!-- Compiles (does not jar) the translet samples.                       -->
   <!-- For time being, classes are generated in place.                     -->
-  <!-- To run these samples, add xsltc.jar, runtime.jar, bcel.jar,         -->
+  <!-- To run these samples, add xsltc.jar, runtime.jar,                   -->
   <!-- and java_cup.jar (all in the bin directory) to the classpath        --> 
   <!--                                                                     -->
   <!-- When we have straightened out classpath issues,                     -->
diff --git a/src/org/apache/bcel/Const.java b/src/org/apache/bcel/Const.java
new file mode 100644
index 00000000..b79b0461
--- /dev/null
+++ b/src/org/apache/bcel/Const.java
@@ -0,0 +1,2438 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel;
+
+import java.util.Arrays;
+import java.util.Collections;
+
+/**
+ * Constants for the project, mostly defined in the JVM specification.
+ *
+ * @since 6.0 (intended to replace the Constants interface)
+ */
+public final class Const {
+
+  /**
+   * Java class file format Magic number (0xCAFEBABE)
+   *
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se7/html/jvms-4.html#jvms-4.1-200-A">
 +   * The ClassFile Structure in The Java Virtual Machine Specification</a>
+   */
+  public static final int JVM_CLASSFILE_MAGIC = 0xCAFEBABE;
+
+  /** Major version number of class files for Java 1.1.
+   *  @see #MINOR_1_1
+   *  */
+  public static final short MAJOR_1_1 = 45;
+
+  /** Minor version number of class files for Java 1.1.
+   *  @see #MAJOR_1_1
+   *  */
+  public static final short MINOR_1_1 = 3;
+
+  /** Major version number of class files for Java 1.2.
+   *  @see #MINOR_1_2
+   *  */
+  public static final short MAJOR_1_2 = 46;
+
+  /** Minor version number of class files for Java 1.2.
+   *  @see #MAJOR_1_2
+   *  */
+  public static final short MINOR_1_2 = 0;
+
+  /** Major version number of class files for Java 1.2.
+   *  @see #MINOR_1_2
+   *  */
+  public static final short MAJOR_1_3 = 47;
+
+  /** Minor version number of class files for Java 1.3.
+   *  @see #MAJOR_1_3
+   *  */
+  public static final short MINOR_1_3 = 0;
+
+  /** Major version number of class files for Java 1.3.
+   *  @see #MINOR_1_3
+   *  */
+  public static final short MAJOR_1_4 = 48;
+
+  /** Minor version number of class files for Java 1.4.
+   *  @see #MAJOR_1_4
+   *  */
+  public static final short MINOR_1_4 = 0;
+
+  /** Major version number of class files for Java 1.4.
+   *  @see #MINOR_1_4
+   *  */
+  public static final short MAJOR_1_5 = 49;
+
+  /** Minor version number of class files for Java 1.5.
+   *  @see #MAJOR_1_5
+   *  */
+  public static final short MINOR_1_5 = 0;
+
+  /** Major version number of class files for Java 1.6.
+   *  @see #MINOR_1_6
+   *  */
+  public static final short MAJOR_1_6 = 50;
+
+  /** Minor version number of class files for Java 1.6.
+   *  @see #MAJOR_1_6
+   *  */
+  public static final short MINOR_1_6 = 0;
+
+  /** Major version number of class files for Java 1.7.
+   *  @see #MINOR_1_7
+   *  */
+  public static final short MAJOR_1_7 = 51;
+
+  /** Minor version number of class files for Java 1.7.
+   *  @see #MAJOR_1_7
+   *  */
+  public static final short MINOR_1_7 = 0;
+
+  /** Major version number of class files for Java 1.8.
+   *  @see #MINOR_1_8
+   *  */
+  public static final short MAJOR_1_8 = 52;
+
+  /** Minor version number of class files for Java 1.8.
+   *  @see #MAJOR_1_8
+   *  */
+  public static final short MINOR_1_8 = 0;
+
+  /** Major version number of class files for Java 9.
+   *  @see #MINOR_9
+   *  */
+  public static final short MAJOR_9 = 53;
+
+  /** Minor version number of class files for Java 9.
+   *  @see #MAJOR_9
+   *  */
+  public static final short MINOR_9 = 0;
+
+  /**
+   * @deprecated Use {@link #MAJOR_9} instead
+   */
+  @Deprecated
+  public static final short MAJOR_1_9 = MAJOR_9;
+
+  /**
+   * @deprecated Use {@link #MINOR_9} instead
+   */
+  @Deprecated
+  public static final short MINOR_1_9 = MINOR_9;
+
+  /** Major version number of class files for Java 10.
+   *  @see #MINOR_10
+   *  */
+  public static final short MAJOR_10 = 54;
+
+  /** Minor version number of class files for Java 10.
+   *  @see #MAJOR_10
+   *  */
+  public static final short MINOR_10 = 0;
+
+  /** Major version number of class files for Java 11.
+   *  @see #MINOR_11
+   *  */
+  public static final short MAJOR_11 = 55;
+
+  /** Minor version number of class files for Java 11.
+   *  @see #MAJOR_11
+   *  */
+  public static final short MINOR_11 = 0;
+
+  /** Major version number of class files for Java 12.
+   *  @see #MINOR_12
+   *  */
+  public static final short MAJOR_12 = 56;
+
+  /** Minor version number of class files for Java 12.
+   *  @see #MAJOR_12
+   *  */
+  public static final short MINOR_12 = 0;
+
+  /** Major version number of class files for Java 13.
+   *  @see #MINOR_13
+   *  */
+  public static final short MAJOR_13 = 57;
+
+  /** Minor version number of class files for Java 13.
+   *  @see #MAJOR_13
+   *  */
+  public static final short MINOR_13 = 0;
+
+  /** Major version number of class files for Java 14.
+   *  @see #MINOR_14
+   *  @since 6.4.0
+   *  */
+  public static final short MAJOR_14 = 58;
+
+  /** Minor version number of class files for Java 14.
+   *  @see #MAJOR_14
+   *  @since 6.4.0
+   *  */
+  public static final short MINOR_14 = 0;
+
+  /** Default major version number.  Class file is for Java 1.1.
+   *  @see #MAJOR_1_1
+   *  */
+  public static final short MAJOR = MAJOR_1_1;
+
+  /** Default major version number.  Class file is for Java 1.1.
+   *  @see #MAJOR_1_1
+   *  */
+  public static final short MINOR     = MINOR_1_1;
+
+  /** Maximum value for an unsigned short.
+   */
+  public static final int MAX_SHORT = 65535; // 2^16 - 1
+
+  /** Maximum value for an unsigned byte.
+   */
+  public static final int MAX_BYTE  = 255; // 2^8 - 1
+
+  /** One of the access flags for fields, methods, or classes.
+   *
+   *  @see <a href="https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.1-200-E.1">
 +   *  Flag definitions for Classes in the Java Virtual Machine Specification (Java \
SE 9 Edition).</a> +   *  @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.5"> +   * \
Flag definitions for Fields in the Java Virtual Machine Specification (Java SE 9 \
Edition).</a> +   *  @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.6"> +   * \
Flag definitions for Methods in the Java Virtual Machine Specification (Java SE 9 \
Edition).</a> +   *  @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.7.6-300-D.1-D.1">
 +   *  Flag definitions for Inner Classes in the Java Virtual Machine Specification \
(Java SE 9 Edition).</a> +   */
+  public static final short ACC_PUBLIC       = 0x0001;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_PRIVATE      = 0x0002;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_PROTECTED    = 0x0004;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_STATIC       = 0x0008;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_FINAL        = 0x0010;
+
+  /** One of the access flags for the Module attribute.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_OPEN         = 0x0020;
+
+  /** One of the access flags for classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_SUPER        = 0x0020;
+
+  /** One of the access flags for methods.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_SYNCHRONIZED = 0x0020;
+
+  /** One of the access flags for the Module attribute.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_TRANSITIVE   = 0x0020;
+
+  /** One of the access flags for methods.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_BRIDGE       = 0x0040;
+
+  /** One of the access flags for the Module attribute.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_STATIC_PHASE = 0x0040;
+
+  /** One of the access flags for fields.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_VOLATILE     = 0x0040;
+
+  /** One of the access flags for fields.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_TRANSIENT    = 0x0080;
+
+  /** One of the access flags for methods.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_VARARGS      = 0x0080;
+
+  /** One of the access flags for methods.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_NATIVE       = 0x0100;
+
+  /** One of the access flags for classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_INTERFACE    = 0x0200;
+
+  /** One of the access flags for methods or classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_ABSTRACT     = 0x0400;
+
+  /** One of the access flags for methods.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_STRICT       = 0x0800;
+
+  /** One of the access flags for fields, methods, classes, MethodParameter \
attribute, or Module attribute. +   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_SYNTHETIC    = 0x1000;
+
+  /** One of the access flags for classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_ANNOTATION   = 0x2000;
+
+  /** One of the access flags for fields or classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_ENUM         = 0x4000;
+
+  // Applies to classes compiled by new compilers only
+  /** One of the access flags for MethodParameter or Module attributes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_MANDATED     = (short) 0x8000;
+
+  /** One of the access flags for classes.
+   *  @see #ACC_PUBLIC
+   */
+  public static final short ACC_MODULE       = (short) 0x8000;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   *  @deprecated Use {@link #MAX_ACC_FLAG_I}
+   */
+  @Deprecated
+  public static final short MAX_ACC_FLAG     = ACC_ENUM;
+
+  /** One of the access flags for fields, methods, or classes.
+   * ACC_MODULE is negative as a short.
+   * @see #ACC_PUBLIC
+   * @since 6.4.0
+   */
+  public static final int MAX_ACC_FLAG_I = 0x8000; // ACC_MODULE is negative as a \
short +
+  // Note that do to overloading:
+  // 'synchronized' is for methods, might be 'open' (if Module), 'super' (if class), \
or 'transitive' (if Module). +  // 'volatile'     is for fields,  might be 'bridge' \
(if method) or 'static_phase' (if Module) +  // 'transient'    is for fields,  might \
be 'varargs' (if method) +  // 'module'       is for classes, might be 'mandated' (if \
Module or MethodParameters) +  /**
+   * The names of the access flags.
+   */
+  private static final String[] ACCESS_NAMES = {
+    "public", "private", "protected", "static", "final", "synchronized",
+    "volatile", "transient", "native", "interface", "abstract", "strictfp",
+    "synthetic", "annotation", "enum", "module"
+  };
+
+  /** @since 6.0 */
+  public static final int ACCESS_NAMES_LENGTH = ACCESS_NAMES.length;
+
+  /**
+   * @param index
+   * @return the ACCESS_NAMES entry at the given index
+   * @since 6.0
+   */
+  public static String getAccessName(final int index) {
+      return ACCESS_NAMES[index];
+  }
+
+  /*
+   * The description of the constant pool is at:
+   * http://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4
+   * References below are to the individual sections
+   */
+
+  /**
+   * Marks a constant pool entry as type UTF-8.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.7">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Utf8               = 1;
+
+  /**
+   * Marks a constant pool entry as type Integer.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.4">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Integer            = 3;
+
+  /**
+   * Marks a constant pool entry as type Float.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.4">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Float              = 4;
+
+  /**
+   * Marks a constant pool entry as type Long.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.5">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Long               = 5;
+
+  /**
+   * Marks a constant pool entry as type Double.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.5">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Double             = 6;
+
+  /**
+   * Marks a constant pool entry as a Class
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.1">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Class              = 7;
+
+  /**
+   * Marks a constant pool entry as a Field Reference.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.2">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_Fieldref           = 9;
+
+  /**
+   * Marks a constant pool entry as type String
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.3">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_String             = 8;
+
+  /** Marks a constant pool entry as a Method Reference.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.2">
 +   * The Constant Pool in The Java Virtual Machine Specification</a> */
+  public static final byte CONSTANT_Methodref          = 10;
+
+  /**
+   * Marks a constant pool entry as an Interface Method Reference.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.2">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_InterfaceMethodref = 11;
+
+  /** Marks a constant pool entry as a name and type.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.6">
 +   * The Constant Pool in The Java Virtual Machine Specification</a> */
+  public static final byte CONSTANT_NameAndType        = 12;
+
+  /**
+   * Marks a constant pool entry as a Method Handle.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.8">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_MethodHandle       = 15;
+
+  /**
+   * Marks a constant pool entry as a Method Type.
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.9">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_MethodType         = 16;
+
+  /**
+   * Marks a constant pool entry as dynamically computed.
+   * @see  <a href="https://bugs.openjdk.java.net/secure/attachment/74618/constant-dynamic.html">
 +   * Change request for JEP 309</a>
+   * @since 6.3
+   */
+  public static final byte CONSTANT_Dynamic            = 17;
+
+  /**
+   * Marks a constant pool entry as an Invoke Dynamic
+   * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.10">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   */
+  public static final byte CONSTANT_InvokeDynamic      = 18;
+
+  /**
+   * Marks a constant pool entry as a Module Reference.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.4.11">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   * @since 6.1
+   */
+  public static final byte CONSTANT_Module             = 19;
+
+  /**
+   * Marks a constant pool entry as a Package Reference.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se9/html/jvms-4.html#jvms-4.4.12">
 +   * The Constant Pool in The Java Virtual Machine Specification</a>
+   * @since 6.1
+   */
+  public static final byte CONSTANT_Package            = 20;
+
+  /**
+   * The names of the types of entries in a constant pool.
+   * Use getConstantName instead
+   */
+  private static final String[] CONSTANT_NAMES = {
+    "", "CONSTANT_Utf8", "", "CONSTANT_Integer",
+    "CONSTANT_Float", "CONSTANT_Long", "CONSTANT_Double",
+    "CONSTANT_Class", "CONSTANT_String", "CONSTANT_Fieldref",
+    "CONSTANT_Methodref", "CONSTANT_InterfaceMethodref",
+    "CONSTANT_NameAndType", "", "", "CONSTANT_MethodHandle",
+    "CONSTANT_MethodType", "CONSTANT_Dynamic", "CONSTANT_InvokeDynamic",
+    "CONSTANT_Module", "CONSTANT_Package"};
+
+  /**
+   *
+   * @param index
+   * @return the CONSTANT_NAMES entry at the given index
+   * @since 6.0
+   */
+  public static String getConstantName(final int index) {
+      return CONSTANT_NAMES[index];
+  }
+
+  /** The name of the static initializer, also called &quot;class
+   *  initialization method&quot; or &quot;interface initialization
+   *   method&quot;. This is &quot;&lt;clinit&gt;&quot;.
+   */
+  public static final String STATIC_INITIALIZER_NAME = "<clinit>";
+
+  /** The name of every constructor method in a class, also called
+   * &quot;instance initialization method&quot;. This is &quot;&lt;init&gt;&quot;.
+   */
+  public static final String CONSTRUCTOR_NAME = "<init>";
+
+  /**
+   * The names of the interfaces implemented by arrays
+   */
+  private static final String[] INTERFACES_IMPLEMENTED_BY_ARRAYS = \
{"java.lang.Cloneable", "java.io.Serializable"}; +
+  /**
+   * @since 6.0
+   */
+  public static Iterable<String> getInterfacesImplementedByArrays() {
+      return Collections.unmodifiableList(Arrays.asList(INTERFACES_IMPLEMENTED_BY_ARRAYS));
 +  }
+
+  /**
+   * Maximum Constant Pool entries.
+   * One of the limitations of the Java Virtual Machine.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.11-100-A">
 +   * The Java Virtual Machine Specification, Java SE 8 Edition, page 330, chapter \
4.11.</a> +   */
+  public static final int MAX_CP_ENTRIES     = 65535;
+
+  /**
+   * Maximum code size (plus one; the code size must be LESS than this)
+   * One of the limitations of the Java Virtual Machine.
+   * Note vmspec2 page 152 ("Limitations") says:
+   * "The amount of code per non-native, non-abstract method is limited to 65536 \
bytes by +   * the sizes of the indices in the exception_table of the Code attribute \
( §4.7.3), +   * in the LineNumberTable attribute ( §4.7.8), and in the \
LocalVariableTable attribute ( §4.7.9)." +   * However this should be taken as an \
upper limit rather than the defined maximum. +   * On page 134 (4.8.1 Static \
Constants) of the same spec, it says: +   * "The value of the code_length item must \
be less than 65536." +   * The entry in the Limitations section has been removed from \
later versions of the spec; +   * it is not present in the Java SE 8 edition.
+   *
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.3-300-E">
 +   * The Java Virtual Machine Specification, Java SE 8 Edition, page 104, chapter \
4.7.</a> +   */
+  public static final int MAX_CODE_SIZE      = 65536; //bytes
+
+  /**
+   * The maximum number of dimensions in an array ({@value}).
+   * One of the limitations of the Java Virtual Machine.
+   *
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.3.2-150">
 +   * Field Descriptors in The Java Virtual Machine Specification</a>
+   */
+  public static final int MAX_ARRAY_DIMENSIONS = 255;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.nop">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short NOP              = 0;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aconst_null">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ACONST_NULL      = 1;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_M1        = 2;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_0         = 3;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_1         = 4;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_2         = 5;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_3         = 6;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_4         = 7;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iconst_i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ICONST_5         = 8;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lconst_l">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LCONST_0         = 9;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lconst_l">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LCONST_1         = 10;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fconst_f">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FCONST_0         = 11;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fconst_f">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FCONST_1         = 12;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fconst_f">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FCONST_2         = 13;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dconst_d">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DCONST_0         = 14;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dconst_d">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DCONST_1         = 15;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.bipush">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short BIPUSH           = 16;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.sipush">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short SIPUSH           = 17;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ldc">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LDC              = 18;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ldc_w">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LDC_W            = 19;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ldc2_w">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LDC2_W           = 20;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ILOAD            = 21;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LLOAD            = 22;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FLOAD            = 23;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DLOAD            = 24;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ALOAD            = 25;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ILOAD_0          = 26;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ILOAD_1          = 27;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ILOAD_2          = 28;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ILOAD_3          = 29;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LLOAD_0          = 30;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LLOAD_1          = 31;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LLOAD_2          = 32;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LLOAD_3          = 33;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FLOAD_0          = 34;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FLOAD_1          = 35;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FLOAD_2          = 36;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FLOAD_3          = 37;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DLOAD_0          = 38;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DLOAD_1          = 39;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DLOAD_2          = 40;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DLOAD_3          = 41;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ALOAD_0          = 42;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ALOAD_1          = 43;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ALOAD_2          = 44;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aload_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ALOAD_3          = 45;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iaload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IALOAD           = 46;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.laload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LALOAD           = 47;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.faload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FALOAD           = 48;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.daload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DALOAD           = 49;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aaload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short AALOAD           = 50;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.baload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short BALOAD           = 51;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.caload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short CALOAD           = 52;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.saload">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short SALOAD           = 53;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.istore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISTORE           = 54;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lstore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSTORE           = 55;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fstore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FSTORE           = 56;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dstore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DSTORE           = 57;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.astore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ASTORE           = 58;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.istore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISTORE_0         = 59;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.istore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISTORE_1         = 60;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.istore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISTORE_2         = 61;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.istore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISTORE_3         = 62;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSTORE_0         = 63;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSTORE_1         = 64;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSTORE_2         = 65;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSTORE_3         = 66;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FSTORE_0         = 67;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FSTORE_1         = 68;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FSTORE_2         = 69;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FSTORE_3         = 70;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DSTORE_0         = 71;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DSTORE_1         = 72;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DSTORE_2         = 73;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dstore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DSTORE_3         = 74;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.astore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ASTORE_0         = 75;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.astore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ASTORE_1         = 76;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.astore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ASTORE_2         = 77;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.astore_n">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ASTORE_3         = 78;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IASTORE          = 79;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LASTORE          = 80;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FASTORE          = 81;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DASTORE          = 82;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.aastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short AASTORE          = 83;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.bastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short BASTORE          = 84;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.castore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short CASTORE          = 85;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.sastore">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short SASTORE          = 86;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.pop">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short POP              = 87;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.pop2">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short POP2             = 88;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dup">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DUP              = 89;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dup_x1">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DUP_X1           = 90;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dup_x2">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DUP_X2           = 91;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dup2">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DUP2             = 92;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dup2_x1">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DUP2_X1          = 93;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dup2_x2">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DUP2_X2          = 94;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.swap">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short SWAP             = 95;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iadd">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IADD             = 96;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ladd">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LADD             = 97;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fadd">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FADD             = 98;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dadd">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DADD             = 99;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.isub">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISUB             = 100;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lsub">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSUB             = 101;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fsub">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FSUB             = 102;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dsub">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DSUB             = 103;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.imul">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IMUL             = 104;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lmul">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LMUL             = 105;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fmul">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FMUL             = 106;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dmul">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DMUL             = 107;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.idiv">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IDIV             = 108;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ldiv">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LDIV             = 109;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fdiv">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FDIV             = 110;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ddiv">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DDIV             = 111;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.irem">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IREM             = 112;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lrem">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LREM             = 113;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.frem">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FREM             = 114;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.drem">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DREM             = 115;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ineg">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INEG             = 116;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lneg">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LNEG             = 117;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fneg">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FNEG             = 118;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dneg">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DNEG             = 119;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ishl">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISHL             = 120;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lshl">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSHL             = 121;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ishr">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ISHR             = 122;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lshr">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LSHR             = 123;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iushr">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IUSHR            = 124;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lushr">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LUSHR            = 125;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iand">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IAND             = 126;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.land">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LAND             = 127;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ior">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IOR              = 128;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lor">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LOR              = 129;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ixor">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IXOR             = 130;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lxor">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LXOR             = 131;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iinc">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IINC             = 132;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.i2l">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short I2L              = 133;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.i2f">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short I2F              = 134;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.i2d">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short I2D              = 135;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.l2i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short L2I              = 136;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.l2f">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short L2F              = 137;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.l2d">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short L2D              = 138;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.f2i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short F2I              = 139;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.f2l">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short F2L              = 140;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.f2d">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short F2D              = 141;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.d2i">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short D2I              = 142;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.d2l">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short D2L              = 143;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.d2f">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short D2F              = 144;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.i2b">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short I2B              = 145;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INT2BYTE         = 145; // Old notation
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.i2c">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short I2C              = 146;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INT2CHAR         = 146; // Old notation
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.i2s">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short I2S              = 147;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INT2SHORT        = 147; // Old notation
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lcmp">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LCMP             = 148;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fcmpl">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FCMPL            = 149;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.fcmpg">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FCMPG            = 150;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dcmpl">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DCMPL            = 151;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dcmpg">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DCMPG            = 152;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifeq">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFEQ             = 153;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifne">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFNE             = 154;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.iflt">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFLT             = 155;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifge">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFGE             = 156;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifgt">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFGT             = 157;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifle">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFLE             = 158;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_icmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ICMPEQ        = 159;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_icmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ICMPNE        = 160;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_icmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ICMPLT        = 161;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_icmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ICMPGE        = 162;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_icmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ICMPGT        = 163;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_icmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ICMPLE        = 164;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_acmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ACMPEQ        = 165;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.if_acmp_cond">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IF_ACMPNE        = 166;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.goto">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short GOTO             = 167;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.jsr">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short JSR              = 168;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ret">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short RET              = 169;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.tableswitch">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short TABLESWITCH      = 170;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lookupswitch">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LOOKUPSWITCH     = 171;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ireturn">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IRETURN          = 172;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.lreturn">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short LRETURN          = 173;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.freturn">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short FRETURN          = 174;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.dreturn">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short DRETURN          = 175;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.areturn">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ARETURN          = 176;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.return">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short RETURN           = 177;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.getstatic">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short GETSTATIC        = 178;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.putstatic">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short PUTSTATIC        = 179;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.getfield">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short GETFIELD         = 180;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.putfield">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short PUTFIELD         = 181;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.invokevirtual">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INVOKEVIRTUAL    = 182;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.invokespecial">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INVOKESPECIAL    = 183;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INVOKENONVIRTUAL = 183; // Old name in JDK 1.0
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.invokestatic">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INVOKESTATIC     = 184;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.invokeinterface">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INVOKEINTERFACE  = 185;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.invokedynamic">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INVOKEDYNAMIC    = 186;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.new">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short NEW              = 187;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.newarray">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short NEWARRAY         = 188;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.anewarray">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ANEWARRAY        = 189;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.arraylength">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ARRAYLENGTH      = 190;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.athrow">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short ATHROW           = 191;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.checkcast">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short CHECKCAST        = 192;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.instanceof">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short INSTANCEOF       = 193;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.monitorenter">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short MONITORENTER     = 194;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.monitorexit">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short MONITOREXIT      = 195;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.wide">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short WIDE             = 196;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.multianewarray">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short MULTIANEWARRAY   = 197;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifnull">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFNULL           = 198;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.ifnonnull">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short IFNONNULL        = 199;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.goto_w">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short GOTO_W           = 200;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5.jsr_w">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  public static final short JSR_W            = 201;
+
+  /** JVM internal opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.2">
 +   * Reserved opcodes in the Java Virtual Machine Specification</a> */
+  public static final short BREAKPOINT                = 202;
+
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short LDC_QUICK          \
= 203; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short LDC_W_QUICK        \
= 204; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short LDC2_W_QUICK       \
= 205; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short GETFIELD_QUICK     \
= 206; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short PUTFIELD_QUICK     \
= 207; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short GETFIELD2_QUICK    \
= 208; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short PUTFIELD2_QUICK    \
= 209; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short GETSTATIC_QUICK    \
= 210; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short PUTSTATIC_QUICK    \
= 211; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short GETSTATIC2_QUICK   \
= 212; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short PUTSTATIC2_QUICK   \
= 213; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short \
INVOKEVIRTUAL_QUICK       = 214; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short \
INVOKENONVIRTUAL_QUICK    = 215; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short INVOKESUPER_QUICK  \
= 216; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short INVOKESTATIC_QUICK \
= 217; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short \
INVOKEINTERFACE_QUICK     = 218; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short \
INVOKEVIRTUALOBJECT_QUICK = 219; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short NEW_QUICK          \
= 221; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short ANEWARRAY_QUICK    \
= 222; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short \
MULTIANEWARRAY_QUICK      = 223; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short CHECKCAST_QUICK    \
= 224; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short INSTANCEOF_QUICK   \
= 225; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short \
INVOKEVIRTUAL_QUICK_W     = 226; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short GETFIELD_QUICK_W   \
= 227; +
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  public static final short PUTFIELD_QUICK_W   \
= 228; +
+  /** JVM internal opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.2">
 +   * Reserved opcodes in the Java Virtual Machine Specification</a> */
+  public static final short IMPDEP1                   = 254;
+
+  /** JVM internal opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.2">
 +   * Reserved opcodes in the Java Virtual Machine Specification</a> */
+  public static final short IMPDEP2                   = 255;
+
+  /**
+   * BCEL virtual instruction for pushing an arbitrary data type onto the stack.  \
Will be converted to the appropriate JVM +   * opcode when the class is dumped.
+   */
+  public static final short PUSH             = 4711;
+
+  /**
+   * BCEL virtual instruction for either LOOKUPSWITCH or TABLESWITCH.  Will be \
converted to the appropriate JVM +   * opcode when the class is dumped.
+   */
+  public static final short SWITCH           = 4712;
+
+  /** Illegal opcode. */
+  public static final short  UNDEFINED      = -1;
+
+  /** Illegal opcode. */
+  public static final short  UNPREDICTABLE  = -2;
+
+  /** Illegal opcode. */
+  public static final short  RESERVED       = -3;
+
+  /** Mnemonic for an illegal opcode. */
+  public static final String ILLEGAL_OPCODE = "<illegal opcode>";
+
+  /** Mnemonic for an illegal type. */
+  public static final String ILLEGAL_TYPE   = "<illegal type>";
+
+  /** Boolean data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_BOOLEAN = 4;
+
+  /** Char data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_CHAR    = 5;
+
+  /** Float data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_FLOAT   = 6;
+
+  /** Double data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_DOUBLE  = 7;
+
+  /** Byte data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_BYTE    = 8;
+
+  /** Short data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_SHORT   = 9;
+
+  /** Int data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_INT     = 10;
+
+  /** Long data type.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.9.1-120-P">
 +   * Static Constraints in the Java Virtual Machine Specification</a> */
+  public static final byte T_LONG    = 11;
+
+  /** Void data type (non-standard). */
+  public static final byte T_VOID      = 12; // Non-standard
+
+  /** Array data type. */
+  public static final byte T_ARRAY     = 13;
+
+  /** Object data type. */
+  public static final byte T_OBJECT    = 14;
+
+  /** Reference data type (deprecated). */
+  public static final byte T_REFERENCE = 14; // Deprecated
+
+  /** Unknown data type. */
+  public static final byte T_UNKNOWN   = 15;
+
+  /** Address data type. */
+  public static final byte T_ADDRESS   = 16;
+
+  /** The primitive type names corresponding to the T_XX constants,
+   * e.g., TYPE_NAMES[T_INT] = "int"
+   */
+  private static final String[] TYPE_NAMES = {
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE, ILLEGAL_TYPE,
+    "boolean", "char", "float", "double", "byte", "short", "int", "long",
+    "void", "array", "object", "unknown", "address"
+  };
+
+  /**
+   * The primitive type names corresponding to the T_XX constants,
+   * e.g., TYPE_NAMES[T_INT] = "int"
+   * @param index
+   * @return the type name
+   * @since 6.0
+   */
+  public static String getTypeName(final int index) {
+      return TYPE_NAMES[index];
+  }
+
+  /** The primitive class names corresponding to the T_XX constants,
+   * e.g., CLASS_TYPE_NAMES[T_INT] = "java.lang.Integer"
+   */
+  private static final String[] CLASS_TYPE_NAMES = {
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE, ILLEGAL_TYPE,
+    "java.lang.Boolean", "java.lang.Character", "java.lang.Float",
+    "java.lang.Double", "java.lang.Byte", "java.lang.Short",
+    "java.lang.Integer", "java.lang.Long", "java.lang.Void",
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE,  ILLEGAL_TYPE
+  };
+
+  /**
+   * The primitive class names corresponding to the T_XX constants,
+   * e.g., CLASS_TYPE_NAMES[T_INT] = "java.lang.Integer"
+   * @param index
+   * @return the class name
+   * @since 6.0
+   */
+  public static String getClassTypeName(final int index) {
+      return CLASS_TYPE_NAMES[index];
+  }
+
+  /** The signature characters corresponding to primitive types,
+   * e.g., SHORT_TYPE_NAMES[T_INT] = "I"
+   */
+  private static final String[] SHORT_TYPE_NAMES = {
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE, ILLEGAL_TYPE,
+    "Z", "C", "F", "D", "B", "S", "I", "J",
+    "V", ILLEGAL_TYPE, ILLEGAL_TYPE, ILLEGAL_TYPE
+  };
+
+  /**
+   *
+   * @param index
+   * @return the short type name
+   * @since 6.0
+   */
+  public static String getShortTypeName(final int index) {
+      return SHORT_TYPE_NAMES[index];
+  }
+
+
+  /**
+   * Number of byte code operands for each opcode, i.e., number of bytes after the \
tag byte +   * itself.  Indexed by opcode, so NO_OF_OPERANDS[BIPUSH] = the number of \
operands for a bipush +   * instruction.
+   */
+  private static final short[] NO_OF_OPERANDS = {
+    0/*nop*/, 0/*aconst_null*/, 0/*iconst_m1*/, 0/*iconst_0*/,
+    0/*iconst_1*/, 0/*iconst_2*/, 0/*iconst_3*/, 0/*iconst_4*/,
+    0/*iconst_5*/, 0/*lconst_0*/, 0/*lconst_1*/, 0/*fconst_0*/,
+    0/*fconst_1*/, 0/*fconst_2*/, 0/*dconst_0*/, 0/*dconst_1*/,
+    1/*bipush*/, 2/*sipush*/, 1/*ldc*/, 2/*ldc_w*/, 2/*ldc2_w*/,
+    1/*iload*/, 1/*lload*/, 1/*fload*/, 1/*dload*/, 1/*aload*/,
+    0/*iload_0*/, 0/*iload_1*/, 0/*iload_2*/, 0/*iload_3*/,
+    0/*lload_0*/, 0/*lload_1*/, 0/*lload_2*/, 0/*lload_3*/,
+    0/*fload_0*/, 0/*fload_1*/, 0/*fload_2*/, 0/*fload_3*/,
+    0/*dload_0*/, 0/*dload_1*/, 0/*dload_2*/, 0/*dload_3*/,
+    0/*aload_0*/, 0/*aload_1*/, 0/*aload_2*/, 0/*aload_3*/,
+    0/*iaload*/, 0/*laload*/, 0/*faload*/, 0/*daload*/,
+    0/*aaload*/, 0/*baload*/, 0/*caload*/, 0/*saload*/,
+    1/*istore*/, 1/*lstore*/, 1/*fstore*/, 1/*dstore*/,
+    1/*astore*/, 0/*istore_0*/, 0/*istore_1*/, 0/*istore_2*/,
+    0/*istore_3*/, 0/*lstore_0*/, 0/*lstore_1*/, 0/*lstore_2*/,
+    0/*lstore_3*/, 0/*fstore_0*/, 0/*fstore_1*/, 0/*fstore_2*/,
+    0/*fstore_3*/, 0/*dstore_0*/, 0/*dstore_1*/, 0/*dstore_2*/,
+    0/*dstore_3*/, 0/*astore_0*/, 0/*astore_1*/, 0/*astore_2*/,
+    0/*astore_3*/, 0/*iastore*/, 0/*lastore*/, 0/*fastore*/,
+    0/*dastore*/, 0/*aastore*/, 0/*bastore*/, 0/*castore*/,
+    0/*sastore*/, 0/*pop*/, 0/*pop2*/, 0/*dup*/, 0/*dup_x1*/,
+    0/*dup_x2*/, 0/*dup2*/, 0/*dup2_x1*/, 0/*dup2_x2*/, 0/*swap*/,
+    0/*iadd*/, 0/*ladd*/, 0/*fadd*/, 0/*dadd*/, 0/*isub*/,
+    0/*lsub*/, 0/*fsub*/, 0/*dsub*/, 0/*imul*/, 0/*lmul*/,
+    0/*fmul*/, 0/*dmul*/, 0/*idiv*/, 0/*ldiv*/, 0/*fdiv*/,
+    0/*ddiv*/, 0/*irem*/, 0/*lrem*/, 0/*frem*/, 0/*drem*/,
+    0/*ineg*/, 0/*lneg*/, 0/*fneg*/, 0/*dneg*/, 0/*ishl*/,
+    0/*lshl*/, 0/*ishr*/, 0/*lshr*/, 0/*iushr*/, 0/*lushr*/,
+    0/*iand*/, 0/*land*/, 0/*ior*/, 0/*lor*/, 0/*ixor*/, 0/*lxor*/,
+    2/*iinc*/, 0/*i2l*/, 0/*i2f*/, 0/*i2d*/, 0/*l2i*/, 0/*l2f*/,
+    0/*l2d*/, 0/*f2i*/, 0/*f2l*/, 0/*f2d*/, 0/*d2i*/, 0/*d2l*/,
+    0/*d2f*/, 0/*i2b*/, 0/*i2c*/, 0/*i2s*/, 0/*lcmp*/, 0/*fcmpl*/,
+    0/*fcmpg*/, 0/*dcmpl*/, 0/*dcmpg*/, 2/*ifeq*/, 2/*ifne*/,
+    2/*iflt*/, 2/*ifge*/, 2/*ifgt*/, 2/*ifle*/, 2/*if_icmpeq*/,
+    2/*if_icmpne*/, 2/*if_icmplt*/, 2/*if_icmpge*/, 2/*if_icmpgt*/,
+    2/*if_icmple*/, 2/*if_acmpeq*/, 2/*if_acmpne*/, 2/*goto*/,
+    2/*jsr*/, 1/*ret*/, UNPREDICTABLE/*tableswitch*/, UNPREDICTABLE/*lookupswitch*/,
+    0/*ireturn*/, 0/*lreturn*/, 0/*freturn*/,
+    0/*dreturn*/, 0/*areturn*/, 0/*return*/,
+    2/*getstatic*/, 2/*putstatic*/, 2/*getfield*/,
+    2/*putfield*/, 2/*invokevirtual*/, 2/*invokespecial*/, 2/*invokestatic*/,
+    4/*invokeinterface*/, 4/*invokedynamic*/, 2/*new*/,
+    1/*newarray*/, 2/*anewarray*/,
+    0/*arraylength*/, 0/*athrow*/, 2/*checkcast*/,
+    2/*instanceof*/, 0/*monitorenter*/,
+    0/*monitorexit*/, UNPREDICTABLE/*wide*/, 3/*multianewarray*/,
+    2/*ifnull*/, 2/*ifnonnull*/, 4/*goto_w*/,
+    4/*jsr_w*/, 0/*breakpoint*/, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, RESERVED/*impdep1*/, RESERVED/*impdep2*/
+  };
+
+  /**
+   *
+   * @param index
+   * @return Number of byte code operands
+   * @since 6.0
+   */
+  public static short getNoOfOperands(final int index) {
+      return NO_OF_OPERANDS[index];
+  }
+
+  /**
+   * How the byte code operands are to be interpreted for each opcode.
+   * Indexed by opcode.  TYPE_OF_OPERANDS[ILOAD] = an array of shorts
+   * describing the data types for the instruction.
+   */
+  private static final short[][] TYPE_OF_OPERANDS = {
+    {}/*nop*/, {}/*aconst_null*/, {}/*iconst_m1*/, {}/*iconst_0*/,
+    {}/*iconst_1*/, {}/*iconst_2*/, {}/*iconst_3*/, {}/*iconst_4*/,
+    {}/*iconst_5*/, {}/*lconst_0*/, {}/*lconst_1*/, {}/*fconst_0*/,
+    {}/*fconst_1*/, {}/*fconst_2*/, {}/*dconst_0*/, {}/*dconst_1*/,
+    {T_BYTE}/*bipush*/, {T_SHORT}/*sipush*/, {T_BYTE}/*ldc*/,
+    {T_SHORT}/*ldc_w*/, {T_SHORT}/*ldc2_w*/,
+    {T_BYTE}/*iload*/, {T_BYTE}/*lload*/, {T_BYTE}/*fload*/,
+    {T_BYTE}/*dload*/, {T_BYTE}/*aload*/, {}/*iload_0*/,
+    {}/*iload_1*/, {}/*iload_2*/, {}/*iload_3*/, {}/*lload_0*/,
+    {}/*lload_1*/, {}/*lload_2*/, {}/*lload_3*/, {}/*fload_0*/,
+    {}/*fload_1*/, {}/*fload_2*/, {}/*fload_3*/, {}/*dload_0*/,
+    {}/*dload_1*/, {}/*dload_2*/, {}/*dload_3*/, {}/*aload_0*/,
+    {}/*aload_1*/, {}/*aload_2*/, {}/*aload_3*/, {}/*iaload*/,
+    {}/*laload*/, {}/*faload*/, {}/*daload*/, {}/*aaload*/,
+    {}/*baload*/, {}/*caload*/, {}/*saload*/, {T_BYTE}/*istore*/,
+    {T_BYTE}/*lstore*/, {T_BYTE}/*fstore*/, {T_BYTE}/*dstore*/,
+    {T_BYTE}/*astore*/, {}/*istore_0*/, {}/*istore_1*/,
+    {}/*istore_2*/, {}/*istore_3*/, {}/*lstore_0*/, {}/*lstore_1*/,
+    {}/*lstore_2*/, {}/*lstore_3*/, {}/*fstore_0*/, {}/*fstore_1*/,
+    {}/*fstore_2*/, {}/*fstore_3*/, {}/*dstore_0*/, {}/*dstore_1*/,
+    {}/*dstore_2*/, {}/*dstore_3*/, {}/*astore_0*/, {}/*astore_1*/,
+    {}/*astore_2*/, {}/*astore_3*/, {}/*iastore*/, {}/*lastore*/,
+    {}/*fastore*/, {}/*dastore*/, {}/*aastore*/, {}/*bastore*/,
+    {}/*castore*/, {}/*sastore*/, {}/*pop*/, {}/*pop2*/, {}/*dup*/,
+    {}/*dup_x1*/, {}/*dup_x2*/, {}/*dup2*/, {}/*dup2_x1*/,
+    {}/*dup2_x2*/, {}/*swap*/, {}/*iadd*/, {}/*ladd*/, {}/*fadd*/,
+    {}/*dadd*/, {}/*isub*/, {}/*lsub*/, {}/*fsub*/, {}/*dsub*/,
+    {}/*imul*/, {}/*lmul*/, {}/*fmul*/, {}/*dmul*/, {}/*idiv*/,
+    {}/*ldiv*/, {}/*fdiv*/, {}/*ddiv*/, {}/*irem*/, {}/*lrem*/,
+    {}/*frem*/, {}/*drem*/, {}/*ineg*/, {}/*lneg*/, {}/*fneg*/,
+    {}/*dneg*/, {}/*ishl*/, {}/*lshl*/, {}/*ishr*/, {}/*lshr*/,
+    {}/*iushr*/, {}/*lushr*/, {}/*iand*/, {}/*land*/, {}/*ior*/,
+    {}/*lor*/, {}/*ixor*/, {}/*lxor*/, {T_BYTE, T_BYTE}/*iinc*/,
+    {}/*i2l*/, {}/*i2f*/, {}/*i2d*/, {}/*l2i*/, {}/*l2f*/, {}/*l2d*/,
+    {}/*f2i*/, {}/*f2l*/, {}/*f2d*/, {}/*d2i*/, {}/*d2l*/, {}/*d2f*/,
+    {}/*i2b*/, {}/*i2c*/, {}/*i2s*/, {}/*lcmp*/, {}/*fcmpl*/,
+    {}/*fcmpg*/, {}/*dcmpl*/, {}/*dcmpg*/, {T_SHORT}/*ifeq*/,
+    {T_SHORT}/*ifne*/, {T_SHORT}/*iflt*/, {T_SHORT}/*ifge*/,
+    {T_SHORT}/*ifgt*/, {T_SHORT}/*ifle*/, {T_SHORT}/*if_icmpeq*/,
+    {T_SHORT}/*if_icmpne*/, {T_SHORT}/*if_icmplt*/,
+    {T_SHORT}/*if_icmpge*/, {T_SHORT}/*if_icmpgt*/,
+    {T_SHORT}/*if_icmple*/, {T_SHORT}/*if_acmpeq*/,
+    {T_SHORT}/*if_acmpne*/, {T_SHORT}/*goto*/, {T_SHORT}/*jsr*/,
+    {T_BYTE}/*ret*/, {}/*tableswitch*/, {}/*lookupswitch*/,
+    {}/*ireturn*/, {}/*lreturn*/, {}/*freturn*/, {}/*dreturn*/,
+    {}/*areturn*/, {}/*return*/, {T_SHORT}/*getstatic*/,
+    {T_SHORT}/*putstatic*/, {T_SHORT}/*getfield*/,
+    {T_SHORT}/*putfield*/, {T_SHORT}/*invokevirtual*/,
+    {T_SHORT}/*invokespecial*/, {T_SHORT}/*invokestatic*/,
+    {T_SHORT, T_BYTE, T_BYTE}/*invokeinterface*/, {T_SHORT, T_BYTE, \
T_BYTE}/*invokedynamic*/, +    {T_SHORT}/*new*/, {T_BYTE}/*newarray*/,
+    {T_SHORT}/*anewarray*/, {}/*arraylength*/, {}/*athrow*/,
+    {T_SHORT}/*checkcast*/, {T_SHORT}/*instanceof*/,
+    {}/*monitorenter*/, {}/*monitorexit*/, {T_BYTE}/*wide*/,
+    {T_SHORT, T_BYTE}/*multianewarray*/, {T_SHORT}/*ifnull*/,
+    {T_SHORT}/*ifnonnull*/, {T_INT}/*goto_w*/, {T_INT}/*jsr_w*/,
+    {}/*breakpoint*/, {}, {}, {}, {}, {}, {}, {},
+    {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {},
+    {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {},
+    {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {},
+    {}/*impdep1*/, {}/*impdep2*/
+  };
+
+  /**
+   * @since 6.0
+   */
+  public static short getOperandType(final int opcode, final int index) {
+      return TYPE_OF_OPERANDS[opcode][index];
+  }
+
+  /**
+   * @since 6.0
+   */
+  public static long getOperandTypeCount(final int opcode) {
+      return TYPE_OF_OPERANDS[opcode].length;
+  }
+
+  /**
+   * Names of opcodes.  Indexed by opcode.  OPCODE_NAMES[ALOAD] = "aload".
+   */
+  private static final String[] OPCODE_NAMES = {
+    "nop", "aconst_null", "iconst_m1", "iconst_0", "iconst_1",
+    "iconst_2", "iconst_3", "iconst_4", "iconst_5", "lconst_0",
+    "lconst_1", "fconst_0", "fconst_1", "fconst_2", "dconst_0",
+    "dconst_1", "bipush", "sipush", "ldc", "ldc_w", "ldc2_w", "iload",
+    "lload", "fload", "dload", "aload", "iload_0", "iload_1", "iload_2",
+    "iload_3", "lload_0", "lload_1", "lload_2", "lload_3", "fload_0",
+    "fload_1", "fload_2", "fload_3", "dload_0", "dload_1", "dload_2",
+    "dload_3", "aload_0", "aload_1", "aload_2", "aload_3", "iaload",
+    "laload", "faload", "daload", "aaload", "baload", "caload", "saload",
+    "istore", "lstore", "fstore", "dstore", "astore", "istore_0",
+    "istore_1", "istore_2", "istore_3", "lstore_0", "lstore_1",
+    "lstore_2", "lstore_3", "fstore_0", "fstore_1", "fstore_2",
+    "fstore_3", "dstore_0", "dstore_1", "dstore_2", "dstore_3",
+    "astore_0", "astore_1", "astore_2", "astore_3", "iastore", "lastore",
+    "fastore", "dastore", "aastore", "bastore", "castore", "sastore",
+    "pop", "pop2", "dup", "dup_x1", "dup_x2", "dup2", "dup2_x1",
+    "dup2_x2", "swap", "iadd", "ladd", "fadd", "dadd", "isub", "lsub",
+    "fsub", "dsub", "imul", "lmul", "fmul", "dmul", "idiv", "ldiv",
+    "fdiv", "ddiv", "irem", "lrem", "frem", "drem", "ineg", "lneg",
+    "fneg", "dneg", "ishl", "lshl", "ishr", "lshr", "iushr", "lushr",
+    "iand", "land", "ior", "lor", "ixor", "lxor", "iinc", "i2l", "i2f",
+    "i2d", "l2i", "l2f", "l2d", "f2i", "f2l", "f2d", "d2i", "d2l", "d2f",
+    "i2b", "i2c", "i2s", "lcmp", "fcmpl", "fcmpg",
+    "dcmpl", "dcmpg", "ifeq", "ifne", "iflt", "ifge", "ifgt", "ifle",
+    "if_icmpeq", "if_icmpne", "if_icmplt", "if_icmpge", "if_icmpgt",
+    "if_icmple", "if_acmpeq", "if_acmpne", "goto", "jsr", "ret",
+    "tableswitch", "lookupswitch", "ireturn", "lreturn", "freturn",
+    "dreturn", "areturn", "return", "getstatic", "putstatic", "getfield",
+    "putfield", "invokevirtual", "invokespecial", "invokestatic",
+    "invokeinterface", "invokedynamic", "new", "newarray", "anewarray",
+    "arraylength", "athrow", "checkcast", "instanceof", "monitorenter",
+    "monitorexit", "wide", "multianewarray", "ifnull", "ifnonnull",
+    "goto_w", "jsr_w", "breakpoint", ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, "impdep1", "impdep2"
+  };
+
+  /**
+   * @since 6.0
+   */
+  public static final int OPCODE_NAMES_LENGTH = OPCODE_NAMES.length;
+
+
+  /**
+   * @since 6.0
+   */
+  public static String getOpcodeName(final int index) {
+      return OPCODE_NAMES[index];
+  }
+
+  /**
+   * Number of words consumed on operand stack by instructions.
+   * Indexed by opcode.  CONSUME_STACK[FALOAD] = number of words
+   * consumed from the stack by a faload instruction.
+   */
+  private static final int[] CONSUME_STACK = {
+    0/*nop*/, 0/*aconst_null*/, 0/*iconst_m1*/, 0/*iconst_0*/, 0/*iconst_1*/,
+    0/*iconst_2*/, 0/*iconst_3*/, 0/*iconst_4*/, 0/*iconst_5*/, 0/*lconst_0*/,
+    0/*lconst_1*/, 0/*fconst_0*/, 0/*fconst_1*/, 0/*fconst_2*/, 0/*dconst_0*/,
+    0/*dconst_1*/, 0/*bipush*/, 0/*sipush*/, 0/*ldc*/, 0/*ldc_w*/, 0/*ldc2_w*/, \
0/*iload*/, +    0/*lload*/, 0/*fload*/, 0/*dload*/, 0/*aload*/, 0/*iload_0*/, \
0/*iload_1*/, 0/*iload_2*/, +    0/*iload_3*/, 0/*lload_0*/, 0/*lload_1*/, \
0/*lload_2*/, 0/*lload_3*/, 0/*fload_0*/, +    0/*fload_1*/, 0/*fload_2*/, \
0/*fload_3*/, 0/*dload_0*/, 0/*dload_1*/, 0/*dload_2*/, +    0/*dload_3*/, \
0/*aload_0*/, 0/*aload_1*/, 0/*aload_2*/, 0/*aload_3*/, 2/*iaload*/, +    \
2/*laload*/, 2/*faload*/, 2/*daload*/, 2/*aaload*/, 2/*baload*/, 2/*caload*/, \
2/*saload*/, +    1/*istore*/, 2/*lstore*/, 1/*fstore*/, 2/*dstore*/, 1/*astore*/, \
1/*istore_0*/, +    1/*istore_1*/, 1/*istore_2*/, 1/*istore_3*/, 2/*lstore_0*/, \
2/*lstore_1*/, +    2/*lstore_2*/, 2/*lstore_3*/, 1/*fstore_0*/, 1/*fstore_1*/, \
1/*fstore_2*/, +    1/*fstore_3*/, 2/*dstore_0*/, 2/*dstore_1*/, 2/*dstore_2*/, \
2/*dstore_3*/, +    1/*astore_0*/, 1/*astore_1*/, 1/*astore_2*/, 1/*astore_3*/, \
3/*iastore*/, 4/*lastore*/, +    3/*fastore*/, 4/*dastore*/, 3/*aastore*/, \
3/*bastore*/, 3/*castore*/, 3/*sastore*/, +    1/*pop*/, 2/*pop2*/, 1/*dup*/, \
2/*dup_x1*/, 3/*dup_x2*/, 2/*dup2*/, 3/*dup2_x1*/, +    4/*dup2_x2*/, 2/*swap*/, \
2/*iadd*/, 4/*ladd*/, 2/*fadd*/, 4/*dadd*/, 2/*isub*/, 4/*lsub*/, +    2/*fsub*/, \
4/*dsub*/, 2/*imul*/, 4/*lmul*/, 2/*fmul*/, 4/*dmul*/, 2/*idiv*/, 4/*ldiv*/, +    \
2/*fdiv*/, 4/*ddiv*/, 2/*irem*/, 4/*lrem*/, 2/*frem*/, 4/*drem*/, 1/*ineg*/, \
2/*lneg*/, +    1/*fneg*/, 2/*dneg*/, 2/*ishl*/, 3/*lshl*/, 2/*ishr*/, 3/*lshr*/, \
2/*iushr*/, 3/*lushr*/, +    2/*iand*/, 4/*land*/, 2/*ior*/, 4/*lor*/, 2/*ixor*/, \
4/*lxor*/, 0/*iinc*/, +    1/*i2l*/, 1/*i2f*/, 1/*i2d*/, 2/*l2i*/, 2/*l2f*/, \
2/*l2d*/, 1/*f2i*/, 1/*f2l*/, +    1/*f2d*/, 2/*d2i*/, 2/*d2l*/, 2/*d2f*/, 1/*i2b*/, \
1/*i2c*/, 1/*i2s*/, +    4/*lcmp*/, 2/*fcmpl*/, 2/*fcmpg*/, 4/*dcmpl*/, 4/*dcmpg*/, \
1/*ifeq*/, 1/*ifne*/, +    1/*iflt*/, 1/*ifge*/, 1/*ifgt*/, 1/*ifle*/, \
2/*if_icmpeq*/, 2/*if_icmpne*/, 2/*if_icmplt*/, +    2 /*if_icmpge*/, 2/*if_icmpgt*/, \
2/*if_icmple*/, 2/*if_acmpeq*/, 2/*if_acmpne*/, +    0/*goto*/, 0/*jsr*/, 0/*ret*/, \
1/*tableswitch*/, 1/*lookupswitch*/, 1/*ireturn*/, +    2/*lreturn*/, 1/*freturn*/, \
2/*dreturn*/, 1/*areturn*/, 0/*return*/, 0/*getstatic*/, +    \
UNPREDICTABLE/*putstatic*/, 1/*getfield*/, UNPREDICTABLE/*putfield*/, +    \
UNPREDICTABLE/*invokevirtual*/, UNPREDICTABLE/*invokespecial*/, +    \
UNPREDICTABLE/*invokestatic*/, +    UNPREDICTABLE/*invokeinterface*/, \
UNPREDICTABLE/*invokedynamic*/, 0/*new*/, 1/*newarray*/, 1/*anewarray*/, +    \
1/*arraylength*/, 1/*athrow*/, 1/*checkcast*/, 1/*instanceof*/, 1/*monitorenter*/, +  \
1/*monitorexit*/, 0/*wide*/, UNPREDICTABLE/*multianewarray*/, 1/*ifnull*/, \
1/*ifnonnull*/, +    0/*goto_w*/, 0/*jsr_w*/, 0/*breakpoint*/, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNPREDICTABLE/*impdep1*/, UNPREDICTABLE/*impdep2*/
+  };
+
+  /**
+   *
+   * @param index
+   * @return Number of words consumed on operand stack
+   * @since 6.0
+   */
+  public static int getConsumeStack(final int index) {
+      return CONSUME_STACK[index];
+  }
+
+
+  /**
+   * Number of words produced onto operand stack by instructions.
+   * Indexed by opcode.  CONSUME_STACK[DALOAD] = number of words
+   * consumed from the stack by a daload instruction.
+   */
+  private static final int[] PRODUCE_STACK = {
+    0/*nop*/, 1/*aconst_null*/, 1/*iconst_m1*/, 1/*iconst_0*/, 1/*iconst_1*/,
+    1/*iconst_2*/, 1/*iconst_3*/, 1/*iconst_4*/, 1/*iconst_5*/, 2/*lconst_0*/,
+    2/*lconst_1*/, 1/*fconst_0*/, 1/*fconst_1*/, 1/*fconst_2*/, 2/*dconst_0*/,
+    2/*dconst_1*/, 1/*bipush*/, 1/*sipush*/, 1/*ldc*/, 1/*ldc_w*/, 2/*ldc2_w*/, \
1/*iload*/, +    2/*lload*/, 1/*fload*/, 2/*dload*/, 1/*aload*/, 1/*iload_0*/, \
1/*iload_1*/, 1/*iload_2*/, +    1/*iload_3*/, 2/*lload_0*/, 2/*lload_1*/, \
2/*lload_2*/, 2/*lload_3*/, 1/*fload_0*/, +    1/*fload_1*/, 1/*fload_2*/, \
1/*fload_3*/, 2/*dload_0*/, 2/*dload_1*/, 2/*dload_2*/, +    2/*dload_3*/, \
1/*aload_0*/, 1/*aload_1*/, 1/*aload_2*/, 1/*aload_3*/, 1/*iaload*/, +    \
2/*laload*/, 1/*faload*/, 2/*daload*/, 1/*aaload*/, 1/*baload*/, 1/*caload*/, \
1/*saload*/, +    0/*istore*/, 0/*lstore*/, 0/*fstore*/, 0/*dstore*/, 0/*astore*/, \
0/*istore_0*/, +    0/*istore_1*/, 0/*istore_2*/, 0/*istore_3*/, 0/*lstore_0*/, \
0/*lstore_1*/, +    0/*lstore_2*/, 0/*lstore_3*/, 0/*fstore_0*/, 0/*fstore_1*/, \
0/*fstore_2*/, +    0/*fstore_3*/, 0/*dstore_0*/, 0/*dstore_1*/, 0/*dstore_2*/, \
0/*dstore_3*/, +    0/*astore_0*/, 0/*astore_1*/, 0/*astore_2*/, 0/*astore_3*/, \
0/*iastore*/, 0/*lastore*/, +    0/*fastore*/, 0/*dastore*/, 0/*aastore*/, \
0/*bastore*/, 0/*castore*/, 0/*sastore*/, +    0/*pop*/, 0/*pop2*/, 2/*dup*/, \
3/*dup_x1*/, 4/*dup_x2*/, 4/*dup2*/, 5/*dup2_x1*/, +    6/*dup2_x2*/, 2/*swap*/, \
1/*iadd*/, 2/*ladd*/, 1/*fadd*/, 2/*dadd*/, 1/*isub*/, 2/*lsub*/, +    1/*fsub*/, \
2/*dsub*/, 1/*imul*/, 2/*lmul*/, 1/*fmul*/, 2/*dmul*/, 1/*idiv*/, 2/*ldiv*/, +    \
1/*fdiv*/, 2/*ddiv*/, 1/*irem*/, 2/*lrem*/, 1/*frem*/, 2/*drem*/, 1/*ineg*/, \
2/*lneg*/, +    1/*fneg*/, 2/*dneg*/, 1/*ishl*/, 2/*lshl*/, 1/*ishr*/, 2/*lshr*/, \
1/*iushr*/, 2/*lushr*/, +    1/*iand*/, 2/*land*/, 1/*ior*/, 2/*lor*/, 1/*ixor*/, \
2/*lxor*/, +    0/*iinc*/, 2/*i2l*/, 1/*i2f*/, 2/*i2d*/, 1/*l2i*/, 1/*l2f*/, \
2/*l2d*/, 1/*f2i*/, +    2/*f2l*/, 2/*f2d*/, 1/*d2i*/, 2/*d2l*/, 1/*d2f*/,
+    1/*i2b*/, 1/*i2c*/, 1/*i2s*/, 1/*lcmp*/, 1/*fcmpl*/, 1/*fcmpg*/,
+    1/*dcmpl*/, 1/*dcmpg*/, 0/*ifeq*/, 0/*ifne*/, 0/*iflt*/, 0/*ifge*/, 0/*ifgt*/, \
0/*ifle*/, +    0/*if_icmpeq*/, 0/*if_icmpne*/, 0/*if_icmplt*/, 0/*if_icmpge*/, \
0/*if_icmpgt*/, +    0/*if_icmple*/, 0/*if_acmpeq*/, 0/*if_acmpne*/, 0/*goto*/, \
1/*jsr*/, 0/*ret*/, +    0/*tableswitch*/, 0/*lookupswitch*/, 0/*ireturn*/, \
0/*lreturn*/, 0/*freturn*/, +    0/*dreturn*/, 0/*areturn*/, 0/*return*/, \
UNPREDICTABLE/*getstatic*/, 0/*putstatic*/, +    UNPREDICTABLE/*getfield*/, \
0/*putfield*/, UNPREDICTABLE/*invokevirtual*/, +    UNPREDICTABLE/*invokespecial*/, \
UNPREDICTABLE/*invokestatic*/, +    UNPREDICTABLE/*invokeinterface*/, \
UNPREDICTABLE/*invokedynamic*/, 1/*new*/, 1/*newarray*/, 1/*anewarray*/, +    \
1/*arraylength*/, 1/*athrow*/, 1/*checkcast*/, 1/*instanceof*/, 0/*monitorenter*/, +  \
0/*monitorexit*/, 0/*wide*/, 1/*multianewarray*/, 0/*ifnull*/, 0/*ifnonnull*/, +    \
0/*goto_w*/, 1/*jsr_w*/, 0/*breakpoint*/, UNDEFINED, UNDEFINED, +    UNDEFINED, \
UNDEFINED, UNDEFINED, UNDEFINED, +    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNPREDICTABLE/*impdep1*/, UNPREDICTABLE/*impdep2*/
+  };
+
+  /**
+   *
+   * @param index
+   * @return Number of words produced onto operand stack
+   * @since 6.0
+   */
+  public static int getProduceStack(final int index) {
+      return PRODUCE_STACK[index];
+  }
+
+  /** Attributes and their corresponding names.
+   */
+  public static final byte ATTR_UNKNOWN                                 = -1;
+  public static final byte ATTR_SOURCE_FILE                             = 0;
+  public static final byte ATTR_CONSTANT_VALUE                          = 1;
+  public static final byte ATTR_CODE                                    = 2;
+  public static final byte ATTR_EXCEPTIONS                              = 3;
+  public static final byte ATTR_LINE_NUMBER_TABLE                       = 4;
+  public static final byte ATTR_LOCAL_VARIABLE_TABLE                    = 5;
+  public static final byte ATTR_INNER_CLASSES                           = 6;
+  public static final byte ATTR_SYNTHETIC                               = 7;
+  public static final byte ATTR_DEPRECATED                              = 8;
+  public static final byte ATTR_PMG                                     = 9;
+  public static final byte ATTR_SIGNATURE                               = 10;
+  public static final byte ATTR_STACK_MAP                               = 11;
+  public static final byte ATTR_RUNTIME_VISIBLE_ANNOTATIONS             = 12;
+  public static final byte ATTR_RUNTIME_INVISIBLE_ANNOTATIONS           = 13;
+  public static final byte ATTR_RUNTIME_VISIBLE_PARAMETER_ANNOTATIONS   = 14;
+  public static final byte ATTR_RUNTIME_INVISIBLE_PARAMETER_ANNOTATIONS = 15;
+  public static final byte ATTR_ANNOTATION_DEFAULT                      = 16;
+  public static final byte ATTR_LOCAL_VARIABLE_TYPE_TABLE               = 17;
+  public static final byte ATTR_ENCLOSING_METHOD                        = 18;
+  public static final byte ATTR_STACK_MAP_TABLE                         = 19;
+  public static final byte ATTR_BOOTSTRAP_METHODS                       = 20;
+  public static final byte ATTR_METHOD_PARAMETERS                       = 21;
+  public static final byte ATTR_MODULE                                  = 22;
+  public static final byte ATTR_MODULE_PACKAGES                         = 23;
+  public static final byte ATTR_MODULE_MAIN_CLASS                       = 24;
+  public static final byte ATTR_NEST_HOST                               = 25;
+  public static final byte ATTR_NEST_MEMBERS                            = 26;
+
+  public static final short KNOWN_ATTRIBUTES = 27; // count of attributes
+
+  private static final String[] ATTRIBUTE_NAMES = {
+    "SourceFile", "ConstantValue", "Code", "Exceptions",
+    "LineNumberTable", "LocalVariableTable",
+    "InnerClasses", "Synthetic", "Deprecated",
+    "PMGClass", "Signature", "StackMap",
+    "RuntimeVisibleAnnotations", "RuntimeInvisibleAnnotations",
+    "RuntimeVisibleParameterAnnotations", "RuntimeInvisibleParameterAnnotations",
+    "AnnotationDefault", "LocalVariableTypeTable", "EnclosingMethod", \
"StackMapTable", +    "BootstrapMethods", "MethodParameters", "Module", \
"ModulePackages", +    "ModuleMainClass", "NestHost", "NestMembers"
+  };
+
+  /**
+   *
+   * @param index
+   * @return the attribute name
+   * @since 6.0
+   */
+  public static String getAttributeName(final int index) {
+      return ATTRIBUTE_NAMES[index];
+  }
+
+  /** Constants used in the StackMap attribute.
+   */
+  public static final byte ITEM_Bogus      = 0;
+  public static final byte ITEM_Integer    = 1;
+  public static final byte ITEM_Float      = 2;
+  public static final byte ITEM_Double     = 3;
+  public static final byte ITEM_Long       = 4;
+  public static final byte ITEM_Null       = 5;
+  public static final byte ITEM_InitObject = 6;
+  public static final byte ITEM_Object     = 7;
+  public static final byte ITEM_NewObject  = 8;
+
+  private static final String[] ITEM_NAMES = {
+    "Bogus", "Integer", "Float", "Double", "Long",
+    "Null", "InitObject", "Object", "NewObject"
+  };
+
+  /**
+   *
+   * @param index
+   * @return the item name
+   * @since 6.0
+   */
+  public static String getItemName(final int index) {
+      return ITEM_NAMES[index];
+  }
+
+  /** Constants used to identify StackMapEntry types.
+   *
+   * For those types which can specify a range, the
+   * constant names the lowest value.
+   */
+  public static final int SAME_FRAME = 0;
+  public static final int SAME_LOCALS_1_STACK_ITEM_FRAME = 64;
+  public static final int SAME_LOCALS_1_STACK_ITEM_FRAME_EXTENDED = 247;
+  public static final int CHOP_FRAME = 248;
+  public static final int SAME_FRAME_EXTENDED = 251;
+  public static final int APPEND_FRAME = 252;
+  public static final int FULL_FRAME = 255;
+
+  /** Constants that define the maximum value of
+   * those constants which store ranges. */
+
+  public static final int SAME_FRAME_MAX = 63;
+  public static final int SAME_LOCALS_1_STACK_ITEM_FRAME_MAX = 127;
+  public static final int CHOP_FRAME_MAX = 250;
+  public static final int APPEND_FRAME_MAX = 254;
+
+
+  // Constants defining the behavior of the Method Handles (JVMS �5.4.3.5)
+
+  public static final byte REF_getField         = 1;
+  public static final byte REF_getStatic        = 2;
+  public static final byte REF_putField         = 3;
+  public static final byte REF_putStatic        = 4;
+  public static final byte REF_invokeVirtual    = 5;
+  public static final byte REF_invokeStatic     = 6;
+  public static final byte REF_invokeSpecial    = 7;
+  public static final byte REF_newInvokeSpecial = 8;
+  public static final byte REF_invokeInterface  = 9;
+
+  /**
+   * The names of the reference_kinds of a CONSTANT_MethodHandle_info.
+   */
+  private static final String[] METHODHANDLE_NAMES = {
+      "", "getField", "getStatic", "putField", "putStatic", "invokeVirtual",
+      "invokeStatic", "invokeSpecial", "newInvokeSpecial", "invokeInterface" };
+
+  /**
+   *
+   * @param index
+   * @return the method handle name
+   * @since 6.0
+   */
+  public static String getMethodHandleName(final int index) {
+      return METHODHANDLE_NAMES[index];
+  }
+
+  private Const() { } // not instantiable
+
+}
diff --git a/src/org/apache/bcel/Constants.java b/src/org/apache/bcel/Constants.java
new file mode 100644
index 00000000..07ec9228
--- /dev/null
+++ b/src/org/apache/bcel/Constants.java
@@ -0,0 +1,1697 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel;
+
+/**
+ * Constants for the project, mostly defined in the JVM specification.
+ *
+ * @deprecated (since 6.0) DO NOT USE - use Const instead
+ */
+@Deprecated
+public interface Constants {
+
+  /** Major version number of class files for Java 1.1.
+   *  @see #MINOR_1_1
+   *  */
+  short MAJOR_1_1 = 45;
+
+  /** Minor version number of class files for Java 1.1.
+   *  @see #MAJOR_1_1
+   *  */
+  short MINOR_1_1 = 3;
+
+  /** Major version number of class files for Java 1.2.
+   *  @see #MINOR_1_2
+   *  */
+  short MAJOR_1_2 = 46;
+
+  /** Minor version number of class files for Java 1.2.
+   *  @see #MAJOR_1_2
+   *  */
+  short MINOR_1_2 = 0;
+
+  /** Major version number of class files for Java 1.2.
+   *  @see #MINOR_1_2
+   *  */
+  short MAJOR_1_3 = 47;
+
+  /** Minor version number of class files for Java 1.3.
+   *  @see #MAJOR_1_3
+   *  */
+  short MINOR_1_3 = 0;
+
+  /** Major version number of class files for Java 1.3.
+   *  @see #MINOR_1_3
+   *  */
+  short MAJOR_1_4 = 48;
+
+  /** Minor version number of class files for Java 1.4.
+   *  @see #MAJOR_1_4
+   *  */
+  short MINOR_1_4 = 0;
+
+  /** Major version number of class files for Java 1.4.
+   *  @see #MINOR_1_4
+   *  */
+  short MAJOR_1_5 = 49;
+
+  /** Minor version number of class files for Java 1.5.
+   *  @see #MAJOR_1_5
+   *  */
+  short MINOR_1_5 = 0;
+
+
+  /** Default major version number.  Class file is for Java 1.1.
+   *  @see #MAJOR_1_1
+   *  */
+  short MAJOR = MAJOR_1_1;
+
+  /** Default major version number.  Class file is for Java 1.1.
+   *  @see #MAJOR_1_1
+   *  */
+  short MINOR     = MINOR_1_1;
+
+  /** Maximum value for an unsigned short.
+   */
+  int MAX_SHORT = 65535; // 2^16 - 1
+
+  /** Maximum value for an unsigned byte.
+   */
+  int MAX_BYTE  = 255; // 2^8 - 1
+
+  /** One of the access flags for fields, methods, or classes.
+   *
+   *  @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.5">
 +   *  Flag definitions for Fields in the Java Virtual Machine Specification (Java \
SE 8 Edition).</a> +   *  @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.6"> +   * \
Flag definitions for Methods in the Java Virtual Machine Specification (Java SE 8 \
Edition).</a> +   *  @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.6-300-D.1-D.1">
 +   *  Flag definitions for Classes in the Java Virtual Machine Specification (Java \
SE 8 Edition).</a> +   */
+  short ACC_PUBLIC       = 0x0001;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_PRIVATE      = 0x0002;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_PROTECTED    = 0x0004;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_STATIC       = 0x0008;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_FINAL        = 0x0010;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_SYNCHRONIZED = 0x0020;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_VOLATILE     = 0x0040;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_BRIDGE       = 0x0040;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_TRANSIENT    = 0x0080;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_VARARGS      = 0x0080;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_NATIVE       = 0x0100;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_INTERFACE    = 0x0200;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_ABSTRACT     = 0x0400;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_STRICT       = 0x0800;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_SYNTHETIC    = 0x1000;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_ANNOTATION   = 0x2000;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_ENUM         = 0x4000;
+
+  // Applies to classes compiled by new compilers only
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short ACC_SUPER        = 0x0020;
+
+  /** One of the access flags for fields, methods, or classes.
+   *  @see #ACC_PUBLIC
+   */
+  short MAX_ACC_FLAG     = ACC_ENUM;
+
+  /** The names of the access flags. */
+  String[] ACCESS_NAMES = {
+    "public", "private", "protected", "static", "final", "synchronized",
+    "volatile", "transient", "native", "interface", "abstract", "strictfp",
+    "synthetic", "annotation", "enum"
+  };
+
+  /** Marks a constant pool entry as type UTF-8.  */
+  byte CONSTANT_Utf8               = 1;
+
+  /** Marks a constant pool entry as type Integer.  */
+  byte CONSTANT_Integer            = 3;
+
+  /** Marks a constant pool entry as type Float.  */
+  byte CONSTANT_Float              = 4;
+
+  /** Marks a constant pool entry as type Long.  */
+  byte CONSTANT_Long               = 5;
+
+  /** Marks a constant pool entry as type Double.  */
+  byte CONSTANT_Double             = 6;
+
+  /** Marks a constant pool entry as a Class.  */
+  byte CONSTANT_Class              = 7;
+
+  /** Marks a constant pool entry as a Field Reference.  */
+  byte CONSTANT_Fieldref           = 9;
+
+  /** Marks a constant pool entry as type String.  */
+  byte CONSTANT_String             = 8;
+
+  /** Marks a constant pool entry as a Method Reference.  */
+  byte CONSTANT_Methodref          = 10;
+
+  /** Marks a constant pool entry as an Interface Method Reference.  */
+  byte CONSTANT_InterfaceMethodref = 11;
+
+  /** Marks a constant pool entry as a name and type.  */
+  byte CONSTANT_NameAndType        = 12;
+
+  /** The names of the types of entries in a constant pool. */
+  String[] CONSTANT_NAMES = {
+    "", "CONSTANT_Utf8", "", "CONSTANT_Integer",
+    "CONSTANT_Float", "CONSTANT_Long", "CONSTANT_Double",
+    "CONSTANT_Class", "CONSTANT_String", "CONSTANT_Fieldref",
+    "CONSTANT_Methodref", "CONSTANT_InterfaceMethodref",
+    "CONSTANT_NameAndType" };
+
+  /** The name of the static initializer, also called &quot;class
+   *  initialization method&quot; or &quot;interface initialization
+   *   method&quot;. This is &quot;&lt;clinit&gt;&quot;.
+   */
+  String STATIC_INITIALIZER_NAME = "<clinit>";
+
+  /** The name of every constructor method in a class, also called
+   * &quot;instance initialization method&quot;. This is &quot;&lt;init&gt;&quot;.
+   */
+  String CONSTRUCTOR_NAME = "<init>";
+
+  /** The names of the interfaces implemented by arrays */
+  String[] INTERFACES_IMPLEMENTED_BY_ARRAYS = {"java.lang.Cloneable", \
"java.io.Serializable"}; +
+  /**
+   * One of the limitations of the Java Virtual Machine.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.11">
 +   * The Java Virtual Machine Specification, Second Edition, page 152, chapter \
4.10.</a> +   */
+  int MAX_CP_ENTRIES     = 65535;
+
+  /**
+   * One of the limitations of the Java Virtual Machine.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.11">
 +   * The Java Virtual Machine Specification, Second Edition, page 152, chapter \
4.10.</a> +   */
+  int MAX_CODE_SIZE      = 65536; //bytes
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short NOP              = 0;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ACONST_NULL      = 1;
+
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_M1        = 2;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_0         = 3;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_1         = 4;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_2         = 5;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_3         = 6;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_4         = 7;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ICONST_5         = 8;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LCONST_0         = 9;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LCONST_1         = 10;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FCONST_0         = 11;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FCONST_1         = 12;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FCONST_2         = 13;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DCONST_0         = 14;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DCONST_1         = 15;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short BIPUSH           = 16;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short SIPUSH           = 17;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LDC              = 18;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LDC_W            = 19;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LDC2_W           = 20;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ILOAD            = 21;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LLOAD            = 22;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FLOAD            = 23;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DLOAD            = 24;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ALOAD            = 25;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ILOAD_0          = 26;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ILOAD_1          = 27;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ILOAD_2          = 28;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ILOAD_3          = 29;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LLOAD_0          = 30;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LLOAD_1          = 31;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LLOAD_2          = 32;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LLOAD_3          = 33;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FLOAD_0          = 34;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FLOAD_1          = 35;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FLOAD_2          = 36;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FLOAD_3          = 37;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DLOAD_0          = 38;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DLOAD_1          = 39;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DLOAD_2          = 40;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DLOAD_3          = 41;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ALOAD_0          = 42;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ALOAD_1          = 43;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ALOAD_2          = 44;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ALOAD_3          = 45;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IALOAD           = 46;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LALOAD           = 47;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FALOAD           = 48;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DALOAD           = 49;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short AALOAD           = 50;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short BALOAD           = 51;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short CALOAD           = 52;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short SALOAD           = 53;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISTORE           = 54;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSTORE           = 55;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FSTORE           = 56;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DSTORE           = 57;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ASTORE           = 58;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISTORE_0         = 59;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISTORE_1         = 60;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISTORE_2         = 61;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISTORE_3         = 62;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSTORE_0         = 63;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSTORE_1         = 64;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSTORE_2         = 65;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSTORE_3         = 66;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FSTORE_0         = 67;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FSTORE_1         = 68;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FSTORE_2         = 69;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FSTORE_3         = 70;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DSTORE_0         = 71;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DSTORE_1         = 72;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DSTORE_2         = 73;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DSTORE_3         = 74;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ASTORE_0         = 75;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ASTORE_1         = 76;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ASTORE_2         = 77;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ASTORE_3         = 78;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IASTORE          = 79;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LASTORE          = 80;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FASTORE          = 81;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DASTORE          = 82;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short AASTORE          = 83;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short BASTORE          = 84;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short CASTORE          = 85;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short SASTORE          = 86;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short POP              = 87;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short POP2             = 88;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DUP              = 89;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DUP_X1           = 90;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DUP_X2           = 91;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DUP2             = 92;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DUP2_X1          = 93;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DUP2_X2          = 94;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short SWAP             = 95;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IADD             = 96;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LADD             = 97;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FADD             = 98;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DADD             = 99;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISUB             = 100;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSUB             = 101;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FSUB             = 102;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DSUB             = 103;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IMUL             = 104;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LMUL             = 105;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FMUL             = 106;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DMUL             = 107;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IDIV             = 108;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LDIV             = 109;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FDIV             = 110;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DDIV             = 111;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IREM             = 112;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LREM             = 113;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FREM             = 114;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DREM             = 115;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INEG             = 116;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LNEG             = 117;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FNEG             = 118;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DNEG             = 119;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISHL             = 120;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSHL             = 121;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ISHR             = 122;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LSHR             = 123;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IUSHR            = 124;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LUSHR            = 125;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IAND             = 126;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LAND             = 127;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IOR              = 128;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LOR              = 129;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IXOR             = 130;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LXOR             = 131;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IINC             = 132;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short I2L              = 133;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short I2F              = 134;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short I2D              = 135;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short L2I              = 136;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short L2F              = 137;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short L2D              = 138;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short F2I              = 139;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short F2L              = 140;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short F2D              = 141;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short D2I              = 142;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short D2L              = 143;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short D2F              = 144;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short I2B              = 145;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INT2BYTE         = 145; // Old notion
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short I2C              = 146;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INT2CHAR         = 146; // Old notion
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short I2S              = 147;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INT2SHORT        = 147; // Old notion
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LCMP             = 148;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FCMPL            = 149;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FCMPG            = 150;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DCMPL            = 151;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DCMPG            = 152;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFEQ             = 153;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFNE             = 154;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFLT             = 155;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFGE             = 156;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFGT             = 157;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFLE             = 158;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ICMPEQ        = 159;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ICMPNE        = 160;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ICMPLT        = 161;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ICMPGE        = 162;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ICMPGT        = 163;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ICMPLE        = 164;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ACMPEQ        = 165;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IF_ACMPNE        = 166;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short GOTO             = 167;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short JSR              = 168;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short RET              = 169;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short TABLESWITCH      = 170;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LOOKUPSWITCH     = 171;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IRETURN          = 172;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short LRETURN          = 173;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short FRETURN          = 174;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short DRETURN          = 175;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ARETURN          = 176;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short RETURN           = 177;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short GETSTATIC        = 178;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short PUTSTATIC        = 179;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short GETFIELD         = 180;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short PUTFIELD         = 181;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INVOKEVIRTUAL    = 182;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INVOKESPECIAL    = 183;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INVOKENONVIRTUAL = 183; // Old name in JDK 1.0
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INVOKESTATIC     = 184;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INVOKEINTERFACE  = 185;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INVOKEDYNAMIC   = 186;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short NEW              = 187;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short NEWARRAY         = 188;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ANEWARRAY        = 189;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ARRAYLENGTH      = 190;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short ATHROW           = 191;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short CHECKCAST        = 192;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short INSTANCEOF       = 193;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short MONITORENTER     = 194;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short MONITOREXIT      = 195;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short WIDE             = 196;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short MULTIANEWARRAY   = 197;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFNULL           = 198;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short IFNONNULL        = 199;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short GOTO_W           = 200;
+  /** Java VM opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.5">
 +   * Opcode definitions in The Java Virtual Machine Specification</a> */
+  short JSR_W            = 201;
+
+  /** JVM internal opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.2">
 +   * Reserved opcodes in the Java Virtual Machine Specification</a> */
+  short BREAKPOINT                = 202;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short LDC_QUICK                 = 203;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short LDC_W_QUICK               = 204;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short LDC2_W_QUICK              = 205;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short GETFIELD_QUICK            = 206;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short PUTFIELD_QUICK            = 207;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short GETFIELD2_QUICK           = 208;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short PUTFIELD2_QUICK           = 209;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short GETSTATIC_QUICK           = 210;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short PUTSTATIC_QUICK           = 211;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short GETSTATIC2_QUICK          = 212;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short PUTSTATIC2_QUICK          = 213;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKEVIRTUAL_QUICK       = 214;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKENONVIRTUAL_QUICK    = 215;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKESUPER_QUICK         = 216;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKESTATIC_QUICK        = 217;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKEINTERFACE_QUICK     = 218;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKEVIRTUALOBJECT_QUICK = 219;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short NEW_QUICK                 = 221;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short ANEWARRAY_QUICK           = 222;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short MULTIANEWARRAY_QUICK      = 223;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short CHECKCAST_QUICK           = 224;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INSTANCEOF_QUICK          = 225;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short INVOKEVIRTUAL_QUICK_W     = 226;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short GETFIELD_QUICK_W          = 227;
+  /** JVM internal opcode.
+   * @see <a href="https://web.archive.org/web/20120108031230/http://java.sun.com/docs/books/jvms/first_edition/html/Quick.doc.html">
 +   * Specification of _quick opcodes in the Java Virtual Machine Specification \
(version 1)</a> +   * @see <a \
href="https://docs.oracle.com/javase/specs/jvms/se5.0/html/ChangesAppendix.doc.html#448885">
 +   * Why the _quick opcodes were removed from the second version of the Java \
Virtual Machine Specification.</a> */ +  short PUTFIELD_QUICK_W          = 228;
+  /** JVM internal opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.2">
 +   * Reserved opcodes in the Java Virtual Machine Specification</a> */
+  short IMPDEP1                   = 254;
+  /** JVM internal opcode.
+   * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-6.html#jvms-6.2">
 +   * Reserved opcodes in the Java Virtual Machine Specification</a> */
+  short IMPDEP2                   = 255;
+
+  /**
+   * BCEL virtual instruction for pushing an arbitrary data type onto the stack.  \
Will be converted to the appropriate JVM +   * opcode when the class is dumped.
+   */
+  short PUSH             = 4711;
+  /**
+   * BCEL virtual instruction for either LOOKUPSWITCH or TABLESWITCH.  Will be \
converted to the appropriate JVM +   * opcode when the class is dumped.
+   */
+  short SWITCH           = 4712;
+
+  /** Illegal opcode. */
+  short  UNDEFINED      = -1;
+  /** Illegal opcode. */
+  short  UNPREDICTABLE  = -2;
+  /** Illegal opcode. */
+  short  RESERVED       = -3;
+  /** Mnemonic for an illegal opcode. */
+  String ILLEGAL_OPCODE = "<illegal opcode>";
+  /** Mnemonic for an illegal type. */
+  String ILLEGAL_TYPE   = "<illegal type>";
+
+  /** Boolean data type. */
+  byte T_BOOLEAN = 4;
+  /** Char data type. */
+  byte T_CHAR    = 5;
+  /** Float data type. */
+  byte T_FLOAT   = 6;
+  /** Double data type. */
+  byte T_DOUBLE  = 7;
+  /** Byte data type. */
+  byte T_BYTE    = 8;
+  /** Short data type. */
+  byte T_SHORT   = 9;
+  /** Int data type. */
+  byte T_INT     = 10;
+  /** Long data type. */
+  byte T_LONG    = 11;
+
+  /** Void data type (non-standard). */
+  byte T_VOID      = 12; // Non-standard
+  /** Array data type. */
+  byte T_ARRAY     = 13;
+  /** Object data type. */
+  byte T_OBJECT    = 14;
+  /** Reference data type (deprecated). */
+  byte T_REFERENCE = 14; // Deprecated
+  /** Unknown data type. */
+  byte T_UNKNOWN   = 15;
+  /** Address data type. */
+  byte T_ADDRESS   = 16;
+
+  /** The primitive type names corresponding to the T_XX constants,
+   * e.g., TYPE_NAMES[T_INT] = "int"
+   */
+  String[] TYPE_NAMES = {
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE, ILLEGAL_TYPE,
+    "boolean", "char", "float", "double", "byte", "short", "int", "long",
+    "void", "array", "object", "unknown", "address"
+  };
+
+  /** The primitive class names corresponding to the T_XX constants,
+   * e.g., CLASS_TYPE_NAMES[T_INT] = "java.lang.Integer"
+   */
+  String[] CLASS_TYPE_NAMES = {
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE, ILLEGAL_TYPE,
+    "java.lang.Boolean", "java.lang.Character", "java.lang.Float",
+    "java.lang.Double", "java.lang.Byte", "java.lang.Short",
+    "java.lang.Integer", "java.lang.Long", "java.lang.Void",
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE,  ILLEGAL_TYPE
+  };
+
+  /** The signature characters corresponding to primitive types,
+   * e.g., SHORT_TYPE_NAMES[T_INT] = "I"
+   */
+  String[] SHORT_TYPE_NAMES = {
+    ILLEGAL_TYPE, ILLEGAL_TYPE,  ILLEGAL_TYPE, ILLEGAL_TYPE,
+    "Z", "C", "F", "D", "B", "S", "I", "J",
+    "V", ILLEGAL_TYPE, ILLEGAL_TYPE, ILLEGAL_TYPE
+  };
+
+  /**
+   * Number of byte code operands for each opcode, i.e., number of bytes after the \
tag byte +   * itself.  Indexed by opcode, so NO_OF_OPERANDS[BIPUSH] = the number of \
operands for a bipush +   * instruction.
+   */
+  short[] NO_OF_OPERANDS = {
+    0/*nop*/, 0/*aconst_null*/, 0/*iconst_m1*/, 0/*iconst_0*/,
+    0/*iconst_1*/, 0/*iconst_2*/, 0/*iconst_3*/, 0/*iconst_4*/,
+    0/*iconst_5*/, 0/*lconst_0*/, 0/*lconst_1*/, 0/*fconst_0*/,
+    0/*fconst_1*/, 0/*fconst_2*/, 0/*dconst_0*/, 0/*dconst_1*/,
+    1/*bipush*/, 2/*sipush*/, 1/*ldc*/, 2/*ldc_w*/, 2/*ldc2_w*/,
+    1/*iload*/, 1/*lload*/, 1/*fload*/, 1/*dload*/, 1/*aload*/,
+    0/*iload_0*/, 0/*iload_1*/, 0/*iload_2*/, 0/*iload_3*/,
+    0/*lload_0*/, 0/*lload_1*/, 0/*lload_2*/, 0/*lload_3*/,
+    0/*fload_0*/, 0/*fload_1*/, 0/*fload_2*/, 0/*fload_3*/,
+    0/*dload_0*/, 0/*dload_1*/, 0/*dload_2*/, 0/*dload_3*/,
+    0/*aload_0*/, 0/*aload_1*/, 0/*aload_2*/, 0/*aload_3*/,
+    0/*iaload*/, 0/*laload*/, 0/*faload*/, 0/*daload*/,
+    0/*aaload*/, 0/*baload*/, 0/*caload*/, 0/*saload*/,
+    1/*istore*/, 1/*lstore*/, 1/*fstore*/, 1/*dstore*/,
+    1/*astore*/, 0/*istore_0*/, 0/*istore_1*/, 0/*istore_2*/,
+    0/*istore_3*/, 0/*lstore_0*/, 0/*lstore_1*/, 0/*lstore_2*/,
+    0/*lstore_3*/, 0/*fstore_0*/, 0/*fstore_1*/, 0/*fstore_2*/,
+    0/*fstore_3*/, 0/*dstore_0*/, 0/*dstore_1*/, 0/*dstore_2*/,
+    0/*dstore_3*/, 0/*astore_0*/, 0/*astore_1*/, 0/*astore_2*/,
+    0/*astore_3*/, 0/*iastore*/, 0/*lastore*/, 0/*fastore*/,
+    0/*dastore*/, 0/*aastore*/, 0/*bastore*/, 0/*castore*/,
+    0/*sastore*/, 0/*pop*/, 0/*pop2*/, 0/*dup*/, 0/*dup_x1*/,
+    0/*dup_x2*/, 0/*dup2*/, 0/*dup2_x1*/, 0/*dup2_x2*/, 0/*swap*/,
+    0/*iadd*/, 0/*ladd*/, 0/*fadd*/, 0/*dadd*/, 0/*isub*/,
+    0/*lsub*/, 0/*fsub*/, 0/*dsub*/, 0/*imul*/, 0/*lmul*/,
+    0/*fmul*/, 0/*dmul*/, 0/*idiv*/, 0/*ldiv*/, 0/*fdiv*/,
+    0/*ddiv*/, 0/*irem*/, 0/*lrem*/, 0/*frem*/, 0/*drem*/,
+    0/*ineg*/, 0/*lneg*/, 0/*fneg*/, 0/*dneg*/, 0/*ishl*/,
+    0/*lshl*/, 0/*ishr*/, 0/*lshr*/, 0/*iushr*/, 0/*lushr*/,
+    0/*iand*/, 0/*land*/, 0/*ior*/, 0/*lor*/, 0/*ixor*/, 0/*lxor*/,
+    2/*iinc*/, 0/*i2l*/, 0/*i2f*/, 0/*i2d*/, 0/*l2i*/, 0/*l2f*/,
+    0/*l2d*/, 0/*f2i*/, 0/*f2l*/, 0/*f2d*/, 0/*d2i*/, 0/*d2l*/,
+    0/*d2f*/, 0/*i2b*/, 0/*i2c*/, 0/*i2s*/, 0/*lcmp*/, 0/*fcmpl*/,
+    0/*fcmpg*/, 0/*dcmpl*/, 0/*dcmpg*/, 2/*ifeq*/, 2/*ifne*/,
+    2/*iflt*/, 2/*ifge*/, 2/*ifgt*/, 2/*ifle*/, 2/*if_icmpeq*/,
+    2/*if_icmpne*/, 2/*if_icmplt*/, 2/*if_icmpge*/, 2/*if_icmpgt*/,
+    2/*if_icmple*/, 2/*if_acmpeq*/, 2/*if_acmpne*/, 2/*goto*/,
+    2/*jsr*/, 1/*ret*/, UNPREDICTABLE/*tableswitch*/, UNPREDICTABLE/*lookupswitch*/,
+    0/*ireturn*/, 0/*lreturn*/, 0/*freturn*/,
+    0/*dreturn*/, 0/*areturn*/, 0/*return*/,
+    2/*getstatic*/, 2/*putstatic*/, 2/*getfield*/,
+    2/*putfield*/, 2/*invokevirtual*/, 2/*invokespecial*/, 2/*invokestatic*/,
+    4/*invokeinterface*/, 4/*invokedynamic*/, 2/*new*/,
+    1/*newarray*/, 2/*anewarray*/,
+    0/*arraylength*/, 0/*athrow*/, 2/*checkcast*/,
+    2/*instanceof*/, 0/*monitorenter*/,
+    0/*monitorexit*/, UNPREDICTABLE/*wide*/, 3/*multianewarray*/,
+    2/*ifnull*/, 2/*ifnonnull*/, 4/*goto_w*/,
+    4/*jsr_w*/, 0/*breakpoint*/, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, RESERVED/*impdep1*/, RESERVED/*impdep2*/
+  };
+
+  /**
+   * How the byte code operands are to be interpreted for each opcode.
+   * Indexed by opcode.  TYPE_OF_OPERANDS[ILOAD] = an array of shorts
+   * describing the data types for the instruction.
+   */
+  short[][] TYPE_OF_OPERANDS = {
+    {}/*nop*/, {}/*aconst_null*/, {}/*iconst_m1*/, {}/*iconst_0*/,
+    {}/*iconst_1*/, {}/*iconst_2*/, {}/*iconst_3*/, {}/*iconst_4*/,
+    {}/*iconst_5*/, {}/*lconst_0*/, {}/*lconst_1*/, {}/*fconst_0*/,
+    {}/*fconst_1*/, {}/*fconst_2*/, {}/*dconst_0*/, {}/*dconst_1*/,
+    {T_BYTE}/*bipush*/, {T_SHORT}/*sipush*/, {T_BYTE}/*ldc*/,
+    {T_SHORT}/*ldc_w*/, {T_SHORT}/*ldc2_w*/,
+    {T_BYTE}/*iload*/, {T_BYTE}/*lload*/, {T_BYTE}/*fload*/,
+    {T_BYTE}/*dload*/, {T_BYTE}/*aload*/, {}/*iload_0*/,
+    {}/*iload_1*/, {}/*iload_2*/, {}/*iload_3*/, {}/*lload_0*/,
+    {}/*lload_1*/, {}/*lload_2*/, {}/*lload_3*/, {}/*fload_0*/,
+    {}/*fload_1*/, {}/*fload_2*/, {}/*fload_3*/, {}/*dload_0*/,
+    {}/*dload_1*/, {}/*dload_2*/, {}/*dload_3*/, {}/*aload_0*/,
+    {}/*aload_1*/, {}/*aload_2*/, {}/*aload_3*/, {}/*iaload*/,
+    {}/*laload*/, {}/*faload*/, {}/*daload*/, {}/*aaload*/,
+    {}/*baload*/, {}/*caload*/, {}/*saload*/, {T_BYTE}/*istore*/,
+    {T_BYTE}/*lstore*/, {T_BYTE}/*fstore*/, {T_BYTE}/*dstore*/,
+    {T_BYTE}/*astore*/, {}/*istore_0*/, {}/*istore_1*/,
+    {}/*istore_2*/, {}/*istore_3*/, {}/*lstore_0*/, {}/*lstore_1*/,
+    {}/*lstore_2*/, {}/*lstore_3*/, {}/*fstore_0*/, {}/*fstore_1*/,
+    {}/*fstore_2*/, {}/*fstore_3*/, {}/*dstore_0*/, {}/*dstore_1*/,
+    {}/*dstore_2*/, {}/*dstore_3*/, {}/*astore_0*/, {}/*astore_1*/,
+    {}/*astore_2*/, {}/*astore_3*/, {}/*iastore*/, {}/*lastore*/,
+    {}/*fastore*/, {}/*dastore*/, {}/*aastore*/, {}/*bastore*/,
+    {}/*castore*/, {}/*sastore*/, {}/*pop*/, {}/*pop2*/, {}/*dup*/,
+    {}/*dup_x1*/, {}/*dup_x2*/, {}/*dup2*/, {}/*dup2_x1*/,
+    {}/*dup2_x2*/, {}/*swap*/, {}/*iadd*/, {}/*ladd*/, {}/*fadd*/,
+    {}/*dadd*/, {}/*isub*/, {}/*lsub*/, {}/*fsub*/, {}/*dsub*/,
+    {}/*imul*/, {}/*lmul*/, {}/*fmul*/, {}/*dmul*/, {}/*idiv*/,
+    {}/*ldiv*/, {}/*fdiv*/, {}/*ddiv*/, {}/*irem*/, {}/*lrem*/,
+    {}/*frem*/, {}/*drem*/, {}/*ineg*/, {}/*lneg*/, {}/*fneg*/,
+    {}/*dneg*/, {}/*ishl*/, {}/*lshl*/, {}/*ishr*/, {}/*lshr*/,
+    {}/*iushr*/, {}/*lushr*/, {}/*iand*/, {}/*land*/, {}/*ior*/,
+    {}/*lor*/, {}/*ixor*/, {}/*lxor*/, {T_BYTE, T_BYTE}/*iinc*/,
+    {}/*i2l*/, {}/*i2f*/, {}/*i2d*/, {}/*l2i*/, {}/*l2f*/, {}/*l2d*/,
+    {}/*f2i*/, {}/*f2l*/, {}/*f2d*/, {}/*d2i*/, {}/*d2l*/, {}/*d2f*/,
+    {}/*i2b*/, {}/*i2c*/,{}/*i2s*/, {}/*lcmp*/, {}/*fcmpl*/,
+    {}/*fcmpg*/, {}/*dcmpl*/, {}/*dcmpg*/, {T_SHORT}/*ifeq*/,
+    {T_SHORT}/*ifne*/, {T_SHORT}/*iflt*/, {T_SHORT}/*ifge*/,
+    {T_SHORT}/*ifgt*/, {T_SHORT}/*ifle*/, {T_SHORT}/*if_icmpeq*/,
+    {T_SHORT}/*if_icmpne*/, {T_SHORT}/*if_icmplt*/,
+    {T_SHORT}/*if_icmpge*/, {T_SHORT}/*if_icmpgt*/,
+    {T_SHORT}/*if_icmple*/, {T_SHORT}/*if_acmpeq*/,
+    {T_SHORT}/*if_acmpne*/, {T_SHORT}/*goto*/, {T_SHORT}/*jsr*/,
+    {T_BYTE}/*ret*/, {}/*tableswitch*/, {}/*lookupswitch*/,
+    {}/*ireturn*/, {}/*lreturn*/, {}/*freturn*/, {}/*dreturn*/,
+    {}/*areturn*/, {}/*return*/, {T_SHORT}/*getstatic*/,
+    {T_SHORT}/*putstatic*/, {T_SHORT}/*getfield*/,
+    {T_SHORT}/*putfield*/, {T_SHORT}/*invokevirtual*/,
+    {T_SHORT}/*invokespecial*/, {T_SHORT}/*invokestatic*/,
+    {T_SHORT, T_BYTE, T_BYTE}/*invokeinterface*/, {T_SHORT, T_BYTE, \
T_BYTE}/*invokedynamic*/, +    {T_SHORT}/*new*/, {T_BYTE}/*newarray*/,
+    {T_SHORT}/*anewarray*/, {}/*arraylength*/, {}/*athrow*/,
+    {T_SHORT}/*checkcast*/, {T_SHORT}/*instanceof*/,
+    {}/*monitorenter*/, {}/*monitorexit*/, {T_BYTE}/*wide*/,
+    {T_SHORT, T_BYTE}/*multianewarray*/, {T_SHORT}/*ifnull*/,
+    {T_SHORT}/*ifnonnull*/, {T_INT}/*goto_w*/, {T_INT}/*jsr_w*/,
+    {}/*breakpoint*/, {}, {}, {}, {}, {}, {}, {},
+    {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {},
+    {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {},
+    {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {}, {},
+    {}/*impdep1*/, {}/*impdep2*/
+  };
+
+  /**
+   * Names of opcodes.  Indexed by opcode.  OPCODE_NAMES[ALOAD] = "aload".
+   */
+  String[] OPCODE_NAMES = {
+    "nop", "aconst_null", "iconst_m1", "iconst_0", "iconst_1",
+    "iconst_2", "iconst_3", "iconst_4", "iconst_5", "lconst_0",
+    "lconst_1", "fconst_0", "fconst_1", "fconst_2", "dconst_0",
+    "dconst_1", "bipush", "sipush", "ldc", "ldc_w", "ldc2_w", "iload",
+    "lload", "fload", "dload", "aload", "iload_0", "iload_1", "iload_2",
+    "iload_3", "lload_0", "lload_1", "lload_2", "lload_3", "fload_0",
+    "fload_1", "fload_2", "fload_3", "dload_0", "dload_1", "dload_2",
+    "dload_3", "aload_0", "aload_1", "aload_2", "aload_3", "iaload",
+    "laload", "faload", "daload", "aaload", "baload", "caload", "saload",
+    "istore", "lstore", "fstore", "dstore", "astore", "istore_0",
+    "istore_1", "istore_2", "istore_3", "lstore_0", "lstore_1",
+    "lstore_2", "lstore_3", "fstore_0", "fstore_1", "fstore_2",
+    "fstore_3", "dstore_0", "dstore_1", "dstore_2", "dstore_3",
+    "astore_0", "astore_1", "astore_2", "astore_3", "iastore", "lastore",
+    "fastore", "dastore", "aastore", "bastore", "castore", "sastore",
+    "pop", "pop2", "dup", "dup_x1", "dup_x2", "dup2", "dup2_x1",
+    "dup2_x2", "swap", "iadd", "ladd", "fadd", "dadd", "isub", "lsub",
+    "fsub", "dsub", "imul", "lmul", "fmul", "dmul", "idiv", "ldiv",
+    "fdiv", "ddiv", "irem", "lrem", "frem", "drem", "ineg", "lneg",
+    "fneg", "dneg", "ishl", "lshl", "ishr", "lshr", "iushr", "lushr",
+    "iand", "land", "ior", "lor", "ixor", "lxor", "iinc", "i2l", "i2f",
+    "i2d", "l2i", "l2f", "l2d", "f2i", "f2l", "f2d", "d2i", "d2l", "d2f",
+    "i2b", "i2c", "i2s", "lcmp", "fcmpl", "fcmpg",
+    "dcmpl", "dcmpg", "ifeq", "ifne", "iflt", "ifge", "ifgt", "ifle",
+    "if_icmpeq", "if_icmpne", "if_icmplt", "if_icmpge", "if_icmpgt",
+    "if_icmple", "if_acmpeq", "if_acmpne", "goto", "jsr", "ret",
+    "tableswitch", "lookupswitch", "ireturn", "lreturn", "freturn",
+    "dreturn", "areturn", "return", "getstatic", "putstatic", "getfield",
+    "putfield", "invokevirtual", "invokespecial", "invokestatic",
+    "invokeinterface", "invokedynamic", "new", "newarray", "anewarray",
+    "arraylength", "athrow", "checkcast", "instanceof", "monitorenter",
+    "monitorexit", "wide", "multianewarray", "ifnull", "ifnonnull",
+    "goto_w", "jsr_w", "breakpoint", ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE, ILLEGAL_OPCODE,
+    ILLEGAL_OPCODE, "impdep1", "impdep2"
+  };
+
+  /**
+   * Number of words consumed on operand stack by instructions.
+   * Indexed by opcode.  CONSUME_STACK[FALOAD] = number of words
+   * consumed from the stack by a faload instruction.
+   */
+  int[] CONSUME_STACK = {
+    0/*nop*/, 0/*aconst_null*/, 0/*iconst_m1*/, 0/*iconst_0*/, 0/*iconst_1*/,
+    0/*iconst_2*/, 0/*iconst_3*/, 0/*iconst_4*/, 0/*iconst_5*/, 0/*lconst_0*/,
+    0/*lconst_1*/, 0/*fconst_0*/, 0/*fconst_1*/, 0/*fconst_2*/, 0/*dconst_0*/,
+    0/*dconst_1*/, 0/*bipush*/, 0/*sipush*/, 0/*ldc*/, 0/*ldc_w*/, 0/*ldc2_w*/, \
0/*iload*/, +    0/*lload*/, 0/*fload*/, 0/*dload*/, 0/*aload*/, 0/*iload_0*/, \
0/*iload_1*/, 0/*iload_2*/, +    0/*iload_3*/, 0/*lload_0*/, 0/*lload_1*/, \
0/*lload_2*/, 0/*lload_3*/, 0/*fload_0*/, +    0/*fload_1*/, 0/*fload_2*/, \
0/*fload_3*/, 0/*dload_0*/, 0/*dload_1*/, 0/*dload_2*/, +    0/*dload_3*/, \
0/*aload_0*/, 0/*aload_1*/, 0/*aload_2*/, 0/*aload_3*/, 2/*iaload*/, +    \
2/*laload*/, 2/*faload*/, 2/*daload*/, 2/*aaload*/, 2/*baload*/, 2/*caload*/, \
2/*saload*/, +    1/*istore*/, 2/*lstore*/, 1/*fstore*/, 2/*dstore*/, 1/*astore*/, \
1/*istore_0*/, +    1/*istore_1*/, 1/*istore_2*/, 1/*istore_3*/, 2/*lstore_0*/, \
2/*lstore_1*/, +    2/*lstore_2*/, 2/*lstore_3*/, 1/*fstore_0*/, 1/*fstore_1*/, \
1/*fstore_2*/, +    1/*fstore_3*/, 2/*dstore_0*/, 2/*dstore_1*/, 2/*dstore_2*/, \
2/*dstore_3*/, +    1/*astore_0*/, 1/*astore_1*/, 1/*astore_2*/, 1/*astore_3*/, \
3/*iastore*/, 4/*lastore*/, +    3/*fastore*/, 4/*dastore*/, 3/*aastore*/, \
3/*bastore*/, 3/*castore*/, 3/*sastore*/, +    1/*pop*/, 2/*pop2*/, 1/*dup*/, \
2/*dup_x1*/, 3/*dup_x2*/, 2/*dup2*/, 3/*dup2_x1*/, +    4/*dup2_x2*/, 2/*swap*/, \
2/*iadd*/, 4/*ladd*/, 2/*fadd*/, 4/*dadd*/, 2/*isub*/, 4/*lsub*/, +    2/*fsub*/, \
4/*dsub*/, 2/*imul*/, 4/*lmul*/, 2/*fmul*/, 4/*dmul*/, 2/*idiv*/, 4/*ldiv*/, +    \
2/*fdiv*/, 4/*ddiv*/, 2/*irem*/, 4/*lrem*/, 2/*frem*/, 4/*drem*/, 1/*ineg*/, \
2/*lneg*/, +    1/*fneg*/, 2/*dneg*/, 2/*ishl*/, 3/*lshl*/, 2/*ishr*/, 3/*lshr*/, \
2/*iushr*/, 3/*lushr*/, +    2/*iand*/, 4/*land*/, 2/*ior*/, 4/*lor*/, 2/*ixor*/, \
4/*lxor*/, 0/*iinc*/, +    1/*i2l*/, 1/*i2f*/, 1/*i2d*/, 2/*l2i*/, 2/*l2f*/, \
2/*l2d*/, 1/*f2i*/, 1/*f2l*/, +    1/*f2d*/, 2/*d2i*/, 2/*d2l*/, 2/*d2f*/, 1/*i2b*/, \
1/*i2c*/, 1/*i2s*/, +    4/*lcmp*/, 2/*fcmpl*/, 2/*fcmpg*/, 4/*dcmpl*/, 4/*dcmpg*/, \
1/*ifeq*/, 1/*ifne*/, +    1/*iflt*/, 1/*ifge*/, 1/*ifgt*/, 1/*ifle*/, \
2/*if_icmpeq*/, 2/*if_icmpne*/, 2/*if_icmplt*/, +    2 /*if_icmpge*/, 2/*if_icmpgt*/, \
2/*if_icmple*/, 2/*if_acmpeq*/, 2/*if_acmpne*/, +    0/*goto*/, 0/*jsr*/, 0/*ret*/, \
1/*tableswitch*/, 1/*lookupswitch*/, 1/*ireturn*/, +    2/*lreturn*/, 1/*freturn*/, \
2/*dreturn*/, 1/*areturn*/, 0/*return*/, 0/*getstatic*/, +    \
UNPREDICTABLE/*putstatic*/, 1/*getfield*/, UNPREDICTABLE/*putfield*/, +    \
UNPREDICTABLE/*invokevirtual*/, UNPREDICTABLE/*invokespecial*/, +    \
UNPREDICTABLE/*invokestatic*/, +    UNPREDICTABLE/*invokeinterface*/, \
UNPREDICTABLE/*invokedynamic*/, 0/*new*/, 1/*newarray*/, 1/*anewarray*/, +    \
1/*arraylength*/, 1/*athrow*/, 1/*checkcast*/, 1/*instanceof*/, 1/*monitorenter*/, +  \
1/*monitorexit*/, 0/*wide*/, UNPREDICTABLE/*multianewarray*/, 1/*ifnull*/, \
1/*ifnonnull*/, +    0/*goto_w*/, 0/*jsr_w*/, 0/*breakpoint*/, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNPREDICTABLE/*impdep1*/, UNPREDICTABLE/*impdep2*/
+  };
+
+  /**
+   * Number of words produced onto operand stack by instructions.
+   * Indexed by opcode.  CONSUME_STACK[DALOAD] = number of words
+   * consumed from the stack by a daload instruction.
+   */
+  int[] PRODUCE_STACK = {
+    0/*nop*/, 1/*aconst_null*/, 1/*iconst_m1*/, 1/*iconst_0*/, 1/*iconst_1*/,
+    1/*iconst_2*/, 1/*iconst_3*/, 1/*iconst_4*/, 1/*iconst_5*/, 2/*lconst_0*/,
+    2/*lconst_1*/, 1/*fconst_0*/, 1/*fconst_1*/, 1/*fconst_2*/, 2/*dconst_0*/,
+    2/*dconst_1*/, 1/*bipush*/, 1/*sipush*/, 1/*ldc*/, 1/*ldc_w*/, 2/*ldc2_w*/, \
1/*iload*/, +    2/*lload*/, 1/*fload*/, 2/*dload*/, 1/*aload*/, 1/*iload_0*/, \
1/*iload_1*/, 1/*iload_2*/, +    1/*iload_3*/, 2/*lload_0*/, 2/*lload_1*/, \
2/*lload_2*/, 2/*lload_3*/, 1/*fload_0*/, +    1/*fload_1*/, 1/*fload_2*/, \
1/*fload_3*/, 2/*dload_0*/, 2/*dload_1*/, 2/*dload_2*/, +    2/*dload_3*/, \
1/*aload_0*/, 1/*aload_1*/, 1/*aload_2*/, 1/*aload_3*/, 1/*iaload*/, +    \
2/*laload*/, 1/*faload*/, 2/*daload*/, 1/*aaload*/, 1/*baload*/, 1/*caload*/, \
1/*saload*/, +    0/*istore*/, 0/*lstore*/, 0/*fstore*/, 0/*dstore*/, 0/*astore*/, \
0/*istore_0*/, +    0/*istore_1*/, 0/*istore_2*/, 0/*istore_3*/, 0/*lstore_0*/, \
0/*lstore_1*/, +    0/*lstore_2*/, 0/*lstore_3*/, 0/*fstore_0*/, 0/*fstore_1*/, \
0/*fstore_2*/, +    0/*fstore_3*/, 0/*dstore_0*/, 0/*dstore_1*/, 0/*dstore_2*/, \
0/*dstore_3*/, +    0/*astore_0*/, 0/*astore_1*/, 0/*astore_2*/, 0/*astore_3*/, \
0/*iastore*/, 0/*lastore*/, +    0/*fastore*/, 0/*dastore*/, 0/*aastore*/, \
0/*bastore*/, 0/*castore*/, 0/*sastore*/, +    0/*pop*/, 0/*pop2*/, 2/*dup*/, \
3/*dup_x1*/, 4/*dup_x2*/, 4/*dup2*/, 5/*dup2_x1*/, +    6/*dup2_x2*/, 2/*swap*/, \
1/*iadd*/, 2/*ladd*/, 1/*fadd*/, 2/*dadd*/, 1/*isub*/, 2/*lsub*/, +    1/*fsub*/, \
2/*dsub*/, 1/*imul*/, 2/*lmul*/, 1/*fmul*/, 2/*dmul*/, 1/*idiv*/, 2/*ldiv*/, +    \
1/*fdiv*/, 2/*ddiv*/, 1/*irem*/, 2/*lrem*/, 1/*frem*/, 2/*drem*/, 1/*ineg*/, \
2/*lneg*/, +    1/*fneg*/, 2/*dneg*/, 1/*ishl*/, 2/*lshl*/, 1/*ishr*/, 2/*lshr*/, \
1/*iushr*/, 2/*lushr*/, +    1/*iand*/, 2/*land*/, 1/*ior*/, 2/*lor*/, 1/*ixor*/, \
2/*lxor*/, +    0/*iinc*/, 2/*i2l*/, 1/*i2f*/, 2/*i2d*/, 1/*l2i*/, 1/*l2f*/, \
2/*l2d*/, 1/*f2i*/, +    2/*f2l*/, 2/*f2d*/, 1/*d2i*/, 2/*d2l*/, 1/*d2f*/,
+    1/*i2b*/, 1/*i2c*/, 1/*i2s*/, 1/*lcmp*/, 1/*fcmpl*/, 1/*fcmpg*/,
+    1/*dcmpl*/, 1/*dcmpg*/, 0/*ifeq*/, 0/*ifne*/, 0/*iflt*/, 0/*ifge*/, 0/*ifgt*/, \
0/*ifle*/, +    0/*if_icmpeq*/, 0/*if_icmpne*/, 0/*if_icmplt*/, 0/*if_icmpge*/, \
0/*if_icmpgt*/, +    0/*if_icmple*/, 0/*if_acmpeq*/, 0/*if_acmpne*/, 0/*goto*/, \
1/*jsr*/, 0/*ret*/, +    0/*tableswitch*/, 0/*lookupswitch*/, 0/*ireturn*/, \
0/*lreturn*/, 0/*freturn*/, +    0/*dreturn*/, 0/*areturn*/, 0/*return*/, \
UNPREDICTABLE/*getstatic*/, 0/*putstatic*/, +    UNPREDICTABLE/*getfield*/, \
0/*putfield*/, UNPREDICTABLE/*invokevirtual*/, +    UNPREDICTABLE/*invokespecial*/, \
UNPREDICTABLE/*invokestatic*/, +    UNPREDICTABLE/*invokeinterface*/, \
UNPREDICTABLE/*invokedynamic*/, 1/*new*/, 1/*newarray*/, 1/*anewarray*/, +    \
1/*arraylength*/, 1/*athrow*/, 1/*checkcast*/, 1/*instanceof*/, 0/*monitorenter*/, +  \
0/*monitorexit*/, 0/*wide*/, 1/*multianewarray*/, 0/*ifnull*/, 0/*ifnonnull*/, +    \
0/*goto_w*/, 1/*jsr_w*/, 0/*breakpoint*/, UNDEFINED, UNDEFINED, +    UNDEFINED, \
UNDEFINED, UNDEFINED, UNDEFINED, +    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNDEFINED, UNDEFINED, UNDEFINED,
+    UNDEFINED, UNPREDICTABLE/*impdep1*/, UNPREDICTABLE/*impdep2*/
+  };
+
+  /** Attributes and their corresponding names.
+   */
+  byte ATTR_UNKNOWN                                 = -1;
+  byte ATTR_SOURCE_FILE                             = 0;
+  byte ATTR_CONSTANT_VALUE                          = 1;
+  byte ATTR_CODE                                    = 2;
+  byte ATTR_EXCEPTIONS                              = 3;
+  byte ATTR_LINE_NUMBER_TABLE                       = 4;
+  byte ATTR_LOCAL_VARIABLE_TABLE                    = 5;
+  byte ATTR_INNER_CLASSES                           = 6;
+  byte ATTR_SYNTHETIC                               = 7;
+  byte ATTR_DEPRECATED                              = 8;
+  byte ATTR_PMG                                     = 9;
+  byte ATTR_SIGNATURE                               = 10;
+  byte ATTR_STACK_MAP                               = 11;
+  byte ATTR_RUNTIMEVISIBLE_ANNOTATIONS              = 12;
+  byte ATTR_RUNTIMEINVISIBLE_ANNOTATIONS            = 13;
+  byte ATTR_RUNTIMEVISIBLE_PARAMETER_ANNOTATIONS    = 14;
+  byte ATTR_RUNTIMEINVISIBLE_PARAMETER_ANNOTATIONS  = 15;
+  byte ATTR_ANNOTATION_DEFAULT                      = 16;
+
+  short KNOWN_ATTRIBUTES = 12;//should be 17
+
+
+  // TODO: mutable public array!!
+  String[] ATTRIBUTE_NAMES = {
+    "SourceFile", "ConstantValue", "Code", "Exceptions",
+    "LineNumberTable", "LocalVariableTable",
+    "InnerClasses", "Synthetic", "Deprecated",
+    "PMGClass", "Signature", "StackMap",
+    "RuntimeVisibleAnnotations", "RuntimeInvisibleAnnotations",
+    "RuntimeVisibleParameterAnnotations", "RuntimeInvisibleParameterAnnotations",
+    "AnnotationDefault"
+  };
+
+  /** Constants used in the StackMap attribute.
+   */
+  byte ITEM_Bogus      = 0;
+  byte ITEM_Integer    = 1;
+  byte ITEM_Float      = 2;
+  byte ITEM_Double     = 3;
+  byte ITEM_Long       = 4;
+  byte ITEM_Null       = 5;
+  byte ITEM_InitObject = 6;
+  byte ITEM_Object     = 7;
+  byte ITEM_NewObject  = 8;
+
+  String[] ITEM_NAMES = {
+    "Bogus", "Integer", "Float", "Double", "Long",
+    "Null", "InitObject", "Object", "NewObject"
+  };
+
+}
diff --git a/src/org/apache/bcel/ExceptionConst.java \
b/src/org/apache/bcel/ExceptionConst.java new file mode 100644
index 00000000..ed2c4268
--- /dev/null
+++ b/src/org/apache/bcel/ExceptionConst.java
@@ -0,0 +1,135 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel;
+
+/**
+ * Exception constants.
+ * @since 6.0 (intended to replace the InstructionConstant interface)
+ */
+public final class ExceptionConst {
+
+    /**
+     * The mother of all exceptions
+     */
+    public static final Class<Throwable> THROWABLE = Throwable.class;
+
+    /**
+     * Super class of any run-time exception
+     */
+    public static final Class<RuntimeException> RUNTIME_EXCEPTION = \
RuntimeException.class; +
+    /**
+     * Super class of any linking exception (aka Linkage Error)
+     */
+    public static final Class<LinkageError> LINKING_EXCEPTION = LinkageError.class;
+
+    /**
+     * Linking Exceptions
+     */
+    public static final Class<ClassCircularityError> CLASS_CIRCULARITY_ERROR = \
ClassCircularityError.class; +    public static final Class<ClassFormatError> \
CLASS_FORMAT_ERROR = ClassFormatError.class; +    public static final \
Class<ExceptionInInitializerError> EXCEPTION_IN_INITIALIZER_ERROR = \
ExceptionInInitializerError.class; +    public static final \
Class<IncompatibleClassChangeError> INCOMPATIBLE_CLASS_CHANGE_ERROR = \
IncompatibleClassChangeError.class; +    public static final \
Class<AbstractMethodError> ABSTRACT_METHOD_ERROR = AbstractMethodError.class; +    \
public static final Class<IllegalAccessError> ILLEGAL_ACCESS_ERROR = \
IllegalAccessError.class; +    public static final Class<InstantiationError> \
INSTANTIATION_ERROR = InstantiationError.class; +    public static final \
Class<NoSuchFieldError> NO_SUCH_FIELD_ERROR = NoSuchFieldError.class; +    public \
static final Class<NoSuchMethodError> NO_SUCH_METHOD_ERROR = NoSuchMethodError.class; \
+    public static final Class<NoClassDefFoundError> NO_CLASS_DEF_FOUND_ERROR = \
NoClassDefFoundError.class; +    public static final Class<UnsatisfiedLinkError> \
UNSATISFIED_LINK_ERROR = UnsatisfiedLinkError.class; +    public static final \
Class<VerifyError> VERIFY_ERROR = VerifyError.class; +    /* \
UnsupportedClassVersionError is new in JDK 1.2 */ +//    public static final Class \
UnsupportedClassVersionError = UnsupportedClassVersionError.class; +
+    /**
+     * Run-Time Exceptions
+     */
+    public static final Class<NullPointerException> NULL_POINTER_EXCEPTION = \
NullPointerException.class; +    public static final \
Class<ArrayIndexOutOfBoundsException> ARRAY_INDEX_OUT_OF_BOUNDS_EXCEPTION +           \
= ArrayIndexOutOfBoundsException.class; +    public static final \
Class<ArithmeticException> ARITHMETIC_EXCEPTION = ArithmeticException.class; +    \
public static final Class<NegativeArraySizeException> NEGATIVE_ARRAY_SIZE_EXCEPTION = \
NegativeArraySizeException.class; +    public static final Class<ClassCastException> \
CLASS_CAST_EXCEPTION = ClassCastException.class; +    public static final \
Class<IllegalMonitorStateException> ILLEGAL_MONITOR_STATE = \
IllegalMonitorStateException.class; +
+    /**
+     * Pre-defined exception arrays according to chapters 5.1-5.4 of the Java \
Virtual +     * Machine Specification
+     */
+    private static final Class<?>[] EXCS_CLASS_AND_INTERFACE_RESOLUTION = {
+            NO_CLASS_DEF_FOUND_ERROR, CLASS_FORMAT_ERROR, VERIFY_ERROR, \
ABSTRACT_METHOD_ERROR, +            EXCEPTION_IN_INITIALIZER_ERROR, \
ILLEGAL_ACCESS_ERROR +    }; // Chapter 5.1
+    private static final Class<?>[] EXCS_FIELD_AND_METHOD_RESOLUTION = {
+            NO_SUCH_FIELD_ERROR, ILLEGAL_ACCESS_ERROR, NO_SUCH_METHOD_ERROR
+    }; // Chapter 5.2
+    private static final Class<?>[] EXCS_INTERFACE_METHOD_RESOLUTION = new Class[0]; \
// Chapter 5.3 (as below) +    private static final Class<?>[] EXCS_STRING_RESOLUTION \
= new Class[0]; +    // Chapter 5.4 (no errors but the ones that _always_ could \
happen! How stupid.) +    private static final Class<?>[] EXCS_ARRAY_EXCEPTION = {
+            NULL_POINTER_EXCEPTION, ARRAY_INDEX_OUT_OF_BOUNDS_EXCEPTION
+    };
+
+    /**
+     * Enum corresponding to the various Exception Class arrays,
+     * used by {@link ExceptionConst#createExceptions(EXCS, Class...)}
+     */
+    public enum EXCS {
+        EXCS_CLASS_AND_INTERFACE_RESOLUTION,
+        EXCS_FIELD_AND_METHOD_RESOLUTION,
+        EXCS_INTERFACE_METHOD_RESOLUTION,
+        EXCS_STRING_RESOLUTION,
+        EXCS_ARRAY_EXCEPTION,
+    }
+
+    // helper method to merge exception class arrays
+    private static Class<?>[] mergeExceptions(final Class<?>[] input, final Class<?> \
... extraClasses) { +        final int extraLen = extraClasses == null ? 0 : \
extraClasses.length; +        final Class<?>[] excs = new Class<?>[input.length + \
extraLen]; +        System.arraycopy(input, 0, excs, 0, input.length);
+        if (extraLen > 0) {
+            System.arraycopy(extraClasses, 0, excs, input.length, extraLen);
+        }
+        return excs;
+    }
+
+    /**
+     * Creates a copy of the specified Exception Class array combined with any \
additional Exception classes. +     * @param type the basic array type
+     * @param extraClasses additional classes, if any
+     * @return the merged array
+     */
+    public static Class<?>[] createExceptions(final EXCS type, final Class<?> ... \
extraClasses) { +        switch (type) {
+        case EXCS_CLASS_AND_INTERFACE_RESOLUTION:
+            return mergeExceptions(EXCS_CLASS_AND_INTERFACE_RESOLUTION, \
extraClasses); +        case EXCS_ARRAY_EXCEPTION:
+            return mergeExceptions(EXCS_ARRAY_EXCEPTION, extraClasses);
+        case EXCS_FIELD_AND_METHOD_RESOLUTION:
+            return mergeExceptions(EXCS_FIELD_AND_METHOD_RESOLUTION, extraClasses);
+        case EXCS_INTERFACE_METHOD_RESOLUTION:
+            return mergeExceptions(EXCS_INTERFACE_METHOD_RESOLUTION, extraClasses);
+        case EXCS_STRING_RESOLUTION:
+            return mergeExceptions(EXCS_STRING_RESOLUTION, extraClasses);
+        default:
+            throw new AssertionError("Cannot happen; unexpected enum value: " + \
type); +        }
+    }
+
+
+}
diff --git a/src/org/apache/bcel/ExceptionConstants.java \
b/src/org/apache/bcel/ExceptionConstants.java new file mode 100644
index 00000000..ea0e1ce6
--- /dev/null
+++ b/src/org/apache/bcel/ExceptionConstants.java
@@ -0,0 +1,87 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel;
+
+/**
+ * Exception constants.
+ *
+ * @deprecated (since 6.0) DO NOT USE - use ExceptionConst instead
+ */
+@Deprecated
+public interface ExceptionConstants {
+
+    /** The mother of all exceptions
+     */
+    Class<Throwable> THROWABLE = Throwable.class;
+    /** Super class of any run-time exception
+     */
+    Class<RuntimeException> RUNTIME_EXCEPTION = RuntimeException.class;
+    /** Super class of any linking exception (aka Linkage Error)
+     */
+    Class<LinkageError> LINKING_EXCEPTION = LinkageError.class;
+    /** Linking Exceptions
+     */
+    Class<ClassCircularityError> CLASS_CIRCULARITY_ERROR = \
ClassCircularityError.class; +    Class<ClassFormatError> CLASS_FORMAT_ERROR = \
ClassFormatError.class; +    Class<ExceptionInInitializerError> \
EXCEPTION_IN_INITIALIZER_ERROR = ExceptionInInitializerError.class; +    \
Class<IncompatibleClassChangeError> INCOMPATIBLE_CLASS_CHANGE_ERROR = \
IncompatibleClassChangeError.class; +    Class<AbstractMethodError> \
ABSTRACT_METHOD_ERROR = AbstractMethodError.class; +    Class<IllegalAccessError> \
ILLEGAL_ACCESS_ERROR = IllegalAccessError.class; +    Class<InstantiationError> \
INSTANTIATION_ERROR = InstantiationError.class; +    Class<NoSuchFieldError> \
NO_SUCH_FIELD_ERROR = NoSuchFieldError.class; +    Class<NoSuchMethodError> \
NO_SUCH_METHOD_ERROR = NoSuchMethodError.class; +    Class<NoClassDefFoundError> \
NO_CLASS_DEF_FOUND_ERROR = NoClassDefFoundError.class; +    \
Class<UnsatisfiedLinkError> UNSATISFIED_LINK_ERROR = UnsatisfiedLinkError.class; +    \
Class<VerifyError> VERIFY_ERROR = VerifyError.class; +    /* \
UnsupportedClassVersionError is new in JDK 1.2 */ +//    Class \
UnsupportedClassVersionError = UnsupportedClassVersionError.class; +    /** Run-Time \
Exceptions +     */
+    Class<NullPointerException> NULL_POINTER_EXCEPTION = NullPointerException.class;
+    Class<ArrayIndexOutOfBoundsException> ARRAY_INDEX_OUT_OF_BOUNDS_EXCEPTION
+                                                            = \
ArrayIndexOutOfBoundsException.class; +    Class<ArithmeticException> \
ARITHMETIC_EXCEPTION = ArithmeticException.class; +    \
Class<NegativeArraySizeException> NEGATIVE_ARRAY_SIZE_EXCEPTION = \
NegativeArraySizeException.class; +    Class<ClassCastException> CLASS_CAST_EXCEPTION \
= ClassCastException.class; +    Class<IllegalMonitorStateException> \
ILLEGAL_MONITOR_STATE = IllegalMonitorStateException.class; +
+    /**
+     * Pre-defined exception arrays according to chapters 5.1-5.4 of the Java \
Virtual +     * Machine Specification
+     * @deprecated Do not use these arrays, use the static methods in the \
ExceptionConst implementation class instead +     */
+    @Deprecated
+    Class<?>[] EXCS_CLASS_AND_INTERFACE_RESOLUTION = {
+            NO_CLASS_DEF_FOUND_ERROR, CLASS_FORMAT_ERROR, VERIFY_ERROR, \
ABSTRACT_METHOD_ERROR, +            EXCEPTION_IN_INITIALIZER_ERROR, \
ILLEGAL_ACCESS_ERROR +    }; // Chapter 5.1
+    @Deprecated
+    Class<?>[] EXCS_FIELD_AND_METHOD_RESOLUTION = {
+            NO_SUCH_FIELD_ERROR, ILLEGAL_ACCESS_ERROR, NO_SUCH_METHOD_ERROR
+    }; // Chapter 5.2
+    @Deprecated
+    Class<?>[] EXCS_INTERFACE_METHOD_RESOLUTION = new Class[0]; // Chapter 5.3 (as \
below) +    @Deprecated
+    Class<?>[] EXCS_STRING_RESOLUTION = new Class[0];
+    // Chapter 5.4 (no errors but the ones that _always_ could happen! How stupid.)
+    @Deprecated
+    Class<?>[] EXCS_ARRAY_EXCEPTION = {
+            NULL_POINTER_EXCEPTION, ARRAY_INDEX_OUT_OF_BOUNDS_EXCEPTION
+    };
+
+}
diff --git a/src/org/apache/bcel/Repository.java \
b/src/org/apache/bcel/Repository.java new file mode 100644
index 00000000..edcccb4a
--- /dev/null
+++ b/src/org/apache/bcel/Repository.java
@@ -0,0 +1,266 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel;
+
+import java.io.IOException;
+
+import org.apache.bcel.classfile.JavaClass;
+import org.apache.bcel.util.ClassPath;
+import org.apache.bcel.util.SyntheticRepository;
+
+/**
+ * The repository maintains informations about class interdependencies, e.g.,
+ * whether a class is a sub-class of another. Delegates actual class loading
+ * to SyntheticRepository with current class path by default.
+ *
+ * @see org.apache.bcel.util.Repository
+ * @see SyntheticRepository
+ *
+ */
+public abstract class Repository {
+
+    private static org.apache.bcel.util.Repository repository = \
SyntheticRepository.getInstance(); +
+
+    /**
+     * @return currently used repository instance
+     */
+    public static org.apache.bcel.util.Repository getRepository() {
+        return repository;
+    }
+
+
+    /**
+     * Sets repository instance to be used for class loading
+     */
+    public static void setRepository( final org.apache.bcel.util.Repository rep ) {
+        repository = rep;
+    }
+
+
+    /**
+     * Lookups class somewhere found on your CLASSPATH, or whereever the
+     * repository instance looks for it.
+     *
+     * @return class object for given fully qualified class name
+     * @throws ClassNotFoundException if the class could not be found or
+     * parsed correctly
+     */
+    public static JavaClass lookupClass( final String class_name ) throws \
ClassNotFoundException { +        return repository.loadClass(class_name);
+    }
+
+
+    /**
+     * Tries to find class source using the internal repository instance.
+     *
+     * @see Class
+     * @return JavaClass object for given runtime class
+     * @throws ClassNotFoundException if the class could not be found or
+     * parsed correctly
+     */
+    public static JavaClass lookupClass( final Class<?> clazz ) throws \
ClassNotFoundException { +        return repository.loadClass(clazz);
+    }
+
+
+    /**
+     * @return class file object for given Java class by looking on the
+     *  system class path; returns null if the class file can't be
+     *  found
+     */
+    public static ClassPath.ClassFile lookupClassFile( final String class_name ) {
+        try {
+            final ClassPath path = repository.getClassPath();
+            if (path == null) {
+                return null;
+            }
+            return path.getClassFile(class_name);
+        } catch (final IOException e) {
+            return null;
+        }
+    }
+
+
+    /**
+     * Clears the repository.
+     */
+    public static void clearCache() {
+        repository.clear();
+    }
+
+
+    /**
+     * Adds clazz to repository if there isn't an equally named class already in \
there. +     *
+     * @return old entry in repository
+     */
+    public static JavaClass addClass( final JavaClass clazz ) {
+        final JavaClass old = repository.findClass(clazz.getClassName());
+        repository.storeClass(clazz);
+        return old;
+    }
+
+
+    /**
+     * Removes class with given (fully qualified) name from repository.
+     */
+    public static void removeClass( final String clazz ) {
+        repository.removeClass(repository.findClass(clazz));
+    }
+
+
+    /**
+     * Removes given class from repository.
+     */
+    public static void removeClass( final JavaClass clazz ) {
+        repository.removeClass(clazz);
+    }
+
+
+    /**
+     * @return list of super classes of clazz in ascending order, i.e.,
+     * Object is always the last element
+     * @throws ClassNotFoundException if any of the superclasses can't be found
+     */
+    public static JavaClass[] getSuperClasses( final JavaClass clazz ) throws \
ClassNotFoundException { +        return clazz.getSuperClasses();
+    }
+
+
+    /**
+     * @return list of super classes of clazz in ascending order, i.e.,
+     * Object is always the last element.
+     * @throws ClassNotFoundException if the named class or any of its
+     *  superclasses can't be found
+     */
+    public static JavaClass[] getSuperClasses( final String class_name ) throws \
ClassNotFoundException { +        final JavaClass jc = lookupClass(class_name);
+        return getSuperClasses(jc);
+    }
+
+
+    /**
+     * @return all interfaces implemented by class and its super
+     * classes and the interfaces that those interfaces extend, and so on.
+     * (Some people call this a transitive hull).
+     * @throws ClassNotFoundException if any of the class's
+     *  superclasses or superinterfaces can't be found
+     */
+    public static JavaClass[] getInterfaces( final JavaClass clazz ) throws \
ClassNotFoundException { +        return clazz.getAllInterfaces();
+    }
+
+
+    /**
+     * @return all interfaces implemented by class and its super
+     * classes and the interfaces that extend those interfaces, and so on
+     * @throws ClassNotFoundException if the named class can't be found,
+     *   or if any of its superclasses or superinterfaces can't be found
+     */
+    public static JavaClass[] getInterfaces( final String class_name ) throws \
ClassNotFoundException { +        return getInterfaces(lookupClass(class_name));
+    }
+
+
+    /**
+     * Equivalent to runtime "instanceof" operator.
+     * @return true, if clazz is an instance of super_class
+     * @throws ClassNotFoundException if any superclasses or superinterfaces
+     *   of clazz can't be found
+     */
+    public static boolean instanceOf( final JavaClass clazz, final JavaClass \
super_class ) +            throws ClassNotFoundException {
+        return clazz.instanceOf(super_class);
+    }
+
+
+    /**
+     * @return true, if clazz is an instance of super_class
+     * @throws ClassNotFoundException if either clazz or super_class
+     *   can't be found
+     */
+    public static boolean instanceOf( final String clazz, final String super_class )
+            throws ClassNotFoundException {
+        return instanceOf(lookupClass(clazz), lookupClass(super_class));
+    }
+
+
+    /**
+     * @return true, if clazz is an instance of super_class
+     * @throws ClassNotFoundException if super_class can't be found
+     */
+    public static boolean instanceOf( final JavaClass clazz, final String \
super_class ) +            throws ClassNotFoundException {
+        return instanceOf(clazz, lookupClass(super_class));
+    }
+
+
+    /**
+     * @return true, if clazz is an instance of super_class
+     * @throws ClassNotFoundException if clazz can't be found
+     */
+    public static boolean instanceOf( final String clazz, final JavaClass \
super_class ) +            throws ClassNotFoundException {
+        return instanceOf(lookupClass(clazz), super_class);
+    }
+
+
+    /**
+     * @return true, if clazz is an implementation of interface inter
+     * @throws ClassNotFoundException if any superclasses or superinterfaces
+     *   of clazz can't be found
+     */
+    public static boolean implementationOf( final JavaClass clazz, final JavaClass \
inter ) +            throws ClassNotFoundException {
+        return clazz.implementationOf(inter);
+    }
+
+
+    /**
+     * @return true, if clazz is an implementation of interface inter
+     * @throws ClassNotFoundException if clazz, inter, or any superclasses
+     *   or superinterfaces of clazz can't be found
+     */
+    public static boolean implementationOf( final String clazz, final String inter )
+            throws ClassNotFoundException {
+        return implementationOf(lookupClass(clazz), lookupClass(inter));
+    }
+
+
+    /**
+     * @return true, if clazz is an implementation of interface inter
+     * @throws ClassNotFoundException if inter or any superclasses
+     *   or superinterfaces of clazz can't be found
+     */
+    public static boolean implementationOf( final JavaClass clazz, final String \
inter ) +            throws ClassNotFoundException {
+        return implementationOf(clazz, lookupClass(inter));
+    }
+
+
+    /**
+     * @return true, if clazz is an implementation of interface inter
+     * @throws ClassNotFoundException if clazz or any superclasses or
+     *   superinterfaces of clazz can't be found
+     */
+    public static boolean implementationOf( final String clazz, final JavaClass \
inter ) +            throws ClassNotFoundException {
+        return implementationOf(lookupClass(clazz), inter);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/AccessFlags.java \
b/src/org/apache/bcel/classfile/AccessFlags.java new file mode 100644
index 00000000..2d03a763
--- /dev/null
+++ b/src/org/apache/bcel/classfile/AccessFlags.java
@@ -0,0 +1,218 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import org.apache.bcel.Const;
+
+/**
+ * Super class for all objects that have modifiers like private, final, ... I.e. \
classes, fields, and methods. + *
+ */
+public abstract class AccessFlags {
+
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected int access_flags; // TODO not used externally at present
+
+    public AccessFlags() {
+    }
+
+    /**
+     * @param a
+     *            inital access flags
+     */
+    public AccessFlags(final int a) {
+        access_flags = a;
+    }
+
+    /**
+     * @return Access flags of the object aka. "modifiers".
+     */
+    public final int getAccessFlags() {
+        return access_flags;
+    }
+
+    /**
+     * @return Access flags of the object aka. "modifiers".
+     */
+    public final int getModifiers() {
+        return access_flags;
+    }
+
+    /**
+     * Set access flags aka "modifiers".
+     *
+     * @param access_flags
+     *            Access flags of the object.
+     */
+    public final void setAccessFlags(final int access_flags) {
+        this.access_flags = access_flags;
+    }
+
+    /**
+     * Set access flags aka "modifiers".
+     *
+     * @param access_flags
+     *            Access flags of the object.
+     */
+    public final void setModifiers(final int access_flags) {
+        setAccessFlags(access_flags);
+    }
+
+    private void setFlag(final int flag, final boolean set) {
+        if ((access_flags & flag) != 0) { // Flag is set already
+            if (!set) {
+                access_flags ^= flag;
+            }
+        } else { // Flag not set
+            if (set) {
+                access_flags |= flag;
+            }
+        }
+    }
+
+    public final void isPublic(final boolean flag) {
+        setFlag(Const.ACC_PUBLIC, flag);
+    }
+
+    public final boolean isPublic() {
+        return (access_flags & Const.ACC_PUBLIC) != 0;
+    }
+
+    public final void isPrivate(final boolean flag) {
+        setFlag(Const.ACC_PRIVATE, flag);
+    }
+
+    public final boolean isPrivate() {
+        return (access_flags & Const.ACC_PRIVATE) != 0;
+    }
+
+    public final void isProtected(final boolean flag) {
+        setFlag(Const.ACC_PROTECTED, flag);
+    }
+
+    public final boolean isProtected() {
+        return (access_flags & Const.ACC_PROTECTED) != 0;
+    }
+
+    public final void isStatic(final boolean flag) {
+        setFlag(Const.ACC_STATIC, flag);
+    }
+
+    public final boolean isStatic() {
+        return (access_flags & Const.ACC_STATIC) != 0;
+    }
+
+    public final void isFinal(final boolean flag) {
+        setFlag(Const.ACC_FINAL, flag);
+    }
+
+    public final boolean isFinal() {
+        return (access_flags & Const.ACC_FINAL) != 0;
+    }
+
+    public final void isSynchronized(final boolean flag) {
+        setFlag(Const.ACC_SYNCHRONIZED, flag);
+    }
+
+    public final boolean isSynchronized() {
+        return (access_flags & Const.ACC_SYNCHRONIZED) != 0;
+    }
+
+    public final void isVolatile(final boolean flag) {
+        setFlag(Const.ACC_VOLATILE, flag);
+    }
+
+    public final boolean isVolatile() {
+        return (access_flags & Const.ACC_VOLATILE) != 0;
+    }
+
+    public final void isTransient(final boolean flag) {
+        setFlag(Const.ACC_TRANSIENT, flag);
+    }
+
+    public final boolean isTransient() {
+        return (access_flags & Const.ACC_TRANSIENT) != 0;
+    }
+
+    public final void isNative(final boolean flag) {
+        setFlag(Const.ACC_NATIVE, flag);
+    }
+
+    public final boolean isNative() {
+        return (access_flags & Const.ACC_NATIVE) != 0;
+    }
+
+    public final void isInterface(final boolean flag) {
+        setFlag(Const.ACC_INTERFACE, flag);
+    }
+
+    public final boolean isInterface() {
+        return (access_flags & Const.ACC_INTERFACE) != 0;
+    }
+
+    public final void isAbstract(final boolean flag) {
+        setFlag(Const.ACC_ABSTRACT, flag);
+    }
+
+    public final boolean isAbstract() {
+        return (access_flags & Const.ACC_ABSTRACT) != 0;
+    }
+
+    public final void isStrictfp(final boolean flag) {
+        setFlag(Const.ACC_STRICT, flag);
+    }
+
+    public final boolean isStrictfp() {
+        return (access_flags & Const.ACC_STRICT) != 0;
+    }
+
+    public final void isSynthetic(final boolean flag) {
+        setFlag(Const.ACC_SYNTHETIC, flag);
+    }
+
+    public final boolean isSynthetic() {
+        return (access_flags & Const.ACC_SYNTHETIC) != 0;
+    }
+
+    public final void isAnnotation(final boolean flag) {
+        setFlag(Const.ACC_ANNOTATION, flag);
+    }
+
+    public final boolean isAnnotation() {
+        return (access_flags & Const.ACC_ANNOTATION) != 0;
+    }
+
+    public final void isEnum(final boolean flag) {
+        setFlag(Const.ACC_ENUM, flag);
+    }
+
+    public final boolean isEnum() {
+        return (access_flags & Const.ACC_ENUM) != 0;
+    }
+
+    public final void isVarArgs(final boolean flag) {
+        setFlag(Const.ACC_VARARGS, flag);
+    }
+
+    public final boolean isVarArgs() {
+        return (access_flags & Const.ACC_VARARGS) != 0;
+    }
+}
diff --git a/src/org/apache/bcel/classfile/AnnotationDefault.java \
b/src/org/apache/bcel/classfile/AnnotationDefault.java new file mode 100644
index 00000000..c0efe4c2
--- /dev/null
+++ b/src/org/apache/bcel/classfile/AnnotationDefault.java
@@ -0,0 +1,93 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * Represents the default value of a annotation for a method info
+ *
+ * @since 6.0
+ */
+public class AnnotationDefault extends Attribute {
+
+    private ElementValue defaultValue;
+
+    /**
+     * @param name_index    Index pointing to the name <em>Code</em>
+     * @param length        Content length in bytes
+     * @param input         Input stream
+     * @param constant_pool Array of constants
+     */
+    AnnotationDefault(final int name_index, final int length, final DataInput input, \
final ConstantPool constant_pool) throws IOException { +        this(name_index, \
length, (ElementValue) null, constant_pool); +        defaultValue = \
ElementValue.readElementValue(input, constant_pool); +    }
+
+    /**
+     * @param name_index    Index pointing to the name <em>Code</em>
+     * @param length        Content length in bytes
+     * @param defaultValue  the annotation's default value
+     * @param constant_pool Array of constants
+     */
+    public AnnotationDefault(final int name_index, final int length, final \
ElementValue defaultValue, final ConstantPool constant_pool) { +        \
super(Const.ATTR_ANNOTATION_DEFAULT, name_index, length, constant_pool); +        \
this.defaultValue = defaultValue; +    }
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept(final Visitor v) {
+        v.visitAnnotationDefault(this);
+    }
+
+    /**
+     * @param defaultValue the default value of this methodinfo's annotation
+     */
+    public final void setDefaultValue(final ElementValue defaultValue) {
+        this.defaultValue = defaultValue;
+    }
+
+    /**
+     * @return the default value
+     */
+    public final ElementValue getDefaultValue() {
+        return defaultValue;
+    }
+
+    @Override
+    public Attribute copy(final ConstantPool _constant_pool) {
+        return (Attribute) clone();
+    }
+
+    @Override
+    public final void dump(final DataOutputStream dos) throws IOException {
+        super.dump(dos);
+        defaultValue.dump(dos);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/AnnotationElementValue.java \
b/src/org/apache/bcel/classfile/AnnotationElementValue.java new file mode 100644
index 00000000..86e68ea1
--- /dev/null
+++ b/src/org/apache/bcel/classfile/AnnotationElementValue.java
@@ -0,0 +1,65 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+/**
+ * @since 6.0
+ */
+public class AnnotationElementValue extends ElementValue
+{
+        // For annotation element values, this is the annotation
+        private final AnnotationEntry annotationEntry;
+
+        public AnnotationElementValue(final int type, final AnnotationEntry \
annotationEntry, +                        final ConstantPool cpool)
+        {
+                super(type, cpool);
+                if (type != ANNOTATION) {
+                    throw new IllegalArgumentException(
+                                    "Only element values of type annotation can be \
built with this ctor - type specified: " + type); +                }
+                this.annotationEntry = annotationEntry;
+        }
+
+        @Override
+        public void dump(final DataOutputStream dos) throws IOException
+        {
+                dos.writeByte(super.getType()); // u1 type of value (ANNOTATION == \
'@') +                annotationEntry.dump(dos);
+        }
+
+        @Override
+        public String stringifyValue()
+        {
+                return annotationEntry.toString();
+        }
+
+        @Override
+        public String toString()
+        {
+                return stringifyValue();
+        }
+
+        public AnnotationEntry getAnnotationEntry()
+        {
+                return annotationEntry;
+        }
+}
diff --git a/src/org/apache/bcel/classfile/AnnotationEntry.java \
b/src/org/apache/bcel/classfile/AnnotationEntry.java new file mode 100644
index 00000000..6540e2d0
--- /dev/null
+++ b/src/org/apache/bcel/classfile/AnnotationEntry.java
@@ -0,0 +1,167 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+import org.apache.bcel.Const;
+
+/**
+ * represents one annotation in the annotation table
+ *
+ * @since 6.0
+ */
+public class AnnotationEntry implements Node {
+
+    private final int typeIndex;
+    private final ConstantPool constantPool;
+    private final boolean isRuntimeVisible;
+
+    private List<ElementValuePair> elementValuePairs;
+
+    /*
+     * Factory method to create an AnnotionEntry from a DataInput
+     *
+     * @param input
+     * @param constantPool
+     * @param isRuntimeVisible
+     * @return the entry
+     * @throws IOException
+     */
+    public static AnnotationEntry read(final DataInput input, final ConstantPool \
constant_pool, final boolean isRuntimeVisible) throws IOException { +
+        final AnnotationEntry annotationEntry = new \
AnnotationEntry(input.readUnsignedShort(), constant_pool, isRuntimeVisible); +        \
final int num_element_value_pairs = input.readUnsignedShort(); +        \
annotationEntry.elementValuePairs = new ArrayList<>(); +        for (int i = 0; i < \
num_element_value_pairs; i++) { +            annotationEntry.elementValuePairs.add(
+                    new ElementValuePair(input.readUnsignedShort(), \
ElementValue.readElementValue(input, constant_pool), +                    \
constant_pool)); +        }
+        return annotationEntry;
+    }
+
+    public AnnotationEntry(final int type_index, final ConstantPool constant_pool, \
final boolean isRuntimeVisible) { +        this.typeIndex = type_index;
+        this.constantPool = constant_pool;
+        this.isRuntimeVisible = isRuntimeVisible;
+    }
+
+    public int getTypeIndex() {
+        return typeIndex;
+    }
+
+    public ConstantPool getConstantPool() {
+        return constantPool;
+    }
+
+    public boolean isRuntimeVisible() {
+        return isRuntimeVisible;
+    }
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely \
defined by the contents of a Java class. +     * I.e., the hierarchy of methods, \
fields, attributes, etc. spawns a tree of objects. +     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept(final Visitor v) {
+        v.visitAnnotationEntry(this);
+    }
+
+    /**
+     * @return the annotation type name
+     */
+    public String getAnnotationType() {
+        final ConstantUtf8 c = (ConstantUtf8) constantPool.getConstant(typeIndex, \
Const.CONSTANT_Utf8); +        return c.getBytes();
+    }
+
+    /**
+     * @return the annotation type index
+     */
+    public int getAnnotationTypeIndex() {
+        return typeIndex;
+    }
+
+    /**
+     * @return the number of element value pairs in this annotation entry
+     */
+    public final int getNumElementValuePairs() {
+        return elementValuePairs.size();
+    }
+
+    /**
+     * @return the element value pairs in this annotation entry
+     */
+    public ElementValuePair[] getElementValuePairs() {
+        // TODO return List
+        return elementValuePairs.toArray(new \
ElementValuePair[elementValuePairs.size()]); +    }
+
+    public void dump(final DataOutputStream dos) throws IOException {
+        dos.writeShort(typeIndex); // u2 index of type name in cpool
+        dos.writeShort(elementValuePairs.size()); // u2 element_value pair
+        // count
+        for (final ElementValuePair envp : elementValuePairs) {
+            envp.dump(dos);
+        }
+    }
+
+    public void addElementNameValuePair(final ElementValuePair elementNameValuePair) \
{ +        elementValuePairs.add(elementNameValuePair);
+    }
+
+    public String toShortString() {
+        final StringBuilder result = new StringBuilder();
+        result.append("@");
+        result.append(getAnnotationType());
+        final ElementValuePair[] evPairs = getElementValuePairs();
+        if (evPairs.length > 0) {
+            result.append("(");
+            for (final ElementValuePair element : evPairs) {
+                result.append(element.toShortString());
+            }
+            result.append(")");
+        }
+        return result.toString();
+    }
+
+    @Override
+    public String toString() {
+        return toShortString();
+    }
+
+    public static AnnotationEntry[] createAnnotationEntries(final Attribute[] attrs) \
{ +        // Find attributes that contain annotation data
+        final List<AnnotationEntry> accumulatedAnnotations = new \
ArrayList<>(attrs.length); +        for (final Attribute attribute : attrs) {
+            if (attribute instanceof Annotations) {
+                final Annotations runtimeAnnotations = (Annotations) attribute;
+                Collections.addAll(accumulatedAnnotations, \
runtimeAnnotations.getAnnotationEntries()); +            }
+        }
+        return accumulatedAnnotations.toArray(new \
AnnotationEntry[accumulatedAnnotations.size()]); +    }
+}
diff --git a/src/org/apache/bcel/classfile/Annotations.java \
b/src/org/apache/bcel/classfile/Annotations.java new file mode 100644
index 00000000..584cc5fa
--- /dev/null
+++ b/src/org/apache/bcel/classfile/Annotations.java
@@ -0,0 +1,113 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+/**
+ * base class for annotations
+ *
+ * @since 6.0
+ */
+public abstract class Annotations extends Attribute {
+
+    private AnnotationEntry[] annotationTable;
+    private final boolean isRuntimeVisible;
+
+    /**
+     * @param annotation_type the subclass type of the annotation
+     * @param name_index Index pointing to the name <em>Code</em>
+     * @param length Content length in bytes
+     * @param input Input stream
+     * @param constant_pool Array of constants
+     */
+    Annotations(final byte annotation_type, final int name_index, final int length, \
final DataInput input, +            final ConstantPool constant_pool, final boolean \
isRuntimeVisible) throws IOException { +        this(annotation_type, name_index, \
length, (AnnotationEntry[]) null, constant_pool, isRuntimeVisible); +        final \
int annotation_table_length = input.readUnsignedShort(); +        annotationTable = \
new AnnotationEntry[annotation_table_length]; +        for (int i = 0; i < \
annotation_table_length; i++) { +            annotationTable[i] = \
AnnotationEntry.read(input, constant_pool, isRuntimeVisible); +        }
+    }
+
+    /**
+     * @param annotationType the subclass type of the annotation
+     * @param nameIndex Index pointing to the name <em>Code</em>
+     * @param length Content length in bytes
+     * @param annotationTable the actual annotations
+     * @param constantPool Array of constants
+     */
+    public Annotations(final byte annotationType, final int nameIndex, final int \
length, final AnnotationEntry[] annotationTable, +            final ConstantPool \
constantPool, final boolean isRuntimeVisible) { +        super(annotationType, \
nameIndex, length, constantPool); +        this.annotationTable = annotationTable;
+        this.isRuntimeVisible = isRuntimeVisible;
+    }
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely \
defined by the contents of a Java class. +     * I.e., the hierarchy of methods, \
fields, attributes, etc. spawns a tree of objects. +     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept(final Visitor v) {
+        v.visitAnnotation(this);
+    }
+
+    /**
+     * @param annotationTable the entries to set in this annotation
+     */
+    public final void setAnnotationTable(final AnnotationEntry[] annotationTable) {
+        this.annotationTable = annotationTable;
+    }
+
+    /**
+     * returns the array of annotation entries in this annotation
+     */
+    public AnnotationEntry[] getAnnotationEntries() {
+        return annotationTable;
+    }
+
+    /**
+     * @return the number of annotation entries in this annotation
+     */
+    public final int getNumAnnotations() {
+        if (annotationTable == null) {
+            return 0;
+        }
+        return annotationTable.length;
+    }
+
+    public boolean isRuntimeVisible() {
+        return isRuntimeVisible;
+    }
+
+    protected void writeAnnotations(final DataOutputStream dos) throws IOException {
+        if (annotationTable == null) {
+            return;
+        }
+        dos.writeShort(annotationTable.length);
+        for (final AnnotationEntry element : annotationTable) {
+            element.dump(dos);
+        }
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ArrayElementValue.java \
b/src/org/apache/bcel/classfile/ArrayElementValue.java new file mode 100644
index 00000000..734a904d
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ArrayElementValue.java
@@ -0,0 +1,92 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+/**
+ * @since 6.0
+ */
+public class ArrayElementValue extends ElementValue
+{
+    // For array types, this is the array
+    private final ElementValue[] elementValues;
+
+    @Override
+    public String toString()
+    {
+        final StringBuilder sb = new StringBuilder();
+        sb.append("{");
+        for (int i = 0; i < elementValues.length; i++)
+        {
+            sb.append(elementValues[i]);
+            if ((i + 1) < elementValues.length) {
+                sb.append(",");
+            }
+        }
+        sb.append("}");
+        return sb.toString();
+    }
+
+    public ArrayElementValue(final int type, final ElementValue[] datums, final \
ConstantPool cpool) +    {
+        super(type, cpool);
+        if (type != ARRAY) {
+            throw new IllegalArgumentException(
+                    "Only element values of type array can be built with this ctor - \
type specified: " + type); +        }
+        this.elementValues = datums;
+    }
+
+    @Override
+    public void dump(final DataOutputStream dos) throws IOException
+    {
+        dos.writeByte(super.getType()); // u1 type of value (ARRAY == '[')
+        dos.writeShort(elementValues.length);
+        for (final ElementValue evalue : elementValues) {
+            evalue.dump(dos);
+        }
+    }
+
+    @Override
+    public String stringifyValue()
+    {
+        final StringBuilder sb = new StringBuilder();
+        sb.append("[");
+        for (int i = 0; i < elementValues.length; i++)
+        {
+            sb.append(elementValues[i].stringifyValue());
+            if ((i + 1) < elementValues.length) {
+                sb.append(",");
+            }
+        }
+        sb.append("]");
+        return sb.toString();
+    }
+
+    public ElementValue[] getElementValuesArray()
+    {
+        return elementValues;
+    }
+
+    public int getElementValuesArraySize()
+    {
+        return elementValues.length;
+    }
+}
diff --git a/src/org/apache/bcel/classfile/Attribute.java \
b/src/org/apache/bcel/classfile/Attribute.java new file mode 100644
index 00000000..72e5c4e8
--- /dev/null
+++ b/src/org/apache/bcel/classfile/Attribute.java
@@ -0,0 +1,389 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataInputStream;
+import java.io.DataOutputStream;
+import java.io.IOException;
+import java.util.HashMap;
+import java.util.Map;
+
+import org.apache.bcel.Const;
+
+/**
+ * Abstract super class for <em>Attribute</em> objects. Currently the
+ * <em>ConstantValue</em>, <em>SourceFile</em>, <em>Code</em>,
+ * <em>Exceptiontable</em>, <em>LineNumberTable</em>,
+ * <em>LocalVariableTable</em>, <em>InnerClasses</em> and
+ * <em>Synthetic</em> attributes are supported. The <em>Unknown</em>
+ * attribute stands for non-standard-attributes.
+ *
+ * @see ConstantValue
+ * @see SourceFile
+ * @see Code
+ * @see Unknown
+ * @see ExceptionTable
+ * @see LineNumberTable
+ * @see LocalVariableTable
+ * @see InnerClasses
+ * @see Synthetic
+ * @see Deprecated
+ * @see Signature
+ */
+public abstract class Attribute implements Cloneable, Node {
+
+    private static final boolean debug = \
Boolean.getBoolean(Attribute.class.getCanonicalName() + ".debug"); // Debugging \
on/off +
+    private static final Map<String, Object> readers = new HashMap<>();
+
+    /**
+     * Add an Attribute reader capable of parsing (user-defined) attributes
+     * named "name". You should not add readers for the standard attributes such
+     * as "LineNumberTable", because those are handled internally.
+     *
+     * @param name the name of the attribute as stored in the class file
+     * @param r    the reader object
+     * @deprecated (6.0) Use {@link #addAttributeReader(String, \
UnknownAttributeReader)} instead +     */
+    @java.lang.Deprecated
+    public static void addAttributeReader(final String name, final AttributeReader \
r) +    {
+        readers.put(name, r);
+    }
+
+    /**
+     * Add an Attribute reader capable of parsing (user-defined) attributes
+     * named "name". You should not add readers for the standard attributes such
+     * as "LineNumberTable", because those are handled internally.
+     *
+     * @param name the name of the attribute as stored in the class file
+     * @param r    the reader object
+     */
+    public static void addAttributeReader(final String name, final \
UnknownAttributeReader r) +    {
+        readers.put(name, r);
+    }
+
+    protected static void println(final String msg) {
+        if (debug) {
+            System.err.println(msg);
+        }
+    }
+
+    /**
+     * Class method reads one attribute from the input data stream. This method
+     * must not be accessible from the outside. It is called by the Field and
+     * Method constructor methods.
+     *
+     * @see Field
+     * @see Method
+     *
+     * @param file Input stream
+     * @param constant_pool Array of constants
+     * @return Attribute
+     * @throws IOException
+     * @throws ClassFormatException
+     * @since 6.0
+     */
+    public static Attribute readAttribute(final DataInput file, final ConstantPool \
constant_pool) +            throws IOException, ClassFormatException
+    {
+        byte tag = Const.ATTR_UNKNOWN; // Unknown attribute
+        // Get class name from constant pool via `name_index' indirection
+        final int name_index = file.readUnsignedShort();
+        final ConstantUtf8 c = (ConstantUtf8) constant_pool.getConstant(name_index, \
Const.CONSTANT_Utf8); +        final String name = c.getBytes();
+
+        // Length of data in bytes
+        final int length = file.readInt();
+
+        // Compare strings to find known attribute
+        for (byte i = 0; i < Const.KNOWN_ATTRIBUTES; i++)
+        {
+            if (name.equals(Const.getAttributeName(i)))
+            {
+                tag = i; // found!
+                break;
+            }
+        }
+
+        // Call proper constructor, depending on `tag'
+        switch (tag)
+        {
+            case Const.ATTR_UNKNOWN:
+                final Object r = readers.get(name);
+                if (r instanceof UnknownAttributeReader)
+                {
+                    return ((UnknownAttributeReader) r).createAttribute(name_index, \
length, file, constant_pool); +                }
+                return new Unknown(name_index, length, file, constant_pool);
+            case Const.ATTR_CONSTANT_VALUE:
+                return new ConstantValue(name_index, length, file, constant_pool);
+            case Const.ATTR_SOURCE_FILE:
+                return new SourceFile(name_index, length, file, constant_pool);
+            case Const.ATTR_CODE:
+                return new Code(name_index, length, file, constant_pool);
+            case Const.ATTR_EXCEPTIONS:
+                return new ExceptionTable(name_index, length, file, constant_pool);
+            case Const.ATTR_LINE_NUMBER_TABLE:
+                return new LineNumberTable(name_index, length, file, constant_pool);
+            case Const.ATTR_LOCAL_VARIABLE_TABLE:
+                return new LocalVariableTable(name_index, length, file, \
constant_pool); +            case Const.ATTR_INNER_CLASSES:
+                return new InnerClasses(name_index, length, file, constant_pool);
+            case Const.ATTR_SYNTHETIC:
+                return new Synthetic(name_index, length, file, constant_pool);
+            case Const.ATTR_DEPRECATED:
+                return new Deprecated(name_index, length, file, constant_pool);
+            case Const.ATTR_PMG:
+                return new PMGClass(name_index, length, file, constant_pool);
+            case Const.ATTR_SIGNATURE:
+                return new Signature(name_index, length, file, constant_pool);
+            case Const.ATTR_STACK_MAP:
+                // old style stack map: unneeded for JDK5 and below;
+                // illegal(?) for JDK6 and above.  So just delete with a warning.
+                println("Warning: Obsolete StackMap attribute ignored.");
+                return new Unknown(name_index, length, file, constant_pool);
+            case Const.ATTR_RUNTIME_VISIBLE_ANNOTATIONS:
+                return new RuntimeVisibleAnnotations(name_index, length, file, \
constant_pool); +            case Const.ATTR_RUNTIME_INVISIBLE_ANNOTATIONS:
+                return new RuntimeInvisibleAnnotations(name_index, length, file, \
constant_pool); +            case Const.ATTR_RUNTIME_VISIBLE_PARAMETER_ANNOTATIONS:
+                return new RuntimeVisibleParameterAnnotations(name_index, length, \
file, constant_pool); +            case \
Const.ATTR_RUNTIME_INVISIBLE_PARAMETER_ANNOTATIONS: +                return new \
RuntimeInvisibleParameterAnnotations(name_index, length, file, constant_pool); +      \
case Const.ATTR_ANNOTATION_DEFAULT: +                return new \
AnnotationDefault(name_index, length, file, constant_pool); +            case \
Const.ATTR_LOCAL_VARIABLE_TYPE_TABLE: +                return new \
LocalVariableTypeTable(name_index, length, file, constant_pool); +            case \
Const.ATTR_ENCLOSING_METHOD: +                return new EnclosingMethod(name_index, \
length, file, constant_pool); +            case Const.ATTR_STACK_MAP_TABLE:
+                // read new style stack map: StackMapTable.  The rest of the code
+                // calls this a StackMap for historical reasons.
+                return new StackMap(name_index, length, file, constant_pool);
+            case Const.ATTR_BOOTSTRAP_METHODS:
+                return new BootstrapMethods(name_index, length, file, \
constant_pool); +            case Const.ATTR_METHOD_PARAMETERS:
+                return new MethodParameters(name_index, length, file, \
constant_pool); +            case Const.ATTR_MODULE:
+                return new Module(name_index, length, file, constant_pool);
+            case Const.ATTR_MODULE_PACKAGES:
+                return new ModulePackages(name_index, length, file, constant_pool);
+            case Const.ATTR_MODULE_MAIN_CLASS:
+                return new ModuleMainClass(name_index, length, file, constant_pool);
+            case Const.ATTR_NEST_HOST:
+                return new NestHost(name_index, length, file, constant_pool);
+            case Const.ATTR_NEST_MEMBERS:
+                return new NestMembers(name_index, length, file, constant_pool);
+            default:
+                // Never reached
+                throw new IllegalStateException("Unrecognized attribute type tag \
parsed: " + tag); +        }
+    }
+
+    /**
+     * Class method reads one attribute from the input data stream. This method
+     * must not be accessible from the outside. It is called by the Field and
+     * Method constructor methods.
+     *
+     * @see Field
+     * @see Method
+     *
+     * @param file Input stream
+     * @param constant_pool Array of constants
+     * @return Attribute
+     * @throws IOException
+     * @throws ClassFormatException
+     */
+    public static Attribute readAttribute(final DataInputStream file, final \
ConstantPool constant_pool) +            throws IOException, ClassFormatException
+    {
+        return readAttribute((DataInput) file, constant_pool);
+    }
+
+    /**
+     * Remove attribute reader
+     *
+     * @param name the name of the attribute as stored in the class file
+     */
+    public static void removeAttributeReader(final String name)
+    {
+        readers.remove(name);
+    }
+
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected int name_index; // Points to attribute name in constant pool TODO make \
private (has getter & setter) +
+    /**
+     * @deprecated (since 6.0) (since 6.0) will be made private; do not access \
directly, use getter/setter +     */
+    @java.lang.Deprecated
+    protected int length; // Content length of attribute field TODO make private \
(has getter & setter) +
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected byte tag; // Tag to distinguish subclasses TODO make private & final; \
supposed to be immutable +
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected ConstantPool constant_pool; // TODO make private (has getter & setter)
+
+    protected Attribute(final byte tag, final int name_index, final int length, \
final ConstantPool constant_pool) +    {
+        this.tag = tag;
+        this.name_index = name_index;
+        this.length = length;
+        this.constant_pool = constant_pool;
+    }
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v
+     *            Visitor object
+     */
+    @Override
+    public abstract void accept(Visitor v);
+
+    /**
+     * Use copy() if you want to have a deep copy(), i.e., with all references
+     * copied correctly.
+     *
+     * @return shallow copy of this attribute
+     */
+    @Override
+    public Object clone()
+    {
+        Attribute attr = null;
+        try
+        {
+            attr = (Attribute) super.clone();
+        }
+        catch (final CloneNotSupportedException e)
+        {
+            throw new Error("Clone Not Supported"); // never happens
+        }
+        return attr;
+    }
+
+    /**
+     * @return deep copy of this attribute
+     */
+    public abstract Attribute copy(ConstantPool _constant_pool);
+
+    /**
+     * Dump attribute to file stream in binary format.
+     *
+     * @param file
+     *            Output file stream
+     * @throws IOException
+     */
+    public void dump(final DataOutputStream file) throws IOException
+    {
+        file.writeShort(name_index);
+        file.writeInt(length);
+    }
+
+    /**
+     * @return Constant pool used by this object.
+     * @see ConstantPool
+     */
+    public final ConstantPool getConstantPool()
+    {
+        return constant_pool;
+    }
+
+    /**
+     * @return Length of attribute field in bytes.
+     */
+    public final int getLength()
+    {
+        return length;
+    }
+
+    /**
+     * @return Name of attribute
+     * @since 6.0
+     */
+    public String getName()
+    {
+        final ConstantUtf8 c = (ConstantUtf8) constant_pool.getConstant(name_index, \
Const.CONSTANT_Utf8); +        return c.getBytes();
+    }
+
+    /**
+     * @return Name index in constant pool of attribute name.
+     */
+    public final int getNameIndex()
+    {
+        return name_index;
+    }
+
+    /**
+     * @return Tag of attribute, i.e., its type. Value may not be altered, thus \
there is no setTag() method. +     */
+    public final byte getTag()
+    {
+        return tag;
+    }
+
+    /**
+     * @param constant_pool Constant pool to be used for this object.
+     * @see ConstantPool
+     */
+    public final void setConstantPool(final ConstantPool constant_pool)
+    {
+        this.constant_pool = constant_pool;
+    }
+
+    /**
+     * @param length length in bytes.
+     */
+    public final void setLength(final int length)
+    {
+        this.length = length;
+    }
+
+    /**
+     * @param name_index of attribute.
+     */
+    public final void setNameIndex(final int name_index)
+    {
+        this.name_index = name_index;
+    }
+
+    /**
+     * @return attribute name.
+     */
+    @Override
+    public String toString()
+    {
+        return Const.getAttributeName(tag);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/AttributeReader.java \
b/src/org/apache/bcel/classfile/AttributeReader.java new file mode 100644
index 00000000..4993aaa6
--- /dev/null
+++ b/src/org/apache/bcel/classfile/AttributeReader.java
@@ -0,0 +1,59 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+/**
+ * Unknown (non-standard) attributes may be read via user-defined factory
+ * objects that can be registered with the Attribute.addAttributeReader
+ * method. These factory objects should implement this interface.
+
+ * @see Attribute
+ *
+ * @deprecated Use UnknownAttributeReader instead
+ */
+@java.lang.Deprecated
+public interface AttributeReader {
+
+    /**
+     When this attribute reader is added via the static method
+     Attribute.addAttributeReader, an attribute name is associated with it.
+     As the class file parser parses attributes, it will call various
+     AttributeReaders based on the name of the attributes it is
+     constructing.
+
+     @param name_index An index into the constant pool, indexing a
+     ConstantUtf8 that represents the name of the attribute.
+
+     @param length The length of the data contained in the attribute.  This
+     is written into the constant pool and should agree with what the
+     factory expects the length to be.
+
+     @param file This is the data input stream that the factory needs to read
+     its data from.
+
+     @param constant_pool This is the constant pool associated with the
+     Attribute that we are constructing.
+
+     @return The user-defined AttributeReader should take this data and use
+     it to construct an attribute.  In the case of errors, a null can be
+     returned which will cause the parsing of the class file to fail.
+
+     @see Attribute#addAttributeReader( String, AttributeReader )
+     */
+    Attribute createAttribute( int name_index, int length, java.io.DataInputStream \
file, ConstantPool constant_pool ); +}
diff --git a/src/org/apache/bcel/classfile/BootstrapMethod.java \
b/src/org/apache/bcel/classfile/BootstrapMethod.java new file mode 100644
index 00000000..0835a659
--- /dev/null
+++ b/src/org/apache/bcel/classfile/BootstrapMethod.java
@@ -0,0 +1,169 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+import java.util.Arrays;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents a bootstrap method attribute, i.e., the bootstrap
+ * method ref, the number of bootstrap arguments and an array of the
+ * bootstrap arguments.
+ *
+ * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.23">
 + * The class File Format : The BootstrapMethods Attribute</a>
+ * @since 6.0
+ */
+public class BootstrapMethod implements Cloneable {
+
+    /** Index of the CONSTANT_MethodHandle_info structure in the constant_pool table \
*/ +    private int bootstrapMethodRef;
+
+    /** Array of references to the constant_pool table */
+    private int[] bootstrapArguments;
+
+
+    /**
+     * Initialize from another object.
+     */
+    public BootstrapMethod(final BootstrapMethod c) {
+        this(c.getBootstrapMethodRef(), c.getBootstrapArguments());
+    }
+
+    /**
+     * Construct object from input stream.
+     *
+     * @param input Input stream
+     * @throws IOException
+     */
+    BootstrapMethod(final DataInput input) throws IOException {
+        this(input.readUnsignedShort(), input.readUnsignedShort());
+
+        for (int i = 0; i < bootstrapArguments.length; i++) {
+            bootstrapArguments[i] = input.readUnsignedShort();
+        }
+    }
+
+    // helper method
+    private BootstrapMethod(final int bootstrap_method_ref, final int \
num_bootstrap_arguments) { +        this(bootstrap_method_ref, new \
int[num_bootstrap_arguments]); +    }
+
+    /**
+     * @param bootstrapMethodRef int index into constant_pool of \
CONSTANT_MethodHandle +     * @param bootstrapArguments int[] indices into \
constant_pool of CONSTANT_[type]_info +     */
+    public BootstrapMethod(final int bootstrapMethodRef, final int[] \
bootstrapArguments) { +        this.bootstrapMethodRef = bootstrapMethodRef;
+        this.bootstrapArguments = bootstrapArguments;
+    }
+
+    /**
+     * @return index into constant_pool of bootstrap_method
+     */
+    public int getBootstrapMethodRef() {
+        return bootstrapMethodRef;
+    }
+
+    /**
+     * @param bootstrapMethodRef int index into constant_pool of \
CONSTANT_MethodHandle +     */
+    public void setBootstrapMethodRef(final int bootstrapMethodRef) {
+        this.bootstrapMethodRef = bootstrapMethodRef;
+    }
+
+    /**
+     * @return int[] of bootstrap_method indices into constant_pool of \
CONSTANT_[type]_info +     */
+    public int[] getBootstrapArguments() {
+        return bootstrapArguments;
+    }
+
+    /**
+     * @return count of number of boostrap arguments
+     */
+    public int getNumBootstrapArguments() {
+        return bootstrapArguments.length;
+    }
+
+    /**
+     * @param bootstrapArguments int[] indices into constant_pool of \
CONSTANT_[type]_info +     */
+    public void setBootstrapArguments(final int[] bootstrapArguments) {
+        this.bootstrapArguments = bootstrapArguments;
+    }
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public final String toString() {
+        return "BootstrapMethod(" + bootstrapMethodRef + ", " + \
bootstrapArguments.length + ", " +               + \
Arrays.toString(bootstrapArguments) + ")"; +    }
+
+    /**
+     * @return Resolved string representation
+     */
+    public final String toString( final ConstantPool constantPool ) {
+        final StringBuilder buf = new StringBuilder();
+        String bootstrap_method_name;
+        bootstrap_method_name = constantPool.constantToString(bootstrapMethodRef,
+                Const.CONSTANT_MethodHandle);
+        buf.append(Utility.compactClassName(bootstrap_method_name, false));
+        final int num_bootstrap_arguments = bootstrapArguments.length;
+        if (num_bootstrap_arguments > 0) {
+            buf.append("\nMethod Arguments:");
+            for (int i = 0; i < num_bootstrap_arguments; i++) {
+                buf.append("\n  ").append(i).append(": ");
+                buf.append(constantPool.constantToString(constantPool.getConstant(bootstrapArguments[i])));
 +            }
+        }
+        return buf.toString();
+    }
+
+    /**
+     * Dump object to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    public final void dump(final DataOutputStream file) throws IOException {
+        file.writeShort(bootstrapMethodRef);
+        file.writeShort(bootstrapArguments.length);
+        for (final int bootstrap_argument : bootstrapArguments) {
+            file.writeShort(bootstrap_argument);
+        }
+    }
+
+    /**
+     * @return deep copy of this object
+     */
+    public BootstrapMethod copy() {
+        try {
+            return (BootstrapMethod) clone();
+        } catch (final CloneNotSupportedException e) {
+            // TODO should this throw?
+        }
+        return null;
+    }
+}
diff --git a/src/org/apache/bcel/classfile/BootstrapMethods.java \
b/src/org/apache/bcel/classfile/BootstrapMethods.java new file mode 100644
index 00000000..3abe716b
--- /dev/null
+++ b/src/org/apache/bcel/classfile/BootstrapMethods.java
@@ -0,0 +1,151 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents a BootstrapMethods attribute.
+ *
+ * @see <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.7.23">
 + * The class File Format : The BootstrapMethods Attribute</a>
+ * @since 6.0
+ */
+public class BootstrapMethods extends Attribute {
+
+    private BootstrapMethod[] bootstrapMethods;  // TODO this could be made final \
(setter is not used) +
+    /**
+     * Initialize from another object. Note that both objects use the same
+     * references (shallow copy). Use clone() for a physical copy.
+     */
+    public BootstrapMethods(final BootstrapMethods c) {
+        this(c.getNameIndex(), c.getLength(), c.getBootstrapMethods(), \
c.getConstantPool()); +    }
+
+
+    /**
+     * @param name_index Index in constant pool to CONSTANT_Utf8
+     * @param length Content length in bytes
+     * @param bootstrapMethods array of bootstrap methods
+     * @param constant_pool Array of constants
+     */
+    public BootstrapMethods(final int name_index, final int length, final \
BootstrapMethod[] bootstrapMethods, final ConstantPool constant_pool) { +        \
super(Const.ATTR_BOOTSTRAP_METHODS, name_index, length, constant_pool); +        \
this.bootstrapMethods = bootstrapMethods; +    }
+
+    /**
+     * Construct object from Input stream.
+     *
+     * @param name_index Index in constant pool to CONSTANT_Utf8
+     * @param length Content length in bytes
+     * @param input Input stream
+     * @param constant_pool Array of constants
+     * @throws IOException
+     */
+    BootstrapMethods(final int name_index, final int length, final DataInput input, \
final ConstantPool constant_pool) throws IOException { +        this(name_index, \
length, (BootstrapMethod[]) null, constant_pool); +
+        final int num_bootstrap_methods = input.readUnsignedShort();
+        bootstrapMethods = new BootstrapMethod[num_bootstrap_methods];
+        for (int i = 0; i < num_bootstrap_methods; i++) {
+            bootstrapMethods[i] = new BootstrapMethod(input);
+        }
+    }
+
+    /**
+     * @return array of bootstrap method "records"
+     */
+    public final BootstrapMethod[] getBootstrapMethods() {
+        return bootstrapMethods;
+    }
+
+    /**
+     * @param bootstrapMethods the array of bootstrap methods
+     */
+    public final void setBootstrapMethods(final BootstrapMethod[] bootstrapMethods) \
{ +        this.bootstrapMethods = bootstrapMethods;
+    }
+
+    /**
+     * @param v Visitor object
+     */
+    @Override
+    public void accept(final Visitor v) {
+        v.visitBootstrapMethods(this);
+    }
+
+    /**
+     * @return deep copy of this attribute
+     */
+    @Override
+    public BootstrapMethods copy(final ConstantPool _constant_pool) {
+        final BootstrapMethods c = (BootstrapMethods) clone();
+        c.bootstrapMethods = new BootstrapMethod[bootstrapMethods.length];
+
+        for (int i = 0; i < bootstrapMethods.length; i++) {
+            c.bootstrapMethods[i] = bootstrapMethods[i].copy();
+        }
+        c.setConstantPool(_constant_pool);
+        return c;
+    }
+
+    /**
+     * Dump bootstrap methods attribute to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public final void dump(final DataOutputStream file) throws IOException {
+        super.dump(file);
+
+        file.writeShort(bootstrapMethods.length);
+        for (final BootstrapMethod bootstrap_method : bootstrapMethods) {
+            bootstrap_method.dump(file);
+        }
+    }
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public final String toString() {
+        final StringBuilder buf = new StringBuilder();
+        buf.append("BootstrapMethods(");
+        buf.append(bootstrapMethods.length);
+        buf.append("):");
+        for (int i = 0; i < bootstrapMethods.length; i++) {
+            buf.append("\n");
+            final int start = buf.length();
+            buf.append("  ").append(i).append(": ");
+            final int indent_count = buf.length() - start;
+            final String[] lines = \
(bootstrapMethods[i].toString(super.getConstantPool())).split("\\r?\\n"); +           \
buf.append(lines[0]); +            for (int j = 1; j < lines.length; j++) {
+                buf.append("\n").append("          \
".substring(0,indent_count)).append(lines[j]); +            }
+        }
+        return buf.toString();
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ClassElementValue.java \
b/src/org/apache/bcel/classfile/ClassElementValue.java new file mode 100644
index 00000000..2a62a872
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ClassElementValue.java
@@ -0,0 +1,67 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * @since 6.0
+ */
+public class ClassElementValue extends ElementValue
+{
+    // For primitive types and string type, this points to the value entry in
+    // the cpool
+    // For 'class' this points to the class entry in the cpool
+    private final int idx;
+
+    public ClassElementValue(final int type, final int idx, final ConstantPool \
cpool) +    {
+        super(type, cpool);
+        this.idx = idx;
+    }
+
+    public int getIndex()
+    {
+        return idx;
+    }
+
+    public String getClassString()
+    {
+        final ConstantUtf8 c = (ConstantUtf8) \
super.getConstantPool().getConstant(idx, +                Const.CONSTANT_Utf8);
+        return c.getBytes();
+    }
+
+    @Override
+    public String stringifyValue()
+    {
+        final ConstantUtf8 cu8 = (ConstantUtf8) \
super.getConstantPool().getConstant(idx, +                Const.CONSTANT_Utf8);
+        return cu8.getBytes();
+    }
+
+    @Override
+    public void dump(final DataOutputStream dos) throws IOException
+    {
+        dos.writeByte(super.getType()); // u1 kind of value
+        dos.writeShort(idx);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ClassFormatException.java \
b/src/org/apache/bcel/classfile/ClassFormatException.java new file mode 100644
index 00000000..963cc266
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ClassFormatException.java
@@ -0,0 +1,45 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+/**
+ * Thrown when the BCEL attempts to read a class file and determines
+ * that the file is malformed or otherwise cannot be interpreted as a
+ * class file.
+ *
+ */
+public class ClassFormatException extends RuntimeException {
+
+    private static final long serialVersionUID = -3569097343160139969L;
+
+    public ClassFormatException() {
+        super();
+    }
+
+
+    public ClassFormatException(final String s) {
+        super(s);
+    }
+
+    /**
+     * @since 6.0
+     */
+    public ClassFormatException(final String message, final Throwable cause) {
+        super(message, cause);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ClassParser.java \
b/src/org/apache/bcel/classfile/ClassParser.java new file mode 100644
index 00000000..a592bfed
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ClassParser.java
@@ -0,0 +1,307 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.BufferedInputStream;
+import java.io.DataInputStream;
+import java.io.FileInputStream;
+import java.io.IOException;
+import java.io.InputStream;
+import java.util.zip.ZipEntry;
+import java.util.zip.ZipFile;
+
+import org.apache.bcel.Const;
+
+/**
+ * Wrapper class that parses a given Java .class file. The method <A
+ * href ="#parse">parse</A> returns a <A href ="JavaClass.html">
+ * JavaClass</A> object on success. When an I/O error or an
+ * inconsistency occurs an appropiate exception is propagated back to
+ * the caller.
+ *
+ * The structure and the names comply, except for a few conveniences,
+ * exactly with the <A href="http://docs.oracle.com/javase/specs/">
+ * JVM specification 1.0</a>. See this paper for
+ * further details about the structure of a bytecode file.
+ *
+ */
+public final class ClassParser {
+
+    private DataInputStream dataInputStream;
+    private final boolean fileOwned;
+    private final String fileName;
+    private String zipFile;
+    private int classNameIndex;
+    private int superclassNameIndex;
+    private int major; // Compiler version
+    private int minor; // Compiler version
+    private int accessFlags; // Access rights of parsed class
+    private int[] interfaces; // Names of implemented interfaces
+    private ConstantPool constantPool; // collection of constants
+    private Field[] fields; // class fields, i.e., its variables
+    private Method[] methods; // methods defined in the class
+    private Attribute[] attributes; // attributes defined in the class
+    private final boolean isZip; // Loaded from zip file
+    private static final int BUFSIZE = 8192;
+
+
+    /**
+     * Parses class from the given stream.
+     *
+     * @param inputStream Input stream
+     * @param fileName File name
+     */
+    public ClassParser(final InputStream inputStream, final String fileName) {
+        this.fileName = fileName;
+        fileOwned = false;
+        final String clazz = inputStream.getClass().getName(); // Not a very clean \
solution ... +        isZip = clazz.startsWith("java.util.zip.") || \
clazz.startsWith("java.util.jar."); +        if (inputStream instanceof \
DataInputStream) { +            this.dataInputStream = (DataInputStream) inputStream;
+        } else {
+            this.dataInputStream = new DataInputStream(new \
BufferedInputStream(inputStream, BUFSIZE)); +        }
+    }
+
+
+    /** Parses class from given .class file.
+     *
+     * @param fileName file name
+     */
+    public ClassParser(final String fileName) {
+        isZip = false;
+        this.fileName = fileName;
+        fileOwned = true;
+    }
+
+
+    /** Parses class from given .class file in a ZIP-archive
+     *
+     * @param zipFile zip file name
+     * @param fileName file name
+     */
+    public ClassParser(final String zipFile, final String fileName) {
+        isZip = true;
+        fileOwned = true;
+        this.zipFile = zipFile;
+        this.fileName = fileName;
+    }
+
+
+    /**
+     * Parses the given Java class file and return an object that represents
+     * the contained data, i.e., constants, methods, fields and commands.
+     * A <em>ClassFormatException</em> is raised, if the file is not a valid
+     * .class file. (This does not include verification of the byte code as it
+     * is performed by the java interpreter).
+     *
+     * @return Class object representing the parsed class file
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    public JavaClass parse() throws IOException, ClassFormatException {
+        ZipFile zip = null;
+        try {
+            if (fileOwned) {
+                if (isZip) {
+                    zip = new ZipFile(zipFile);
+                    final ZipEntry entry = zip.getEntry(fileName);
+
+                    if (entry == null) {
+                        throw new IOException("File " + fileName + " not found");
+                    }
+
+                    dataInputStream = new DataInputStream(new \
BufferedInputStream(zip.getInputStream(entry), +                            \
BUFSIZE)); +                } else {
+                    dataInputStream = new DataInputStream(new \
BufferedInputStream(new FileInputStream( +                            fileName), \
BUFSIZE)); +                }
+            }
+            /****************** Read headers ********************************/
+            // Check magic tag of class file
+            readID();
+            // Get compiler version
+            readVersion();
+            /****************** Read constant pool and related **************/
+            // Read constant pool entries
+            readConstantPool();
+            // Get class information
+            readClassInfo();
+            // Get interface information, i.e., implemented interfaces
+            readInterfaces();
+            /****************** Read class fields and methods ***************/
+            // Read class fields, i.e., the variables of the class
+            readFields();
+            // Read class methods, i.e., the functions in the class
+            readMethods();
+            // Read class attributes
+            readAttributes();
+            // Check for unknown variables
+            //Unknown[] u = Unknown.getUnknownAttributes();
+            //for (int i=0; i < u.length; i++)
+            //  System.err.println("WARNING: " + u[i]);
+            // Everything should have been read now
+            //      if(file.available() > 0) {
+            //        int bytes = file.available();
+            //        byte[] buf = new byte[bytes];
+            //        file.read(buf);
+            //        if(!(isZip && (buf.length == 1))) {
+            //      System.err.println("WARNING: Trailing garbage at end of " + \
fileName); +            //      System.err.println(bytes + " extra bytes: " + \
Utility.toHexString(buf)); +            //        }
+            //      }
+        } finally {
+            // Read everything of interest, so close the file
+            if (fileOwned) {
+                try {
+                    if (dataInputStream != null) {
+                        dataInputStream.close();
+                    }
+                } catch (final IOException ioe) {
+                    //ignore close exceptions
+                }
+            }
+            try {
+                if (zip != null) {
+                    zip.close();
+                }
+            } catch (final IOException ioe) {
+                //ignore close exceptions
+            }
+        }
+        // Return the information we have gathered in a new object
+        return new JavaClass(classNameIndex, superclassNameIndex, fileName, major, \
minor, +                accessFlags, constantPool, interfaces, fields, methods, \
attributes, isZip +                        ? JavaClass.ZIP
+                        : JavaClass.FILE);
+    }
+
+
+    /**
+     * Reads information about the attributes of the class.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readAttributes() throws IOException, ClassFormatException {
+        final int attributes_count = dataInputStream.readUnsignedShort();
+        attributes = new Attribute[attributes_count];
+        for (int i = 0; i < attributes_count; i++) {
+            attributes[i] = Attribute.readAttribute(dataInputStream, constantPool);
+        }
+    }
+
+
+    /**
+     * Reads information about the class and its super class.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readClassInfo() throws IOException, ClassFormatException {
+        accessFlags = dataInputStream.readUnsignedShort();
+        /* Interfaces are implicitely abstract, the flag should be set
+         * according to the JVM specification.
+         */
+        if ((accessFlags & Const.ACC_INTERFACE) != 0) {
+            accessFlags |= Const.ACC_ABSTRACT;
+        }
+        if (((accessFlags & Const.ACC_ABSTRACT) != 0)
+                && ((accessFlags & Const.ACC_FINAL) != 0)) {
+            throw new ClassFormatException("Class " + fileName + " can't be both \
final and abstract"); +        }
+        classNameIndex = dataInputStream.readUnsignedShort();
+        superclassNameIndex = dataInputStream.readUnsignedShort();
+    }
+
+
+    /**
+     * Reads constant pool entries.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readConstantPool() throws IOException, ClassFormatException {
+        constantPool = new ConstantPool(dataInputStream);
+    }
+
+
+    /**
+     * Reads information about the fields of the class, i.e., its variables.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readFields() throws IOException, ClassFormatException {
+        final int fields_count = dataInputStream.readUnsignedShort();
+        fields = new Field[fields_count];
+        for (int i = 0; i < fields_count; i++) {
+            fields[i] = new Field(dataInputStream, constantPool);
+        }
+    }
+
+
+    /******************** Private utility methods **********************/
+    /**
+     * Checks whether the header of the file is ok.
+     * Of course, this has to be the first action on successive file reads.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readID() throws IOException, ClassFormatException {
+        if (dataInputStream.readInt() != Const.JVM_CLASSFILE_MAGIC) {
+            throw new ClassFormatException(fileName + " is not a Java .class file");
+        }
+    }
+
+
+    /**
+     * Reads information about the interfaces implemented by this class.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readInterfaces() throws IOException, ClassFormatException {
+        final int interfaces_count = dataInputStream.readUnsignedShort();
+        interfaces = new int[interfaces_count];
+        for (int i = 0; i < interfaces_count; i++) {
+            interfaces[i] = dataInputStream.readUnsignedShort();
+        }
+    }
+
+
+    /**
+     * Reads information about the methods of the class.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readMethods() throws IOException, ClassFormatException {
+        final int methods_count = dataInputStream.readUnsignedShort();
+        methods = new Method[methods_count];
+        for (int i = 0; i < methods_count; i++) {
+            methods[i] = new Method(dataInputStream, constantPool);
+        }
+    }
+
+
+    /**
+     * Reads major and minor version of compiler which created the file.
+     * @throws  IOException
+     * @throws  ClassFormatException
+     */
+    private void readVersion() throws IOException, ClassFormatException {
+        minor = dataInputStream.readUnsignedShort();
+        major = dataInputStream.readUnsignedShort();
+    }
+}
diff --git a/src/org/apache/bcel/classfile/Code.java \
b/src/org/apache/bcel/classfile/Code.java new file mode 100644
index 00000000..5e81d21f
--- /dev/null
+++ b/src/org/apache/bcel/classfile/Code.java
@@ -0,0 +1,355 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents a chunk of Java byte code contained in a
+ * method. It is instantiated by the
+ * <em>Attribute.readAttribute()</em> method. A <em>Code</em>
+ * attribute contains informations about operand stack, local
+ * variables, byte code and the exceptions handled within this
+ * method.
+ *
+ * This attribute has attributes itself, namely <em>LineNumberTable</em> which
+ * is used for debugging purposes and <em>LocalVariableTable</em> which
+ * contains information about the local variables.
+ *
+ * @see     Attribute
+ * @see     CodeException
+ * @see     LineNumberTable
+ * @see LocalVariableTable
+ */
+public final class Code extends Attribute {
+
+    private int maxStack; // Maximum size of stack used by this method  // TODO this \
could be made final (setter is not used) +    private int maxLocals; // Number of \
local variables  // TODO this could be made final (setter is not used) +    private \
byte[] code; // Actual byte code +    private CodeException[] exceptionTable; // \
Table of handled exceptions +    private Attribute[] attributes; // or LocalVariable
+
+
+    /**
+     * Initialize from another object. Note that both objects use the same
+     * references (shallow copy). Use copy() for a physical copy.
+     */
+    public Code(final Code c) {
+        this(c.getNameIndex(), c.getLength(), c.getMaxStack(), c.getMaxLocals(), \
c.getCode(), c +                .getExceptionTable(), c.getAttributes(), \
c.getConstantPool()); +    }
+
+
+    /**
+     * @param name_index Index pointing to the name <em>Code</em>
+     * @param length Content length in bytes
+     * @param file Input stream
+     * @param constant_pool Array of constants
+     */
+    Code(final int name_index, final int length, final DataInput file, final \
ConstantPool constant_pool) +            throws IOException {
+        // Initialize with some default values which will be overwritten later
+        this(name_index, length, file.readUnsignedShort(), file.readUnsignedShort(), \
(byte[]) null, +                (CodeException[]) null, (Attribute[]) null, \
constant_pool); +        final int code_length = file.readInt();
+        code = new byte[code_length]; // Read byte code
+        file.readFully(code);
+        /* Read exception table that contains all regions where an exception
+         * handler is active, i.e., a try { ... } catch() block.
+         */
+        final int exception_table_length = file.readUnsignedShort();
+        exceptionTable = new CodeException[exception_table_length];
+        for (int i = 0; i < exception_table_length; i++) {
+            exceptionTable[i] = new CodeException(file);
+        }
+        /* Read all attributes, currently `LineNumberTable' and
+         * `LocalVariableTable'
+         */
+        final int attributes_count = file.readUnsignedShort();
+        attributes = new Attribute[attributes_count];
+        for (int i = 0; i < attributes_count; i++) {
+            attributes[i] = Attribute.readAttribute(file, constant_pool);
+        }
+        /* Adjust length, because of setAttributes in this(), s.b.  length
+         * is incorrect, because it didn't take the internal attributes
+         * into account yet! Very subtle bug, fixed in 3.1.1.
+         */
+        super.setLength(length);
+    }
+
+
+    /**
+     * @param name_index Index pointing to the name <em>Code</em>
+     * @param length Content length in bytes
+     * @param maxStack Maximum size of stack
+     * @param maxLocals Number of local variables
+     * @param code Actual byte code
+     * @param exceptionTable of handled exceptions
+     * @param attributes Attributes of code: LineNumber or LocalVariable
+     * @param constant_pool Array of constants
+     */
+    public Code(final int name_index, final int length, final int maxStack, final \
int maxLocals, final byte[] code, +            final CodeException[] exceptionTable, \
final Attribute[] attributes, final ConstantPool constant_pool) { +        \
super(Const.ATTR_CODE, name_index, length, constant_pool); +        this.maxStack = \
maxStack; +        this.maxLocals = maxLocals;
+        this.code = code != null ? code : new byte[0];
+        this.exceptionTable = exceptionTable != null ? exceptionTable : new \
CodeException[0]; +        this.attributes = attributes != null ? attributes : new \
Attribute[0]; +        super.setLength(calculateLength()); // Adjust length
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitCode(this);
+    }
+
+
+    /**
+     * Dump code attribute to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        super.dump(file);
+        file.writeShort(maxStack);
+        file.writeShort(maxLocals);
+        file.writeInt(code.length);
+        file.write(code, 0, code.length);
+        file.writeShort(exceptionTable.length);
+        for (final CodeException exception : exceptionTable) {
+            exception.dump(file);
+        }
+        file.writeShort(attributes.length);
+        for (final Attribute attribute : attributes) {
+            attribute.dump(file);
+        }
+    }
+
+
+    /**
+     * @return Collection of code attributes.
+     * @see Attribute
+     */
+    public Attribute[] getAttributes() {
+        return attributes;
+    }
+
+
+    /**
+     * @return LineNumberTable of Code, if it has one
+     */
+    public LineNumberTable getLineNumberTable() {
+        for (final Attribute attribute : attributes) {
+            if (attribute instanceof LineNumberTable) {
+                return (LineNumberTable) attribute;
+            }
+        }
+        return null;
+    }
+
+
+    /**
+     * @return LocalVariableTable of Code, if it has one
+     */
+    public LocalVariableTable getLocalVariableTable() {
+        for (final Attribute attribute : attributes) {
+            if (attribute instanceof LocalVariableTable) {
+                return (LocalVariableTable) attribute;
+            }
+        }
+        return null;
+    }
+
+
+    /**
+     * @return Actual byte code of the method.
+     */
+    public byte[] getCode() {
+        return code;
+    }
+
+
+    /**
+     * @return Table of handled exceptions.
+     * @see CodeException
+     */
+    public CodeException[] getExceptionTable() {
+        return exceptionTable;
+    }
+
+
+    /**
+     * @return Number of local variables.
+     */
+    public int getMaxLocals() {
+        return maxLocals;
+    }
+
+
+    /**
+     * @return Maximum size of stack used by this method.
+     */
+    public int getMaxStack() {
+        return maxStack;
+    }
+
+
+    /**
+     * @return the internal length of this code attribute (minus the first 6 bytes)
+     * and excluding all its attributes
+     */
+    private int getInternalLength() {
+        return 2 /*maxStack*/+ 2 /*maxLocals*/+ 4 /*code length*/
+                + code.length /*byte-code*/
+                + 2 /*exception-table length*/
+                + 8 * (exceptionTable == null ? 0 : exceptionTable.length) /* \
exception table */ +                + 2 /* attributes count */;
+    }
+
+
+    /**
+     * @return the full size of this code attribute, minus its first 6 bytes,
+     * including the size of all its contained attributes
+     */
+    private int calculateLength() {
+        int len = 0;
+        if (attributes != null) {
+            for (final Attribute attribute : attributes) {
+                len += attribute.getLength() + 6 /*attribute header size*/;
+            }
+        }
+        return len + getInternalLength();
+    }
+
+
+    /**
+     * @param attributes the attributes to set for this Code
+     */
+    public void setAttributes( final Attribute[] attributes ) {
+        this.attributes = attributes != null ? attributes : new Attribute[0];
+        super.setLength(calculateLength()); // Adjust length
+    }
+
+
+    /**
+     * @param code byte code
+     */
+    public void setCode( final byte[] code ) {
+        this.code = code != null ? code : new byte[0];
+        super.setLength(calculateLength()); // Adjust length
+    }
+
+
+    /**
+     * @param exceptionTable exception table
+     */
+    public void setExceptionTable( final CodeException[] exceptionTable ) {
+        this.exceptionTable = exceptionTable != null ? exceptionTable : new \
CodeException[0]; +        super.setLength(calculateLength()); // Adjust length
+    }
+
+
+    /**
+     * @param maxLocals maximum number of local variables
+     */
+    public void setMaxLocals( final int maxLocals ) {
+        this.maxLocals = maxLocals;
+    }
+
+
+    /**
+     * @param maxStack maximum stack size
+     */
+    public void setMaxStack( final int maxStack ) {
+        this.maxStack = maxStack;
+    }
+
+
+    /**
+     * @return String representation of code chunk.
+     */
+    public String toString( final boolean verbose ) {
+        final StringBuilder buf = new StringBuilder(100); // CHECKSTYLE IGNORE \
MagicNumber +        buf.append("Code(maxStack = ").append(maxStack).append(", \
maxLocals = ").append( +                maxLocals).append(", code_length = \
").append(code.length).append(")\n").append( +                \
Utility.codeToString(code, super.getConstantPool(), 0, -1, verbose)); +        if \
(exceptionTable.length > 0) { +            buf.append("\nException handler(s) = \
\n").append("From\tTo\tHandler\tType\n"); +            for (final CodeException \
exception : exceptionTable) { +                \
buf.append(exception.toString(super.getConstantPool(), verbose)).append("\n"); +      \
} +        }
+        if (attributes.length > 0) {
+            buf.append("\nAttribute(s) = ");
+            for (final Attribute attribute : attributes) {
+                buf.append("\n").append(attribute.getName()).append(":");
+                buf.append("\n").append(attribute);
+            }
+        }
+        return buf.toString();
+    }
+
+
+    /**
+     * @return String representation of code chunk.
+     */
+    @Override
+    public String toString() {
+        return toString(true);
+    }
+
+
+    /**
+     * @return deep copy of this attribute
+     *
+     * @param _constant_pool the constant pool to duplicate
+     */
+    @Override
+    public Attribute copy( final ConstantPool _constant_pool ) {
+        final Code c = (Code) clone();
+        if (code != null) {
+            c.code = new byte[code.length];
+            System.arraycopy(code, 0, c.code, 0, code.length);
+        }
+        c.setConstantPool(_constant_pool);
+        c.exceptionTable = new CodeException[exceptionTable.length];
+        for (int i = 0; i < exceptionTable.length; i++) {
+            c.exceptionTable[i] = exceptionTable[i].copy();
+        }
+        c.attributes = new Attribute[attributes.length];
+        for (int i = 0; i < attributes.length; i++) {
+            c.attributes[i] = attributes[i].copy(_constant_pool);
+        }
+        return c;
+    }
+}
diff --git a/src/org/apache/bcel/classfile/CodeException.java \
b/src/org/apache/bcel/classfile/CodeException.java new file mode 100644
index 00000000..d223f08e
--- /dev/null
+++ b/src/org/apache/bcel/classfile/CodeException.java
@@ -0,0 +1,217 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+import org.apache.bcel.Constants;
+
+/**
+ * This class represents an entry in the exception table of the <em>Code</em>
+ * attribute and is used only there. It contains a range in which a
+ * particular exception handler is active.
+ *
+ * @see     Code
+ */
+public final class CodeException implements Cloneable, Node, Constants {
+
+    private int startPc; // Range in the code the exception handler is
+    private int endPc; // active. startPc is inclusive, endPc exclusive
+    private int handlerPc; /* Starting address of exception handler, i.e.,
+     * an offset from start of code.
+     */
+    private int catchType; /* If this is zero the handler catches any
+     * exception, otherwise it points to the
+     * exception class which is to be caught.
+     */
+
+
+    /**
+     * Initialize from another object.
+     */
+    public CodeException(final CodeException c) {
+        this(c.getStartPC(), c.getEndPC(), c.getHandlerPC(), c.getCatchType());
+    }
+
+
+    /**
+     * Construct object from file stream.
+     * @param file Input stream
+     * @throws IOException
+     */
+    CodeException(final DataInput file) throws IOException {
+        this(file.readUnsignedShort(), file.readUnsignedShort(), \
file.readUnsignedShort(), file +                .readUnsignedShort());
+    }
+
+
+    /**
+     * @param startPc Range in the code the exception handler is active,
+     * startPc is inclusive while
+     * @param endPc is exclusive
+     * @param handlerPc Starting address of exception handler, i.e.,
+     * an offset from start of code.
+     * @param catchType If zero the handler catches any
+     * exception, otherwise it points to the exception class which is
+     * to be caught.
+     */
+    public CodeException(final int startPc, final int endPc, final int handlerPc, \
final int catchType) { +        this.startPc = startPc;
+        this.endPc = endPc;
+        this.handlerPc = handlerPc;
+        this.catchType = catchType;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitCodeException(this);
+    }
+
+
+    /**
+     * Dump code exception to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeShort(startPc);
+        file.writeShort(endPc);
+        file.writeShort(handlerPc);
+        file.writeShort(catchType);
+    }
+
+
+    /**
+     * @return 0, if the handler catches any exception, otherwise it points to
+     * the exception class which is to be caught.
+     */
+    public int getCatchType() {
+        return catchType;
+    }
+
+
+    /**
+     * @return Exclusive end index of the region where the handler is active.
+     */
+    public int getEndPC() {
+        return endPc;
+    }
+
+
+    /**
+     * @return Starting address of exception handler, relative to the code.
+     */
+    public int getHandlerPC() {
+        return handlerPc;
+    }
+
+
+    /**
+     * @return Inclusive start index of the region where the handler is active.
+     */
+    public int getStartPC() {
+        return startPc;
+    }
+
+
+    /**
+     * @param catchType the type of exception that is caught
+     */
+    public void setCatchType( final int catchType ) {
+        this.catchType = catchType;
+    }
+
+
+    /**
+     * @param endPc end of handled block
+     */
+    public void setEndPC( final int endPc ) {
+        this.endPc = endPc;
+    }
+
+
+    /**
+     * @param handlerPc where the actual code is
+     */
+    public void setHandlerPC( final int handlerPc ) { // TODO unused
+        this.handlerPc = handlerPc;
+    }
+
+
+    /**
+     * @param startPc start of handled block
+     */
+    public void setStartPC( final int startPc ) { // TODO unused
+        this.startPc = startPc;
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return "CodeException(startPc = " + startPc + ", endPc = " + endPc + ", \
handlerPc = " +                + handlerPc + ", catchType = " + catchType + ")";
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    public String toString( final ConstantPool cp, final boolean verbose ) {
+        String str;
+        if (catchType == 0) {
+            str = "<Any exception>(0)";
+        } else {
+            str = Utility.compactClassName(cp.getConstantString(catchType, \
Const.CONSTANT_Class), false) +                    + (verbose ? "(" + catchType + ")" \
: ""); +        }
+        return startPc + "\t" + endPc + "\t" + handlerPc + "\t" + str;
+    }
+
+
+    public String toString( final ConstantPool cp ) {
+        return toString(cp, true);
+    }
+
+
+    /**
+     * @return deep copy of this object
+     */
+    public CodeException copy() {
+        try {
+            return (CodeException) clone();
+        } catch (final CloneNotSupportedException e) {
+            // TODO should this throw?
+        }
+        return null;
+    }
+}
diff --git a/src/org/apache/bcel/classfile/Constant.java \
b/src/org/apache/bcel/classfile/Constant.java new file mode 100644
index 00000000..36061ed2
--- /dev/null
+++ b/src/org/apache/bcel/classfile/Constant.java
@@ -0,0 +1,206 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+import java.util.Objects;
+
+import org.apache.bcel.Const;
+import org.apache.bcel.util.BCELComparator;
+
+/**
+ * Abstract superclass for classes to represent the different constant types
+ * in the constant pool of a class file. The classes keep closely to
+ * the JVM specification.
+ */
+public abstract class Constant implements Cloneable, Node {
+
+    private static BCELComparator bcelComparator = new BCELComparator() {
+
+        @Override
+        public boolean equals( final Object o1, final Object o2 ) {
+            final Constant THIS = (Constant) o1;
+            final Constant THAT = (Constant) o2;
+            return Objects.equals(THIS.toString(), THAT.toString());
+        }
+
+
+        @Override
+        public int hashCode( final Object o ) {
+            final Constant THIS = (Constant) o;
+            return THIS.toString().hashCode();
+        }
+    };
+
+    /* In fact this tag is redundant since we can distinguish different
+     * `Constant' objects by their type, i.e., via `instanceof'. In some
+     * places we will use the tag for switch()es anyway.
+     *
+     * First, we want match the specification as closely as possible. Second we
+     * need the tag as an index to select the corresponding class name from the
+     * `CONSTANT_NAMES' array.
+     */
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected byte tag; // TODO should be private & final
+
+    Constant(final byte tag) {
+        this.tag = tag;
+    }
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public abstract void accept( Visitor v );
+
+    public abstract void dump( DataOutputStream file ) throws IOException;
+
+    /**
+     * @return Tag of constant, i.e., its type. No setTag() method to avoid
+     * confusion.
+     */
+    public final byte getTag() {
+        return tag;
+    }
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return Const.getConstantName(tag) + "[" + tag + "]";
+    }
+
+    /**
+     * @return deep copy of this constant
+     */
+    public Constant copy() {
+        try {
+            return (Constant) super.clone();
+        } catch (final CloneNotSupportedException e) {
+            // TODO should this throw?
+        }
+        return null;
+    }
+
+    @Override
+    public Object clone() {
+        try {
+            return super.clone();
+        } catch (final CloneNotSupportedException e) {
+            throw new Error("Clone Not Supported"); // never happens
+        }
+    }
+
+    /**
+     * Reads one constant from the given input, the type depends on a tag byte.
+     *
+     * @param dataInput Input stream
+     * @return Constant object
+     * @throws IOException if an I/O error occurs reading from the given {@code \
dataInput}. +     * @throws ClassFormatException if the next byte is not recognized
+     * @since 6.0 made public
+     */
+    public static Constant readConstant(final DataInput dataInput) throws \
IOException, ClassFormatException { +        final byte b = dataInput.readByte(); // \
Read tag byte +        switch (b) {
+        case Const.CONSTANT_Class:
+            return new ConstantClass(dataInput);
+        case Const.CONSTANT_Fieldref:
+            return new ConstantFieldref(dataInput);
+        case Const.CONSTANT_Methodref:
+            return new ConstantMethodref(dataInput);
+        case Const.CONSTANT_InterfaceMethodref:
+            return new ConstantInterfaceMethodref(dataInput);
+        case Const.CONSTANT_String:
+            return new ConstantString(dataInput);
+        case Const.CONSTANT_Integer:
+            return new ConstantInteger(dataInput);
+        case Const.CONSTANT_Float:
+            return new ConstantFloat(dataInput);
+        case Const.CONSTANT_Long:
+            return new ConstantLong(dataInput);
+        case Const.CONSTANT_Double:
+            return new ConstantDouble(dataInput);
+        case Const.CONSTANT_NameAndType:
+            return new ConstantNameAndType(dataInput);
+        case Const.CONSTANT_Utf8:
+            return ConstantUtf8.getInstance(dataInput);
+        case Const.CONSTANT_MethodHandle:
+            return new ConstantMethodHandle(dataInput);
+        case Const.CONSTANT_MethodType:
+            return new ConstantMethodType(dataInput);
+        case Const.CONSTANT_Dynamic:
+            return new ConstantDynamic(dataInput);
+        case Const.CONSTANT_InvokeDynamic:
+            return new ConstantInvokeDynamic(dataInput);
+        case Const.CONSTANT_Module:
+            return new ConstantModule(dataInput);
+        case Const.CONSTANT_Package:
+            return new ConstantPackage(dataInput);
+        default:
+            throw new ClassFormatException("Invalid byte tag in constant pool: " + \
b); +        }
+    }
+
+    /**
+     * @return Comparison strategy object
+     */
+    public static BCELComparator getComparator() {
+        return bcelComparator;
+    }
+
+    /**
+     * @param comparator Comparison strategy object
+     */
+    public static void setComparator( final BCELComparator comparator ) {
+        bcelComparator = comparator;
+    }
+
+    /**
+     * Returns value as defined by given BCELComparator strategy.
+     * By default two Constant objects are said to be equal when
+     * the result of toString() is equal.
+     *
+     * @see java.lang.Object#equals(java.lang.Object)
+     */
+    @Override
+    public boolean equals( final Object obj ) {
+        return bcelComparator.equals(this, obj);
+    }
+
+    /**
+     * Returns value as defined by given BCELComparator strategy.
+     * By default return the hashcode of the result of toString().
+     *
+     * @see java.lang.Object#hashCode()
+     */
+    @Override
+    public int hashCode() {
+        return bcelComparator.hashCode(this);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantCP.java \
b/src/org/apache/bcel/classfile/ConstantCP.java new file mode 100644
index 00000000..73e675c7
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantCP.java
@@ -0,0 +1,150 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * Abstract super class for Fieldref, Methodref, InterfaceMethodref and
+ *                          InvokeDynamic constants.
+ *
+ * @see     ConstantFieldref
+ * @see     ConstantMethodref
+ * @see     ConstantInterfaceMethodref
+ * @see     ConstantInvokeDynamic
+ */
+public abstract class ConstantCP extends Constant {
+
+    /** References to the constants containing the class and the field signature
+     */
+    // Note that this field is used to store the
+    // bootstrap_method_attr_index of a ConstantInvokeDynamic.
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected int class_index; // TODO make private (has getter & setter)
+    // This field has the same meaning for all subclasses.
+
+    /**
+     * @deprecated (since 6.0) will be made private; do not access directly, use \
getter/setter +     */
+    @java.lang.Deprecated
+    protected int name_and_type_index; // TODO make private (has getter & setter)
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantCP(final ConstantCP c) {
+        this(c.getTag(), c.getClassIndex(), c.getNameAndTypeIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param tag  Constant type tag
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantCP(final byte tag, final DataInput file) throws IOException {
+        this(tag, file.readUnsignedShort(), file.readUnsignedShort());
+    }
+
+
+    /**
+     * @param class_index Reference to the class containing the field
+     * @param name_and_type_index and the field signature
+     */
+    protected ConstantCP(final byte tag, final int class_index, final int \
name_and_type_index) { +        super(tag);
+        this.class_index = class_index;
+        this.name_and_type_index = name_and_type_index;
+    }
+
+
+    /**
+     * Dump constant field reference to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public final void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeShort(class_index);
+        file.writeShort(name_and_type_index);
+    }
+
+
+    /**
+     * @return Reference (index) to class this constant refers to.
+     */
+    public final int getClassIndex() {
+        return class_index;
+    }
+
+
+    /**
+     * @param class_index points to Constant_class
+     */
+    public final void setClassIndex( final int class_index ) {
+        this.class_index = class_index;
+    }
+
+
+    /**
+     * @return Reference (index) to signature of the field.
+     */
+    public final int getNameAndTypeIndex() {
+        return name_and_type_index;
+    }
+
+
+    /**
+     * @param name_and_type_index points to Constant_NameAndType
+     */
+    public final void setNameAndTypeIndex( final int name_and_type_index ) {
+        this.name_and_type_index = name_and_type_index;
+    }
+
+
+    /**
+     * @return Class this field belongs to.
+     */
+    public String getClass( final ConstantPool cp ) {
+        return cp.constantToString(class_index, Const.CONSTANT_Class);
+    }
+
+
+    /**
+     * @return String representation.
+     *
+     * not final as ConstantInvokeDynamic needs to modify
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(class_index = " + class_index + ", \
name_and_type_index = " +                + name_and_type_index + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantClass.java \
b/src/org/apache/bcel/classfile/ConstantClass.java new file mode 100644
index 00000000..f77ecc3d
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantClass.java
@@ -0,0 +1,131 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a (external) class.
+ *
+ * @see     Constant
+ */
+public final class ConstantClass extends Constant implements ConstantObject {
+
+    private int nameIndex; // Identical to ConstantString except for the name
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantClass(final ConstantClass c) {
+        this(c.getNameIndex());
+    }
+
+
+    /**
+     * Constructs an instance from file data.
+     *
+     * @param dataInput Input stream
+     * @throws IOException if an I/O error occurs reading from the given {@code \
dataInput}. +     */
+    ConstantClass(final DataInput dataInput) throws IOException {
+        this(dataInput.readUnsignedShort());
+    }
+
+
+    /**
+     * @param nameIndex Name index in constant pool.  Should refer to a
+     * ConstantUtf8.
+     */
+    public ConstantClass(final int nameIndex) {
+        super(Const.CONSTANT_Class);
+        this.nameIndex = nameIndex;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantClass(this);
+    }
+
+
+    /**
+     * Dumps constant class to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException if an I/O error occurs writing to the DataOutputStream.
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeShort(nameIndex);
+    }
+
+
+    /**
+     * @return Name index in constant pool of class name.
+     */
+    public int getNameIndex() {
+        return nameIndex;
+    }
+
+
+    /**
+     * @param nameIndex the name index in the constant pool of this Constant Class
+     */
+    public void setNameIndex( final int nameIndex ) {
+        this.nameIndex = nameIndex;
+    }
+
+
+    /** @return String object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        final Constant c = cp.getConstant(nameIndex, Const.CONSTANT_Utf8);
+        return ((ConstantUtf8) c).getBytes();
+    }
+
+
+    /** @return dereferenced string
+     */
+    public String getBytes( final ConstantPool cp ) {
+        return (String) getConstantValue(cp);
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(nameIndex = " + nameIndex + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantDouble.java \
b/src/org/apache/bcel/classfile/ConstantDouble.java new file mode 100644
index 00000000..9ef7ce68
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantDouble.java
@@ -0,0 +1,122 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract  {@link Constant}
+ * and represents a reference to a Double object.
+ *
+ * @see     Constant
+ */
+public final class ConstantDouble extends Constant implements ConstantObject {
+
+    private double bytes;
+
+
+    /**
+     * @param bytes Data
+     */
+    public ConstantDouble(final double bytes) {
+        super(Const.CONSTANT_Double);
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantDouble(final ConstantDouble c) {
+        this(c.getBytes());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantDouble(final DataInput file) throws IOException {
+        this(file.readDouble());
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantDouble(this);
+    }
+
+
+    /**
+     * Dump constant double to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeDouble(bytes);
+    }
+
+
+    /**
+     * @return data, i.e., 8 bytes.
+     */
+    public double getBytes() {
+        return bytes;
+    }
+
+
+    /**
+     * @param bytes the raw bytes that represent the double value
+     */
+    public void setBytes( final double bytes ) {
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(bytes = " + bytes + ")";
+    }
+
+
+    /** @return Double object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        return new Double(bytes);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantDynamic.java \
b/src/org/apache/bcel/classfile/ConstantDynamic.java new file mode 100644
index 00000000..b76db6dc
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantDynamic.java
@@ -0,0 +1,90 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a dynamically computed constant.
+ *
+ * @see     Constant
+ * @see  <a href="https://bugs.openjdk.java.net/secure/attachment/74618/constant-dynamic.html">
 + * Change request for JEP 309</a>
+ * @since 6.3
+ */
+public final class ConstantDynamic extends ConstantCP {
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantDynamic(final ConstantDynamic c) {
+        this(c.getBootstrapMethodAttrIndex(), c.getNameAndTypeIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantDynamic(final DataInput file) throws IOException {
+        this(file.readShort(), file.readShort());
+    }
+
+
+    public ConstantDynamic(final int bootstrap_method_attr_index, final int \
name_and_type_index) { +        super(Const.CONSTANT_Dynamic, \
bootstrap_method_attr_index, name_and_type_index); +    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitly
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantDynamic(this);
+    }
+
+    /**
+     * @return Reference (index) to bootstrap method this constant refers to.
+     *
+     * Note that this method is a functional duplicate of getClassIndex
+     * for use by ConstantInvokeDynamic.
+     * @since 6.0
+     */
+    public int getBootstrapMethodAttrIndex() {
+        return super.getClassIndex();  // AKA bootstrap_method_attr_index
+    }
+
+    /**
+     * @return String representation
+     */
+    @Override
+    public String toString() {
+        return super.toString().replace("class_index", \
"bootstrap_method_attr_index"); +    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantFieldref.java \
b/src/org/apache/bcel/classfile/ConstantFieldref.java new file mode 100644
index 00000000..2c4e89d1
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantFieldref.java
@@ -0,0 +1,70 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents a constant pool reference to a field.
+ *
+ */
+public final class ConstantFieldref extends ConstantCP {
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantFieldref(final ConstantFieldref c) {
+        super(Const.CONSTANT_Fieldref, c.getClassIndex(), c.getNameAndTypeIndex());
+    }
+
+
+    /**
+     * Initialize instance from input data.
+     *
+     * @param input input stream
+     * @throws IOException
+     */
+    ConstantFieldref(final DataInput input) throws IOException {
+        super(Const.CONSTANT_Fieldref, input);
+    }
+
+
+    /**
+     * @param class_index Reference to the class containing the Field
+     * @param name_and_type_index and the Field signature
+     */
+    public ConstantFieldref(final int class_index, final int name_and_type_index) {
+        super(Const.CONSTANT_Fieldref, class_index, name_and_type_index);
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of Fields,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantFieldref(this);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantFloat.java \
b/src/org/apache/bcel/classfile/ConstantFloat.java new file mode 100644
index 00000000..569021dc
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantFloat.java
@@ -0,0 +1,123 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a float object.
+ *
+ * @see     Constant
+ */
+public final class ConstantFloat extends Constant implements ConstantObject {
+
+    private float bytes;
+
+
+    /**
+     * @param bytes Data
+     */
+    public ConstantFloat(final float bytes) {
+        super(Const.CONSTANT_Float);
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * Initialize from another object. Note that both objects use the same
+     * references (shallow copy). Use clone() for a physical copy.
+     */
+    public ConstantFloat(final ConstantFloat c) {
+        this(c.getBytes());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantFloat(final DataInput file) throws IOException {
+        this(file.readFloat());
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantFloat(this);
+    }
+
+
+    /**
+     * Dump constant float to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeFloat(bytes);
+    }
+
+
+    /**
+     * @return data, i.e., 4 bytes.
+     */
+    public float getBytes() {
+        return bytes;
+    }
+
+
+    /**
+     * @param bytes the raw bytes that represent this float
+     */
+    public void setBytes( final float bytes ) {
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(bytes = " + bytes + ")";
+    }
+
+
+    /** @return Float object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        return new Float(bytes);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantInteger.java \
b/src/org/apache/bcel/classfile/ConstantInteger.java new file mode 100644
index 00000000..68b524da
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantInteger.java
@@ -0,0 +1,122 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to an int object.
+ *
+ * @see     Constant
+ */
+public final class ConstantInteger extends Constant implements ConstantObject {
+
+    private int bytes;
+
+
+    /**
+     * @param bytes Data
+     */
+    public ConstantInteger(final int bytes) {
+        super(Const.CONSTANT_Integer);
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantInteger(final ConstantInteger c) {
+        this(c.getBytes());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantInteger(final DataInput file) throws IOException {
+        this(file.readInt());
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantInteger(this);
+    }
+
+
+    /**
+     * Dump constant integer to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeInt(bytes);
+    }
+
+
+    /**
+     * @return data, i.e., 4 bytes.
+     */
+    public int getBytes() {
+        return bytes;
+    }
+
+
+    /**
+     * @param bytes the raw bytes that represent this integer
+     */
+    public void setBytes( final int bytes ) {
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(bytes = " + bytes + ")";
+    }
+
+
+    /** @return Integer object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        return Integer.valueOf(bytes);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantInterfaceMethodref.java \
b/src/org/apache/bcel/classfile/ConstantInterfaceMethodref.java new file mode 100644
index 00000000..b1c668a5
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantInterfaceMethodref.java
@@ -0,0 +1,70 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents a constant pool reference to an interface method.
+ *
+ */
+public final class ConstantInterfaceMethodref extends ConstantCP {
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantInterfaceMethodref(final ConstantInterfaceMethodref c) {
+        super(Const.CONSTANT_InterfaceMethodref, c.getClassIndex(), \
c.getNameAndTypeIndex()); +    }
+
+
+    /**
+     * Initialize instance from input data.
+     *
+     * @param input input stream
+     * @throws IOException
+     */
+    ConstantInterfaceMethodref(final DataInput input) throws IOException {
+        super(Const.CONSTANT_InterfaceMethodref, input);
+    }
+
+
+    /**
+     * @param class_index Reference to the class containing the method
+     * @param name_and_type_index and the method signature
+     */
+    public ConstantInterfaceMethodref(final int class_index, final int \
name_and_type_index) { +        super(Const.CONSTANT_InterfaceMethodref, class_index, \
name_and_type_index); +    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantInterfaceMethodref(this);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantInvokeDynamic.java \
b/src/org/apache/bcel/classfile/ConstantInvokeDynamic.java new file mode 100644
index 00000000..830276ec
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantInvokeDynamic.java
@@ -0,0 +1,90 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a invoke dynamic.
+ *
+ * @see     Constant
+ * @see  <a href="https://docs.oracle.com/javase/specs/jvms/se8/html/jvms-4.html#jvms-4.4.10">
 + * The CONSTANT_InvokeDynamic_info Structure in The Java Virtual Machine \
Specification</a> + * @since 6.0
+ */
+public final class ConstantInvokeDynamic extends ConstantCP {
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantInvokeDynamic(final ConstantInvokeDynamic c) {
+        this(c.getBootstrapMethodAttrIndex(), c.getNameAndTypeIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantInvokeDynamic(final DataInput file) throws IOException {
+        this(file.readShort(), file.readShort());
+    }
+
+
+    public ConstantInvokeDynamic(final int bootstrap_method_attr_index, final int \
name_and_type_index) { +        super(Const.CONSTANT_InvokeDynamic, \
bootstrap_method_attr_index, name_and_type_index); +    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitly
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantInvokeDynamic(this);
+    }
+
+    /**
+     * @return Reference (index) to bootstrap method this constant refers to.
+     *
+     * Note that this method is a functional duplicate of getClassIndex
+     * for use by ConstantInvokeDynamic.
+     * @since 6.0
+     */
+    public int getBootstrapMethodAttrIndex() {
+        return super.getClassIndex();  // AKA bootstrap_method_attr_index
+    }
+
+    /**
+     * @return String representation
+     */
+    @Override
+    public String toString() {
+        return super.toString().replace("class_index", \
"bootstrap_method_attr_index"); +    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantLong.java \
b/src/org/apache/bcel/classfile/ConstantLong.java new file mode 100644
index 00000000..821c3397
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantLong.java
@@ -0,0 +1,122 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a long object.
+ *
+ * @see     Constant
+ */
+public final class ConstantLong extends Constant implements ConstantObject {
+
+    private long bytes;
+
+
+    /**
+     * @param bytes Data
+     */
+    public ConstantLong(final long bytes) {
+        super(Const.CONSTANT_Long);
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantLong(final ConstantLong c) {
+        this(c.getBytes());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantLong(final DataInput file) throws IOException {
+        this(file.readLong());
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantLong(this);
+    }
+
+
+    /**
+     * Dump constant long to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeLong(bytes);
+    }
+
+
+    /**
+     * @return data, i.e., 8 bytes.
+     */
+    public long getBytes() {
+        return bytes;
+    }
+
+
+    /**
+     * @param bytes the raw bytes that represent this long
+     */
+    public void setBytes( final long bytes ) {
+        this.bytes = bytes;
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(bytes = " + bytes + ")";
+    }
+
+
+    /** @return Long object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        return Long.valueOf(bytes);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantMethodHandle.java \
b/src/org/apache/bcel/classfile/ConstantMethodHandle.java new file mode 100644
index 00000000..cd68fd4b
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantMethodHandle.java
@@ -0,0 +1,120 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a method handle.
+ *
+ * @see     Constant
+ * @since 6.0
+ */
+public final class ConstantMethodHandle extends Constant {
+
+    private int referenceKind;
+    private int referenceIndex;
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantMethodHandle(final ConstantMethodHandle c) {
+        this(c.getReferenceKind(), c.getReferenceIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantMethodHandle(final DataInput file) throws IOException {
+        this(file.readUnsignedByte(), file.readUnsignedShort());
+    }
+
+
+    public ConstantMethodHandle(final int reference_kind, final int reference_index) \
{ +        super(Const.CONSTANT_MethodHandle);
+        this.referenceKind = reference_kind;
+        this.referenceIndex = reference_index;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitly
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantMethodHandle(this);
+    }
+
+
+    /**
+     * Dump method kind and index to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeByte(referenceKind);
+        file.writeShort(referenceIndex);
+    }
+
+
+    public int getReferenceKind() {
+        return referenceKind;
+    }
+
+
+    public void setReferenceKind(final int reference_kind) {
+        this.referenceKind = reference_kind;
+    }
+
+
+    public int getReferenceIndex() {
+        return referenceIndex;
+    }
+
+
+    public void setReferenceIndex(final int reference_index) {
+        this.referenceIndex = reference_index;
+    }
+
+
+    /**
+     * @return String representation
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(referenceKind = " + referenceKind +
+                ", referenceIndex = " + referenceIndex + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantMethodType.java \
b/src/org/apache/bcel/classfile/ConstantMethodType.java new file mode 100644
index 00000000..d687e6ec
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantMethodType.java
@@ -0,0 +1,106 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a method type.
+ *
+ * @see     Constant
+ * @since 6.0
+ */
+public final class ConstantMethodType extends Constant {
+
+    private int descriptorIndex;
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantMethodType(final ConstantMethodType c) {
+        this(c.getDescriptorIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantMethodType(final DataInput file) throws IOException {
+        this(file.readUnsignedShort());
+    }
+
+
+    public ConstantMethodType(final int descriptor_index) {
+        super(Const.CONSTANT_MethodType);
+        this.descriptorIndex = descriptor_index;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitly
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantMethodType(this);
+    }
+
+
+    /**
+     * Dump name and signature index to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeShort(descriptorIndex);
+    }
+
+
+    public int getDescriptorIndex() {
+        return descriptorIndex;
+    }
+
+
+    public void setDescriptorIndex(final int descriptor_index) {
+        this.descriptorIndex = descriptor_index;
+    }
+
+
+    /**
+     * @return String representation
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(descriptorIndex = " + descriptorIndex + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantMethodref.java \
b/src/org/apache/bcel/classfile/ConstantMethodref.java new file mode 100644
index 00000000..0e1e628d
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantMethodref.java
@@ -0,0 +1,70 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents a constant pool reference to a method.
+ *
+ */
+public final class ConstantMethodref extends ConstantCP {
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantMethodref(final ConstantMethodref c) {
+        super(Const.CONSTANT_Methodref, c.getClassIndex(), c.getNameAndTypeIndex());
+    }
+
+
+    /**
+     * Initialize instance from input data.
+     *
+     * @param input input stream
+     * @throws IOException
+     */
+    ConstantMethodref(final DataInput input) throws IOException {
+        super(Const.CONSTANT_Methodref, input);
+    }
+
+
+    /**
+     * @param class_index Reference to the class containing the method
+     * @param name_and_type_index and the method signature
+     */
+    public ConstantMethodref(final int class_index, final int name_and_type_index) {
+        super(Const.CONSTANT_Methodref, class_index, name_and_type_index);
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantMethodref(this);
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantModule.java \
b/src/org/apache/bcel/classfile/ConstantModule.java new file mode 100644
index 00000000..66cc2035
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantModule.java
@@ -0,0 +1,134 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a module.
+ *
+ * <p>Note: Early access Java 9 support- currently subject to change</p>
+ *
+ * @see     Constant
+ * @since 6.1
+ */
+public final class ConstantModule extends Constant implements ConstantObject {
+
+    private int nameIndex;
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantModule(final ConstantModule c) {
+        this(c.getNameIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantModule(final DataInput file) throws IOException {
+        this(file.readUnsignedShort());
+    }
+
+
+    /**
+     * @param nameIndex Name index in constant pool.  Should refer to a
+     * ConstantUtf8.
+     */
+    public ConstantModule(final int nameIndex) {
+        super(Const.CONSTANT_Module);
+        this.nameIndex = nameIndex;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitly
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantModule(this);
+    }
+
+
+    /**
+     * Dump constant module to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeShort(nameIndex);
+    }
+
+
+    /**
+     * @return Name index in constant pool of module name.
+     */
+    public int getNameIndex() {
+        return nameIndex;
+    }
+
+
+    /**
+     * @param nameIndex the name index in the constant pool of this Constant Module
+     */
+    public void setNameIndex( final int nameIndex ) {
+        this.nameIndex = nameIndex;
+    }
+
+
+    /** @return String object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        final Constant c = cp.getConstant(nameIndex, Const.CONSTANT_Utf8);
+        return ((ConstantUtf8) c).getBytes();
+    }
+
+
+    /** @return dereferenced string
+     */
+    public String getBytes( final ConstantPool cp ) {
+        return (String) getConstantValue(cp);
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(nameIndex = " + nameIndex + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantNameAndType.java \
b/src/org/apache/bcel/classfile/ConstantNameAndType.java new file mode 100644
index 00000000..01982ea5
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantNameAndType.java
@@ -0,0 +1,150 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to the name and signature
+ * of a field or method.
+ *
+ * @see     Constant
+ */
+public final class ConstantNameAndType extends Constant {
+
+    private int nameIndex; // Name of field/method
+    private int signatureIndex; // and its signature.
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantNameAndType(final ConstantNameAndType c) {
+        this(c.getNameIndex(), c.getSignatureIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantNameAndType(final DataInput file) throws IOException {
+        this(file.readUnsignedShort(), file.readUnsignedShort());
+    }
+
+
+    /**
+     * @param nameIndex Name of field/method
+     * @param signatureIndex and its signature
+     */
+    public ConstantNameAndType(final int nameIndex, final int signatureIndex) {
+        super(Const.CONSTANT_NameAndType);
+        this.nameIndex = nameIndex;
+        this.signatureIndex = signatureIndex;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitely
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantNameAndType(this);
+    }
+
+
+    /**
+     * Dump name and signature index to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeShort(nameIndex);
+        file.writeShort(signatureIndex);
+    }
+
+
+    /**
+     * @return Name index in constant pool of field/method name.
+     */
+    public int getNameIndex() {
+        return nameIndex;
+    }
+
+
+    /** @return name
+     */
+    public String getName( final ConstantPool cp ) {
+        return cp.constantToString(getNameIndex(), Const.CONSTANT_Utf8);
+    }
+
+
+    /**
+     * @return Index in constant pool of field/method signature.
+     */
+    public int getSignatureIndex() {
+        return signatureIndex;
+    }
+
+
+    /** @return signature
+     */
+    public String getSignature( final ConstantPool cp ) {
+        return cp.constantToString(getSignatureIndex(), Const.CONSTANT_Utf8);
+    }
+
+
+    /**
+     * @param nameIndex the name index of this constant
+     */
+    public void setNameIndex( final int nameIndex ) {
+        this.nameIndex = nameIndex;
+    }
+
+
+    /**
+     * @param signatureIndex the signature index in the constant pool of this type
+     */
+    public void setSignatureIndex( final int signatureIndex ) {
+        this.signatureIndex = signatureIndex;
+    }
+
+
+    /**
+     * @return String representation
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(nameIndex = " + nameIndex + ", signatureIndex = \
" +                + signatureIndex + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantObject.java \
b/src/org/apache/bcel/classfile/ConstantObject.java new file mode 100644
index 00000000..feb2f52d
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantObject.java
@@ -0,0 +1,31 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+/**
+ * This interface denotes those constants that have a "natural" value,
+ * such as ConstantLong, ConstantString, etc..
+ *
+ * @see     Constant
+ */
+public interface ConstantObject {
+
+    /** @return object representing the constant, e.g., Long for ConstantLong
+     */
+    Object getConstantValue( ConstantPool cp );
+}
diff --git a/src/org/apache/bcel/classfile/ConstantPackage.java \
b/src/org/apache/bcel/classfile/ConstantPackage.java new file mode 100644
index 00000000..3f94c749
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantPackage.java
@@ -0,0 +1,134 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class is derived from the abstract {@link Constant}
+ * and represents a reference to a package.
+ *
+ * <p>Note: Early access Java 9 support- currently subject to change</p>
+ *
+ * @see     Constant
+ * @since 6.1
+ */
+public final class ConstantPackage extends Constant implements ConstantObject {
+
+    private int nameIndex;
+
+
+    /**
+     * Initialize from another object.
+     */
+    public ConstantPackage(final ConstantPackage c) {
+        this(c.getNameIndex());
+    }
+
+
+    /**
+     * Initialize instance from file data.
+     *
+     * @param file Input stream
+     * @throws IOException
+     */
+    ConstantPackage(final DataInput file) throws IOException {
+        this(file.readUnsignedShort());
+    }
+
+
+    /**
+     * @param nameIndex Name index in constant pool.  Should refer to a
+     * ConstantUtf8.
+     */
+    public ConstantPackage(final int nameIndex) {
+        super(Const.CONSTANT_Package);
+        this.nameIndex = nameIndex;
+    }
+
+
+    /**
+     * Called by objects that are traversing the nodes of the tree implicitly
+     * defined by the contents of a Java class. I.e., the hierarchy of methods,
+     * fields, attributes, etc. spawns a tree of objects.
+     *
+     * @param v Visitor object
+     */
+    @Override
+    public void accept( final Visitor v ) {
+        v.visitConstantPackage(this);
+    }
+
+
+    /**
+     * Dump constant package to file stream in binary format.
+     *
+     * @param file Output file stream
+     * @throws IOException
+     */
+    @Override
+    public void dump( final DataOutputStream file ) throws IOException {
+        file.writeByte(super.getTag());
+        file.writeShort(nameIndex);
+    }
+
+
+    /**
+     * @return Name index in constant pool of package name.
+     */
+    public int getNameIndex() {
+        return nameIndex;
+    }
+
+
+    /**
+     * @param nameIndex the name index in the constant pool of this Constant Package
+     */
+    public void setNameIndex( final int nameIndex ) {
+        this.nameIndex = nameIndex;
+    }
+
+
+    /** @return String object
+     */
+    @Override
+    public Object getConstantValue( final ConstantPool cp ) {
+        final Constant c = cp.getConstant(nameIndex, Const.CONSTANT_Utf8);
+        return ((ConstantUtf8) c).getBytes();
+    }
+
+
+    /** @return dereferenced string
+     */
+    public String getBytes( final ConstantPool cp ) {
+        return (String) getConstantValue(cp);
+    }
+
+
+    /**
+     * @return String representation.
+     */
+    @Override
+    public String toString() {
+        return super.toString() + "(nameIndex = " + nameIndex + ")";
+    }
+}
diff --git a/src/org/apache/bcel/classfile/ConstantPool.java \
b/src/org/apache/bcel/classfile/ConstantPool.java new file mode 100644
index 00000000..c2926c08
--- /dev/null
+++ b/src/org/apache/bcel/classfile/ConstantPool.java
@@ -0,0 +1,376 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one or more
+ * contributor license agreements.  See the NOTICE file distributed with
+ * this work for additional information regarding copyright ownership.
+ * The ASF licenses this file to You 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.apache.bcel.classfile;
+
+import java.io.DataInput;
+import java.io.DataOutputStream;
+import java.io.IOException;
+
+import org.apache.bcel.Const;
+
+/**
+ * This class represents the constant pool, i.e., a table of constants, of
+ * a parsed classfile. It may contain null references, due to the JVM
+ * specification that skips an entry after an 8-byte constant (double,
+ * long) entry.  Those interested in generating constant pools
+ * programatically should see <a href="../generic/ConstantPoolGen.html">
+ * ConstantPoolGen</a>.
+
+ * @see     Constant
+ * @see     org.apache.bcel.generic.ConstantPoolGen
+ */
+public class ConstantPool implements Cloneable, Node {
+
+    private Constant[] constantPool;
+
+    /**
+     * @param constantPool Array of constants
+     */
+    public ConstantPool(final Constant[] constantPool) {
+        this.constantPool = constantPool;
+    }
+
+    /**
+     * Reads constants from given input stream.
+     *
+     * @param input Input stream
+     * @throws IOException
+     * @throws ClassFormatException
+     */
+    public ConstantPool(final DataInput input) throws IOException, \
ClassFormatException { +        byte tag;
+        final int constant_pool_count = input.readUnsignedShort();
+        constantPool = new Constant[constant_pool_count];
+        /* constantPool[0] is unused by the compiler and may be used freely
+         * by the implementation.
+         */
+        for (int i = 1; i < constant_pool_count; i++) {
+            constantPool[i] = Constant.readConstant(input);
+            /* Quote from the JVM specification:
+             * "All eight byte constants take up two spots in the constant pool.
+             * If this is the n'th byte in the constant pool, then the next item
+             * will be numbered n+2"
+             *
+             * Thus we have to increment the index counter.
+             */
+            tag = constantPool[i].getTag();
+            if ((tag == Const.CONSTANT_Double) || (tag == Const.CONSTANT_Long)) {
+                i++;
... 56285 lines suppressed ...


---------------------------------------------------------------------
To unsubscribe, e-mail: commits-unsubscribe@xalan.apache.org
For additional commands, e-mail: commits-help@xalan.apache.org


[prev in list] [next in list] [prev in thread] [next in thread] 

Configure | About | News | Add a list | Sponsored by KoreLogic