MethodRefForm.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.commons.compress.harmony.unpack200.bytecode.forms;

  18. import org.apache.commons.compress.harmony.unpack200.SegmentConstantPool;
  19. import org.apache.commons.compress.harmony.unpack200.bytecode.OperandManager;

  20. /**
  21.  * This class implements the byte code form for those bytecodes which have regular method references (and only regular method references). These are:
  22.  * invokevirtual invokespecial invokestatic Class-specific references to methods are subclasses of ClassSpecificReferenceForm instead.
  23.  */
  24. public class MethodRefForm extends ReferenceForm {

  25.     public MethodRefForm(final int opcode, final String name, final int[] rewrite) {
  26.         super(opcode, name, rewrite);
  27.     }

  28.     @Override
  29.     protected int getOffset(final OperandManager operandManager) {
  30.         return operandManager.nextMethodRef();
  31.     }

  32.     @Override
  33.     protected int getPoolID() {
  34.         return SegmentConstantPool.CP_METHOD;
  35.     }
  36. }