package nl.tudelft.simulation.dsol.interpreter.operations; import java.io.DataInput; import java.io.IOException; import nl.tudelft.simulation.dsol.interpreter.InterpreterException; import nl.tudelft.simulation.dsol.interpreter.LocalVariable; import nl.tudelft.simulation.dsol.interpreter.OperandStack; import nl.tudelft.simulation.dsol.interpreter.classfile.Constant; import nl.tudelft.simulation.dsol.interpreter.classfile.ConstantClass; /** * The INSTANCEOF operation as defined in * http://java.sun.com/docs/books/vmspec/2nd-edition/html/Instructions2.doc6.html . *

* (c) copyright 2002-2014 Delft University of Technology.
* BSD-style license. See DSOL License.
* @author Peter Jacobs * @author Alexander Verbraeck */ public class INSTANCEOF extends VoidOperation { /** OP refers to the operand code. */ public static final int OP = 193; /** the index of the class in the constantPool. */ private final int index; /** * constructs a new INSTANCEOF. * @param dataInput the dataInput * @throws IOException on failure */ public INSTANCEOF(final DataInput dataInput) throws IOException { super(); this.index = dataInput.readUnsignedShort(); } /** {@inheritDoc} */ @Override public final void execute(final OperandStack stack, final Constant[] constantPool, final LocalVariable[] localVariables) { Object reference = stack.pop(); Class clazz = null; try { clazz = ((ConstantClass) constantPool[this.index]).getValue().getClassValue(); } catch (Exception exception) { throw new InterpreterException(exception); } if (reference != null && clazz.isInstance(reference)) { stack.push(Integer.valueOf(1)); } else { stack.push(Integer.valueOf(0)); } } /** {@inheritDoc} */ @Override public final int getByteLength() { return OPCODE_BYTE_LENGTH + 2; } /** {@inheritDoc} */ @Override public final int getOpcode() { return INSTANCEOF.OP; } }