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

* (c) copyright 2002-2014 Delft University of Technology.
* BSD-style license. See DSOL License.
* @author Peter Jacobs * @author Alexander Verbraeck */ public class JSR extends JumpOperation { /** OP refers to the operand code. */ public static final int OP = 168; /** the index to load. */ private final int offset; /** the startAddress of the next operation. */ private final int nextAddress; /** * constructs a new JSR. * @param dataInput the dataInput * @param startBytePosition the startBytePosition of this operation * @throws IOException on IOfailure */ public JSR(final DataInput dataInput, final int startBytePosition) throws IOException { super(); this.offset = dataInput.readShort(); this.nextAddress = this.getByteLength() + startBytePosition; } /** {@inheritDoc} */ @Override public final int execute(final OperandStack stack, final Constant[] constantPool, final LocalVariable[] localVariables) { stack.push(Integer.valueOf(this.nextAddress)); return this.offset; } /** {@inheritDoc} */ @Override public final int getByteLength() { return OPCODE_BYTE_LENGTH + 2; } /** {@inheritDoc} */ @Override public final int getOpcode() { return JSR.OP; } }