StoreInstruction.java

  1. /*
  2.  * Licensed to the Apache Software Foundation (ASF) under one or more
  3.  * contributor license agreements.  See the NOTICE file distributed with
  4.  * this work for additional information regarding copyright ownership.
  5.  * The ASF licenses this file to You under the Apache License, Version 2.0
  6.  * (the "License"); you may not use this file except in compliance with
  7.  * the License.  You may obtain a copy of the License at
  8.  *
  9.  *      http://www.apache.org/licenses/LICENSE-2.0
  10.  *
  11.  *  Unless required by applicable law or agreed to in writing, software
  12.  *  distributed under the License is distributed on an "AS IS" BASIS,
  13.  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14.  *  See the License for the specific language governing permissions and
  15.  *  limitations under the License.
  16.  */
  17. package org.apache.bcel.generic;

  18. /**
  19.  * Denotes an unparameterized instruction to store a value into a local variable, e.g. ISTORE.
  20.  */
  21. public abstract class StoreInstruction extends LocalVariableInstruction implements PopInstruction {

  22.     /**
  23.      * Empty constructor needed for Instruction.readInstruction. Not to be used otherwise. tag and length are defined in
  24.      * readInstruction and initFromFile, respectively.
  25.      */
  26.     StoreInstruction(final short canonTag, final short cTag) {
  27.         super(canonTag, cTag);
  28.     }

  29.     /**
  30.      * @param opcode Instruction opcode
  31.      * @param cTag Instruction number for compact version, ASTORE_0, e.g.
  32.      * @param n local variable index (unsigned short)
  33.      */
  34.     protected StoreInstruction(final short opcode, final short cTag, final int n) {
  35.         super(opcode, cTag, n);
  36.     }

  37.     /**
  38.      * Call corresponding visitor method(s). The order is: Call visitor methods of implemented interfaces first, then call
  39.      * methods according to the class hierarchy in descending order, i.e., the most specific visitXXX() call comes last.
  40.      *
  41.      * @param v Visitor object
  42.      */
  43.     @Override
  44.     public void accept(final Visitor v) {
  45.         v.visitStackConsumer(this);
  46.         v.visitPopInstruction(this);
  47.         v.visitTypedInstruction(this);
  48.         v.visitLocalVariableInstruction(this);
  49.         v.visitStoreInstruction(this);
  50.     }
  51. }