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;
}
}