/* |
|
* reserved comment block |
|
* DO NOT REMOVE OR ALTER! |
|
*/ |
|
/* |
|
* Licensed to the Apache Software Foundation (ASF) under one or more |
|
* contributor license agreements. See the NOTICE file distributed with |
|
* this work for additional information regarding copyright ownership. |
|
* The ASF licenses this file to You under the Apache License, Version 2.0 |
|
* (the "License"); you may not use this file except in compliance with |
|
* the License. You may obtain a copy of the License at |
|
* |
|
* http://www.apache.org/licenses/LICENSE-2.0 |
|
* |
|
* Unless required by applicable law or agreed to in writing, software |
|
* distributed under the License is distributed on an "AS IS" BASIS, |
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
* See the License for the specific language governing permissions and |
|
* limitations under the License. |
|
*/ |
|
package com.sun.org.apache.bcel.internal.generic; |
|
import com.sun.org.apache.bcel.internal.Const; |
|
import com.sun.org.apache.bcel.internal.ExceptionConst; |
|
/** |
|
* GETFIELD - Fetch field from object |
|
* <PRE>Stack: ..., objectref -> ..., value</PRE> |
|
* OR |
|
* <PRE>Stack: ..., objectref -> ..., value.word1, value.word2</PRE> |
|
* |
|
*/ |
|
public class GETFIELD extends FieldInstruction implements ExceptionThrower, StackConsumer, |
|
StackProducer { |
|
/** |
|
* Empty constructor needed for Instruction.readInstruction. |
|
* Not to be used otherwise. |
|
*/ |
|
GETFIELD() { |
|
} |
|
public GETFIELD(final int index) { |
|
super(Const.GETFIELD, index); |
|
} |
|
@Override |
|
public int produceStack( final ConstantPoolGen cpg ) { |
|
return getFieldSize(cpg); |
|
} |
|
@Override |
|
public Class<?>[] getExceptions() { |
|
return ExceptionConst.createExceptions(ExceptionConst.EXCS.EXCS_FIELD_AND_METHOD_RESOLUTION, |
|
ExceptionConst.NULL_POINTER_EXCEPTION, |
|
ExceptionConst.INCOMPATIBLE_CLASS_CHANGE_ERROR); |
|
} |
|
/** |
|
* Call corresponding visitor method(s). The order is: |
|
* Call visitor methods of implemented interfaces first, then |
|
* call methods according to the class hierarchy in descending order, |
|
* i.e., the most specific visitXXX() call comes last. |
|
* |
|
* @param v Visitor object |
|
*/ |
|
@Override |
|
public void accept( final Visitor v ) { |
|
v.visitExceptionThrower(this); |
|
v.visitStackConsumer(this); |
|
v.visitStackProducer(this); |
|
v.visitTypedInstruction(this); |
|
v.visitLoadClass(this); |
|
v.visitCPInstruction(this); |
|
v.visitFieldOrMethod(this); |
|
v.visitFieldInstruction(this); |
|
v.visitGETFIELD(this); |
|
} |
|
} |