1917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul/* 2917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Copyright (C) 2007 The Android Open Source Project 3917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 4917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Licensed under the Apache License, Version 2.0 (the "License"); 5917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * you may not use this file except in compliance with the License. 6917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * You may obtain a copy of the License at 7917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 8917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * http://www.apache.org/licenses/LICENSE-2.0 9917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 10917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Unless required by applicable law or agreed to in writing, software 11917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * distributed under the License is distributed on an "AS IS" BASIS, 12917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * See the License for the specific language governing permissions and 14917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * limitations under the License. 15917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 16917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 17917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulpackage com.android.dexgen.rop.type; 18917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 19917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulimport com.android.dexgen.util.ToHuman; 20917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 21917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul/** 22917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Object which has an associated type, possibly itself. 23917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 24917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgulpublic interface TypeBearer 25917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul extends ToHuman { 26917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 27917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Gets the type associated with this instance. 28917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 29917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return {@code non-null;} the type 30917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 31917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public Type getType(); 32917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 33917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 34917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Gets the frame type corresponding to this type. This method returns 35917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * {@code this}, except if {@link Type#isIntlike} on the underlying 36917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * type returns {@code true} but the underlying type is not in 37917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * fact {@link Type#INT}, in which case this method returns an instance 38917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * whose underlying type <i>is</i> {@code INT}. 39917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 40917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return {@code non-null;} the frame type for this instance 41917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 42917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public TypeBearer getFrameType(); 43917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 44917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 45917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Gets the basic type corresponding to this instance. 46917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 47917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return the basic type; one of the {@code BT_*} constants 48917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * defined by {@link Type} 49917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 50917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public int getBasicType(); 51917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 52917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 53917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Gets the basic type corresponding to this instance's frame type. This 54917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * is equivalent to {@code getFrameType().getBasicType()}, and 55917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * is the same as calling {@code getFrameType()} unless this 56917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * instance is an int-like type, in which case this method returns 57917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * {@code BT_INT}. 58917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 59917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @see #getBasicType 60917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @see #getFrameType 61917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 62917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return the basic frame type; one of the {@code BT_*} constants 63917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * defined by {@link Type} 64917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 65917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public int getBasicFrameType(); 66917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul 67917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul /** 68917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * Returns whether this instance represents a constant value. 69917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * 70917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * @return {@code true} if this instance represents a constant value 71917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul * and {@code false} if not 72917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul */ 73917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul public boolean isConstant(); 74917cb222329ee8c035c3ffaf947e4265761b9367Piotr Gurgul} 75