Class BasicVerifier

    • Method Detail

      • copyOperation

        public BasicValue copyOperation​(AbstractInsnNode insn,
                                        BasicValue value)
                                 throws AnalyzerException
        Description copied from class: Interpreter
        Interprets a bytecode instruction that moves a value on the stack or to or from local variables. This method is called for the following opcodes:

        ILOAD, LLOAD, FLOAD, DLOAD, ALOAD, ISTORE, LSTORE, FSTORE, DSTORE, ASTORE, DUP, DUP_X1, DUP_X2, DUP2, DUP2_X1, DUP2_X2, SWAP

        Overrides:
        copyOperation in class BasicInterpreter
        Parameters:
        insn - the bytecode instruction to be interpreted.
        value - the value that must be moved by the instruction.
        Returns:
        the result of the interpretation of the given instruction. The returned value must be equal to the given value.
        Throws:
        AnalyzerException - if an error occurred during the interpretation.
      • unaryOperation

        public BasicValue unaryOperation​(AbstractInsnNode insn,
                                         BasicValue value)
                                  throws AnalyzerException
        Description copied from class: Interpreter
        Interprets a bytecode instruction with a single argument. This method is called for the following opcodes:

        INEG, LNEG, FNEG, DNEG, IINC, I2L, I2F, I2D, L2I, L2F, L2D, F2I, F2L, F2D, D2I, D2L, D2F, I2B, I2C, I2S, IFEQ, IFNE, IFLT, IFGE, IFGT, IFLE, TABLESWITCH, LOOKUPSWITCH, IRETURN, LRETURN, FRETURN, DRETURN, ARETURN, PUTSTATIC, GETFIELD, NEWARRAY, ANEWARRAY, ARRAYLENGTH, ATHROW, CHECKCAST, INSTANCEOF, MONITORENTER, MONITOREXIT, IFNULL, IFNONNULL

        Overrides:
        unaryOperation in class BasicInterpreter
        Parameters:
        insn - the bytecode instruction to be interpreted.
        value - the argument of the instruction to be interpreted.
        Returns:
        the result of the interpretation of the given instruction.
        Throws:
        AnalyzerException - if an error occurred during the interpretation.
      • binaryOperation

        public BasicValue binaryOperation​(AbstractInsnNode insn,
                                          BasicValue value1,
                                          BasicValue value2)
                                   throws AnalyzerException
        Description copied from class: Interpreter
        Interprets a bytecode instruction with two arguments. This method is called for the following opcodes:

        IALOAD, LALOAD, FALOAD, DALOAD, AALOAD, BALOAD, CALOAD, SALOAD, IADD, LADD, FADD, DADD, ISUB, LSUB, FSUB, DSUB, IMUL, LMUL, FMUL, DMUL, IDIV, LDIV, FDIV, DDIV, IREM, LREM, FREM, DREM, ISHL, LSHL, ISHR, LSHR, IUSHR, LUSHR, IAND, LAND, IOR, LOR, IXOR, LXOR, LCMP, FCMPL, FCMPG, DCMPL, DCMPG, IF_ICMPEQ, IF_ICMPNE, IF_ICMPLT, IF_ICMPGE, IF_ICMPGT, IF_ICMPLE, IF_ACMPEQ, IF_ACMPNE, PUTFIELD

        Overrides:
        binaryOperation in class BasicInterpreter
        Parameters:
        insn - the bytecode instruction to be interpreted.
        value1 - the first argument of the instruction to be interpreted.
        value2 - the second argument of the instruction to be interpreted.
        Returns:
        the result of the interpretation of the given instruction.
        Throws:
        AnalyzerException - if an error occurred during the interpretation.
      • ternaryOperation

        public BasicValue ternaryOperation​(AbstractInsnNode insn,
                                           BasicValue value1,
                                           BasicValue value2,
                                           BasicValue value3)
                                    throws AnalyzerException
        Description copied from class: Interpreter
        Interprets a bytecode instruction with three arguments. This method is called for the following opcodes:

        IASTORE, LASTORE, FASTORE, DASTORE, AASTORE, BASTORE, CASTORE, SASTORE

        Overrides:
        ternaryOperation in class BasicInterpreter
        Parameters:
        insn - the bytecode instruction to be interpreted.
        value1 - the first argument of the instruction to be interpreted.
        value2 - the second argument of the instruction to be interpreted.
        value3 - the third argument of the instruction to be interpreted.
        Returns:
        the result of the interpretation of the given instruction.
        Throws:
        AnalyzerException - if an error occurred during the interpretation.
      • naryOperation

        public BasicValue naryOperation​(AbstractInsnNode insn,
                                        java.util.List<? extends BasicValue> values)
                                 throws AnalyzerException
        Description copied from class: Interpreter
        Interprets a bytecode instruction with a variable number of arguments. This method is called for the following opcodes:

        INVOKEVIRTUAL, INVOKESPECIAL, INVOKESTATIC, INVOKEINTERFACE, MULTIANEWARRAY and INVOKEDYNAMIC

        Overrides:
        naryOperation in class BasicInterpreter
        Parameters:
        insn - the bytecode instruction to be interpreted.
        values - the arguments of the instruction to be interpreted.
        Returns:
        the result of the interpretation of the given instruction.
        Throws:
        AnalyzerException - if an error occurred during the interpretation.
      • returnOperation

        public void returnOperation​(AbstractInsnNode insn,
                                    BasicValue value,
                                    BasicValue expected)
                             throws AnalyzerException
        Description copied from class: Interpreter
        Interprets a bytecode return instruction. This method is called for the following opcodes:

        IRETURN, LRETURN, FRETURN, DRETURN, ARETURN

        Overrides:
        returnOperation in class BasicInterpreter
        Parameters:
        insn - the bytecode instruction to be interpreted.
        value - the argument of the instruction to be interpreted.
        expected - the expected return type of the analyzed method.
        Throws:
        AnalyzerException - if an error occurred during the interpretation.
      • isArrayValue

        protected boolean isArrayValue​(BasicValue value)
        Returns whether the given value corresponds to an array reference.
        Parameters:
        value - a value.
        Returns:
        whether 'value' corresponds to an array reference.
      • getElementValue

        protected BasicValue getElementValue​(BasicValue objectArrayValue)
                                      throws AnalyzerException
        Returns the value corresponding to the type of the elements of the given array reference value.
        Parameters:
        objectArrayValue - a value corresponding to array of object (or array) references.
        Returns:
        the value corresponding to the type of the elements of 'objectArrayValue'.
        Throws:
        AnalyzerException - if objectArrayValue does not correspond to an array type.
      • isSubTypeOf

        protected boolean isSubTypeOf​(BasicValue value,
                                      BasicValue expected)
        Returns whether the type corresponding to the first argument is a subtype of the type corresponding to the second argument.
        Parameters:
        value - a value.
        expected - another value.
        Returns:
        whether the type corresponding to 'value' is a subtype of the type corresponding to 'expected'.