b4d49f49bf
* gcj/javaprims.h (_Jv_Utf8Const): Change struct to a class, with private fields and access methods. (_Jv_NewStringUTF, _Jv_hashUtf8String): New function declarations. * gcj/cni.h (_Jv_NewStringUTF): Move to javaprims.h. * prims.cc (_Jv_Utf8COnst::init): New method implementation. ( _Jv_makeUtf8Const): Rewrite using new constructors. (hashUtf8String): Rename to +_Jv_hashUtf8String and make non-static. * defineclass.cc: Use new _Utf8Const access/convenience methods. * jni.cc: Likewise. * resolve.cc: Likewise. * gcj/field.h: Likewise. * include/jvm.h: Likewise. * java/lang/Class.h: Likewise. * java/lang/natClass.cc: Likwise. * java/lang/natClassLoader.cc: Likewise * java/lang/reflect/natMethod.cc: Likewise * verify.cc: Likewise. (_Jv_BytecodeVerifier::make_utf8_const): Optimize. (~_Jv_BytecodeVerifier): Don't need second _Jv_Free call. From-SVN: r85854
459 lines
14 KiB
C++
459 lines
14 KiB
C++
// Class.h - Header file for java.lang.Class. -*- c++ -*-
|
|
|
|
/* Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003 Free Software Foundation
|
|
|
|
This file is part of libgcj.
|
|
|
|
This software is copyrighted work licensed under the terms of the
|
|
Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
|
|
details. */
|
|
|
|
// Written primary using compiler source and Class.java as guides.
|
|
#ifndef __JAVA_LANG_CLASS_H__
|
|
#define __JAVA_LANG_CLASS_H__
|
|
|
|
#pragma interface
|
|
|
|
#include <java/lang/Object.h>
|
|
#include <java/lang/String.h>
|
|
#include <java/net/URL.h>
|
|
#include <java/lang/reflect/Modifier.h>
|
|
#include <java/security/ProtectionDomain.h>
|
|
#include <java/lang/Package.h>
|
|
#include <gnu/gcj/runtime/StackTrace.h>
|
|
|
|
// We declare these here to avoid including gcj/cni.h.
|
|
extern "C" void _Jv_InitClass (jclass klass);
|
|
extern "C" void _Jv_RegisterClasses (jclass *classes);
|
|
|
|
// This must be predefined with "C" linkage.
|
|
extern "C" void *_Jv_LookupInterfaceMethodIdx (jclass klass, jclass iface,
|
|
int meth_idx);
|
|
|
|
// These are the possible values for the `state' field of the class
|
|
// structure. Note that ordering is important here. Whenever the
|
|
// state changes, one should notify all waiters of this class.
|
|
enum
|
|
{
|
|
JV_STATE_NOTHING = 0, // Set by compiler.
|
|
|
|
JV_STATE_PRELOADING = 1, // Can do _Jv_FindClass.
|
|
JV_STATE_LOADING = 3, // Has super installed.
|
|
JV_STATE_COMPILED = 5, // This was a compiled class.
|
|
|
|
JV_STATE_LOADED = 6, // Is complete.
|
|
JV_STATE_PREPARED = 7, // Layout & static init done.
|
|
JV_STATE_LINKED = 9, // Strings interned.
|
|
|
|
JV_STATE_IN_PROGRESS = 10, // <Clinit> running.
|
|
|
|
JV_STATE_ERROR = 12,
|
|
|
|
JV_STATE_DONE = 14 // Must be last.
|
|
};
|
|
|
|
struct _Jv_Field;
|
|
struct _Jv_VTable;
|
|
union _Jv_word;
|
|
struct _Jv_ArrayVTable;
|
|
|
|
struct _Jv_Constants
|
|
{
|
|
jint size;
|
|
jbyte *tags;
|
|
_Jv_word *data;
|
|
};
|
|
|
|
struct _Jv_Method
|
|
{
|
|
// Method name.
|
|
_Jv_Utf8Const *name;
|
|
// Method signature.
|
|
_Jv_Utf8Const *signature;
|
|
// Access flags.
|
|
_Jv_ushort accflags;
|
|
// Method's index in the vtable.
|
|
_Jv_ushort index;
|
|
// Pointer to underlying function.
|
|
void *ncode;
|
|
// NULL-terminated list of exception class names; can be NULL if
|
|
// there are none such.
|
|
_Jv_Utf8Const **throws;
|
|
|
|
_Jv_Method *getNextMethod ()
|
|
{ return this + 1; }
|
|
};
|
|
|
|
// Interface Dispatch Tables
|
|
union _Jv_IDispatchTable
|
|
{
|
|
struct
|
|
{
|
|
// Index into interface's ioffsets.
|
|
jshort iindex;
|
|
jshort itable_length;
|
|
// Class Interface dispatch table.
|
|
void **itable;
|
|
} cls;
|
|
|
|
struct
|
|
{
|
|
// Offsets into implementation class itables.
|
|
jshort *ioffsets;
|
|
} iface;
|
|
};
|
|
|
|
// Used by _Jv_GetInterfaces ()
|
|
struct _Jv_ifaces
|
|
{
|
|
jclass *list;
|
|
jshort len;
|
|
jshort count;
|
|
};
|
|
|
|
struct _Jv_MethodSymbol
|
|
{
|
|
_Jv_Utf8Const *class_name;
|
|
_Jv_Utf8Const *name;
|
|
_Jv_Utf8Const *signature;
|
|
};
|
|
|
|
struct _Jv_OffsetTable
|
|
{
|
|
jint state;
|
|
jint offsets[];
|
|
};
|
|
|
|
struct _Jv_AddressTable
|
|
{
|
|
jint state;
|
|
void *addresses[];
|
|
};
|
|
|
|
struct _Jv_CatchClass
|
|
{
|
|
java::lang::Class **address;
|
|
_Jv_Utf8Const *classname;
|
|
};
|
|
|
|
#define JV_PRIMITIVE_VTABLE ((_Jv_VTable *) -1)
|
|
|
|
#define JV_CLASS(Obj) ((jclass) (*(_Jv_VTable **) Obj)->clas)
|
|
|
|
class java::lang::Class : public java::lang::Object
|
|
{
|
|
public:
|
|
static jclass forName (jstring className, jboolean initialize,
|
|
java::lang::ClassLoader *loader);
|
|
static jclass forName (jstring className);
|
|
JArray<jclass> *getClasses (void);
|
|
|
|
java::lang::ClassLoader *getClassLoader (void);
|
|
|
|
// This is an internal method that circumvents the usual security
|
|
// checks when getting the class loader.
|
|
java::lang::ClassLoader *getClassLoaderInternal (void)
|
|
{
|
|
return loader;
|
|
}
|
|
|
|
java::lang::reflect::Constructor *getConstructor (JArray<jclass> *);
|
|
JArray<java::lang::reflect::Constructor *> *getConstructors (void);
|
|
java::lang::reflect::Constructor *getDeclaredConstructor (JArray<jclass> *);
|
|
JArray<java::lang::reflect::Constructor *> *getDeclaredConstructors (void);
|
|
java::lang::reflect::Field *getDeclaredField (jstring);
|
|
JArray<java::lang::reflect::Field *> *getDeclaredFields ();
|
|
JArray<java::lang::reflect::Field *> *getDeclaredFields (jboolean);
|
|
java::lang::reflect::Method *getDeclaredMethod (jstring, JArray<jclass> *);
|
|
JArray<java::lang::reflect::Method *> *getDeclaredMethods (void);
|
|
|
|
JArray<jclass> *getDeclaredClasses (void);
|
|
jclass getDeclaringClass (void);
|
|
|
|
java::lang::reflect::Field *getField (jstring);
|
|
private:
|
|
JArray<java::lang::reflect::Field *> internalGetFields ();
|
|
JArray<java::lang::reflect::Constructor *> *_getConstructors (jboolean);
|
|
java::lang::reflect::Field *getField (jstring, jint);
|
|
jint _getMethods (JArray<java::lang::reflect::Method *> *result,
|
|
jint offset);
|
|
java::lang::reflect::Field *getPrivateField (jstring);
|
|
java::lang::reflect::Method *getPrivateMethod (jstring, JArray<jclass> *);
|
|
java::security::ProtectionDomain *getProtectionDomain0 ();
|
|
|
|
java::lang::reflect::Method *_getMethod (jstring, JArray<jclass> *);
|
|
java::lang::reflect::Method *_getDeclaredMethod (jstring, JArray<jclass> *);
|
|
|
|
public:
|
|
JArray<java::lang::reflect::Field *> *getFields (void);
|
|
|
|
JArray<jclass> *getInterfaces (void);
|
|
|
|
void getSignature (java::lang::StringBuffer *buffer);
|
|
static jstring getSignature (JArray<jclass> *, jboolean is_constructor);
|
|
JArray<java::lang::reflect::Method *> *getMethods (void);
|
|
|
|
inline jint getModifiers (void)
|
|
{
|
|
return accflags & java::lang::reflect::Modifier::ALL_FLAGS;
|
|
}
|
|
|
|
jstring getName (void);
|
|
|
|
java::net::URL *getResource (jstring resourceName);
|
|
java::io::InputStream *getResourceAsStream (jstring resourceName);
|
|
JArray<jobject> *getSigners (void);
|
|
void setSigners(JArray<jobject> *);
|
|
|
|
inline jclass getSuperclass (void)
|
|
{
|
|
return superclass;
|
|
}
|
|
|
|
inline jboolean isArray (void)
|
|
{
|
|
return name->first() == '[';
|
|
}
|
|
|
|
inline jclass getComponentType (void)
|
|
{
|
|
return isArray () ? (* (jclass *) &methods) : 0;
|
|
}
|
|
|
|
jboolean isAssignableFrom (jclass cls);
|
|
jboolean isInstance (jobject obj);
|
|
|
|
inline jboolean isInterface (void)
|
|
{
|
|
return (accflags & java::lang::reflect::Modifier::INTERFACE) != 0;
|
|
}
|
|
|
|
inline jboolean isPrimitive (void)
|
|
{
|
|
return vtable == JV_PRIMITIVE_VTABLE;
|
|
}
|
|
|
|
jobject newInstance (void);
|
|
java::security::ProtectionDomain *getProtectionDomain (void);
|
|
java::lang::Package *getPackage (void);
|
|
jstring toString (void);
|
|
jboolean desiredAssertionStatus (void);
|
|
|
|
// FIXME: this probably shouldn't be public.
|
|
jint size (void)
|
|
{
|
|
return size_in_bytes;
|
|
}
|
|
|
|
// finalization
|
|
void finalize ();
|
|
|
|
// This constructor is used to create Class object for the primitive
|
|
// types. See prims.cc.
|
|
Class ();
|
|
|
|
static java::lang::Class class$;
|
|
|
|
private:
|
|
|
|
void memberAccessCheck (jint flags);
|
|
|
|
void initializeClass (void);
|
|
|
|
static jstring getPackagePortion (jstring);
|
|
|
|
// Friend functions implemented in natClass.cc.
|
|
friend _Jv_Method *_Jv_GetMethodLocal (jclass klass, _Jv_Utf8Const *name,
|
|
_Jv_Utf8Const *signature);
|
|
friend jboolean _Jv_IsAssignableFrom(jclass, jclass);
|
|
friend jboolean _Jv_InterfaceAssignableFrom (jclass, jclass);
|
|
friend void *_Jv_LookupInterfaceMethodIdx (jclass klass, jclass iface,
|
|
int method_idx);
|
|
|
|
inline friend void
|
|
_Jv_InitClass (jclass klass)
|
|
{
|
|
if (__builtin_expect (klass->state == JV_STATE_DONE, true))
|
|
return;
|
|
klass->initializeClass ();
|
|
}
|
|
|
|
friend _Jv_Method* _Jv_LookupDeclaredMethod (jclass, _Jv_Utf8Const *,
|
|
_Jv_Utf8Const*);
|
|
friend jfieldID JvGetFirstInstanceField (jclass);
|
|
friend jint JvNumInstanceFields (jclass);
|
|
friend jfieldID JvGetFirstStaticField (jclass);
|
|
friend jint JvNumStaticFields (jclass);
|
|
|
|
friend jobject _Jv_AllocObject (jclass);
|
|
friend void *_Jv_AllocObj (jint, jclass);
|
|
friend void *_Jv_AllocPtrFreeObj (jint, jclass);
|
|
friend void *_Jv_AllocArray (jint, jclass);
|
|
|
|
friend jobject _Jv_JNI_ToReflectedField (_Jv_JNIEnv *, jclass, jfieldID,
|
|
jboolean);
|
|
friend jobject _Jv_JNI_ToReflectedMethod (_Jv_JNIEnv *, jclass, jmethodID,
|
|
jboolean);
|
|
friend jfieldID _Jv_FromReflectedField (java::lang::reflect::Field *);
|
|
|
|
friend jmethodID _Jv_FromReflectedMethod (java::lang::reflect::Method *);
|
|
friend jmethodID _Jv_FromReflectedConstructor (java::lang::reflect::Constructor *);
|
|
friend jint JvNumMethods (jclass);
|
|
friend jmethodID JvGetFirstMethod (jclass);
|
|
|
|
// Friends classes and functions to implement the ClassLoader
|
|
friend class java::lang::ClassLoader;
|
|
friend class java::lang::VMClassLoader;
|
|
|
|
friend class java::io::ObjectOutputStream;
|
|
friend class java::io::ObjectInputStream;
|
|
friend class java::io::ObjectStreamClass;
|
|
|
|
friend void _Jv_WaitForState (jclass, int);
|
|
friend void _Jv_RegisterClasses (jclass *classes);
|
|
friend void _Jv_RegisterClassHookDefault (jclass klass);
|
|
friend void _Jv_RegisterInitiatingLoader (jclass,java::lang::ClassLoader*);
|
|
friend void _Jv_UnregisterClass (jclass);
|
|
friend jclass _Jv_FindClass (_Jv_Utf8Const *name,
|
|
java::lang::ClassLoader *loader);
|
|
friend jclass _Jv_FindClassInCache (_Jv_Utf8Const *name,
|
|
java::lang::ClassLoader *loader);
|
|
friend jclass _Jv_PopClass (void);
|
|
friend void _Jv_PushClass (jclass k);
|
|
friend void _Jv_NewArrayClass (jclass element,
|
|
java::lang::ClassLoader *loader,
|
|
_Jv_VTable *array_vtable = 0);
|
|
friend jclass _Jv_NewClass (_Jv_Utf8Const *name, jclass superclass,
|
|
java::lang::ClassLoader *loader);
|
|
friend void _Jv_InitNewClassFields (jclass klass);
|
|
|
|
// in prims.cc
|
|
friend void _Jv_InitPrimClass (jclass, char *, char, int);
|
|
|
|
friend void _Jv_PrepareCompiledClass (jclass);
|
|
friend void _Jv_PrepareConstantTimeTables (jclass);
|
|
friend jshort _Jv_GetInterfaces (jclass, _Jv_ifaces *);
|
|
friend void _Jv_GenerateITable (jclass, _Jv_ifaces *, jshort *);
|
|
friend jstring _Jv_GetMethodString(jclass, _Jv_Utf8Const *);
|
|
friend jshort _Jv_AppendPartialITable (jclass, jclass, void **, jshort);
|
|
friend jshort _Jv_FindIIndex (jclass *, jshort *, jshort);
|
|
friend void _Jv_LinkSymbolTable (jclass);
|
|
friend void _Jv_LayoutInterfaceMethods (jclass);
|
|
friend void _Jv_LayoutVTableMethods (jclass klass);
|
|
friend void _Jv_SetVTableEntries (jclass, _Jv_VTable *, jboolean *);
|
|
friend void _Jv_MakeVTable (jclass);
|
|
friend void _Jv_linkExceptionClassTable (jclass);
|
|
|
|
friend jboolean _Jv_CheckAccess (jclass self_klass, jclass other_klass,
|
|
jint flags);
|
|
|
|
// Return array class corresponding to element type KLASS, creating it if
|
|
// necessary.
|
|
inline friend jclass
|
|
_Jv_GetArrayClass (jclass klass, java::lang::ClassLoader *loader)
|
|
{
|
|
extern void _Jv_NewArrayClass (jclass element,
|
|
java::lang::ClassLoader *loader,
|
|
_Jv_VTable *array_vtable = 0);
|
|
if (__builtin_expect (!klass->arrayclass, false))
|
|
_Jv_NewArrayClass (klass, loader);
|
|
return klass->arrayclass;
|
|
}
|
|
|
|
#ifdef INTERPRETER
|
|
friend jboolean _Jv_IsInterpretedClass (jclass);
|
|
friend void _Jv_InitField (jobject, jclass, _Jv_Field*);
|
|
friend void _Jv_InitField (jobject, jclass, int);
|
|
friend _Jv_word _Jv_ResolvePoolEntry (jclass, int);
|
|
friend _Jv_Method *_Jv_SearchMethodInClass (jclass cls, jclass klass,
|
|
_Jv_Utf8Const *method_name,
|
|
_Jv_Utf8Const *method_signature);
|
|
|
|
friend void _Jv_PrepareClass (jclass);
|
|
friend void _Jv_PrepareMissingMethods (jclass base, jclass iface_class);
|
|
|
|
friend void _Jv_Defer_Resolution (void *cl, _Jv_Method *meth, void **);
|
|
|
|
friend class _Jv_ClassReader;
|
|
friend class _Jv_InterpClass;
|
|
friend class _Jv_InterpMethod;
|
|
#endif
|
|
|
|
#ifdef JV_MARKOBJ_DECL
|
|
friend JV_MARKOBJ_DECL;
|
|
#endif
|
|
|
|
friend class _Jv_BytecodeVerifier;
|
|
friend class _Jv_StackTrace;
|
|
friend class gnu::gcj::runtime::StackTrace;
|
|
friend class java::io::VMObjectStreamClass;
|
|
|
|
friend void _Jv_sharedlib_register_hook (jclass klass);
|
|
|
|
// Chain for class pool.
|
|
jclass next;
|
|
// Name of class.
|
|
_Jv_Utf8Const *name;
|
|
// Access flags for class.
|
|
_Jv_ushort accflags;
|
|
// The superclass, or null for Object.
|
|
jclass superclass;
|
|
// Class constants.
|
|
_Jv_Constants constants;
|
|
// Methods. If this is an array class, then this field holds a
|
|
// pointer to the element type.
|
|
_Jv_Method *methods;
|
|
// Number of methods. If this class is primitive, this holds the
|
|
// character used to represent this type in a signature.
|
|
jshort method_count;
|
|
// Number of methods in the vtable.
|
|
jshort vtable_method_count;
|
|
// The fields.
|
|
_Jv_Field *fields;
|
|
// Size of instance fields, in bytes.
|
|
jint size_in_bytes;
|
|
// Total number of fields (instance and static).
|
|
jshort field_count;
|
|
// Number of static fields.
|
|
jshort static_field_count;
|
|
// The vtbl for all objects of this class.
|
|
_Jv_VTable *vtable;
|
|
// Virtual method offset table.
|
|
_Jv_OffsetTable *otable;
|
|
// Offset table symbols.
|
|
_Jv_MethodSymbol *otable_syms;
|
|
_Jv_AddressTable *atable;
|
|
_Jv_MethodSymbol *atable_syms;
|
|
_Jv_CatchClass *catch_classes;
|
|
// Interfaces implemented by this class.
|
|
jclass *interfaces;
|
|
// The class loader for this class.
|
|
java::lang::ClassLoader *loader;
|
|
// Number of interfaces.
|
|
jshort interface_count;
|
|
// State of this class.
|
|
jbyte state;
|
|
// The thread which has locked this class. Used during class
|
|
// initialization.
|
|
java::lang::Thread *thread;
|
|
// How many levels of "extends" this class is removed from Object.
|
|
jshort depth;
|
|
// Vector of this class's superclasses, ordered by decreasing depth.
|
|
jclass *ancestors;
|
|
// Interface Dispatch Table.
|
|
_Jv_IDispatchTable *idt;
|
|
// Pointer to the class that represents an array of this class.
|
|
jclass arrayclass;
|
|
// Security Domain to which this class belongs (or null).
|
|
java::security::ProtectionDomain *protectionDomain;
|
|
// Signers of this class (or null).
|
|
JArray<jobject> *hack_signers;
|
|
// Used by Jv_PopClass and _Jv_PushClass to communicate with StackTrace.
|
|
jclass chain;
|
|
// Additional data, specific to the generator (JIT, native, interpreter) of this
|
|
// class.
|
|
void *aux_info;
|
|
};
|
|
|
|
#endif /* __JAVA_LANG_CLASS_H__ */
|