blob: b53ef8c5af4c6e7d0896acb3784aa7a26eae94d0 [file] [log] [blame]
/*
* Copyright (c) 2000, 2008, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*
*/
package sun.jvm.hotspot.types;
import java.util.*;
/** This is the top-level interface which describes C++ classes and
primitive types as well as enough about Java primitive and object
types to allow the oop hierarchy to be constructed. */
public interface Type {
public String getName();
/* The supertype of this type. May be null for top-level classes and
primitive types. NOTE that multiple inheritance is currently not
handled. However, it could (probably) be by making this return a
list and adding appropriate routines to cast an address of one
type to another. */
public Type getSuperclass();
/** The size in bytes, at the machine level, of this type. This
should be equivalent to the sizeof operator -- i.e., should
include any compiler-inserted fields like the vtbl for C++
types. */
public long getSize();
/** Indicates whether this type is a C integer type -- regardless of
size or signedness. */
public boolean isCIntegerType();
/** Indicates whether this type is const char*. */
public boolean isCStringType();
/** Indicates whether this type is one of the Java primitive types. */
public boolean isJavaPrimitiveType();
/** Indicates whether this type is an oop type in the VM. */
public boolean isOopType();
/** Indicates whether this type is a pointer type. */
public boolean isPointerType();
/** This is permissive and returns the CField regardless of its type
as long as it is present. Returns null if the field was not
found, unless throwExceptionIfNotFound is true, in which case a
RuntimeException is thrown (for debugging purposes). */
public Field getField(String fieldName, boolean searchSuperclassFields,
boolean throwExceptionIfNotFound);
/** This is permissive and returns the CField regardless of its type
as long as it is present -- it is equivalent to
getField(fieldName, searchSuperclassFields, true). Throws a
RuntimeException if the field was not found. */
public Field getField(String fieldName, boolean searchSuperclassFields);
/** This is permissive and returns the CField regardless of its type
as long as it is present. This does not search superclasses'
fields; it is equivalent to getField(fieldName, false). Throws a
RuntimeException if the field was not found. */
public Field getField(String fieldName);
/** If there is a mismatch between the declared type and the type
which would otherwise be returned from this routine, it throws a
WrongTypeException. declaredType must not be null. Throws a
RuntimeException if field was otherwise not found. */
public Field getField(String fieldName, Type declaredType,
boolean searchSuperclassFields) throws WrongTypeException;
/** If there is a mismatch between the declared type and the type
which would otherwise be returned from this routine, it throws a
WrongTypeException. declaredType must not be null. This does not
search superclasses' fields; it is equivalent to
getField(fieldName, declaredType, false). Throws a
RuntimeException if field was otherwise not found. */
public Field getField(String fieldName, Type declaredType) throws WrongTypeException;
/** Iterate over all of the fields in this type but <B>not</B> in
any of its superclasses. The returned Iterator's "remove" method
must not be called. */
public Iterator getFields();
/** <P> These accessors are designed to allow strong type checking
of certain well-known types of fields, specifically Java
primitive and oop types. Specialized fields for all primitive
types, as well as oop fields, are required to have strong type
checking and a WrongTypeException should be thrown if the given
field is not precisely of the given type. Address and Oop fields
are more permissive to reduce the complexity of the initial
implementation. </P>
<P> These accessors do not search the superclass's fields. </P>
*/
public JBooleanField getJBooleanField (String fieldName) throws WrongTypeException;
public JByteField getJByteField (String fieldName) throws WrongTypeException;
public JCharField getJCharField (String fieldName) throws WrongTypeException;
public JDoubleField getJDoubleField (String fieldName) throws WrongTypeException;
public JFloatField getJFloatField (String fieldName) throws WrongTypeException;
public JIntField getJIntField (String fieldName) throws WrongTypeException;
public JLongField getJLongField (String fieldName) throws WrongTypeException;
public JShortField getJShortField (String fieldName) throws WrongTypeException;
public CIntegerField getCIntegerField (String fieldName) throws WrongTypeException;
public OopField getOopField (String fieldName) throws WrongTypeException;
public NarrowOopField getNarrowOopField (String fieldName) throws WrongTypeException;
public AddressField getAddressField (String fieldName);
}