diff --git a/libjava/ChangeLog b/libjava/ChangeLog index 3513b273f6e..a9ce3528f8c 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,10 @@ +2001-12-21 Tom Tromey + + Fix for PR libgcj/2428: + * java/lang/natClass.cc: Include RuntimePermission.h. + (getClassLoader): Define. + * java/lang/Class.h (Class.getClassLoader): Only declare. + 2001-12-19 Tom Tromey * java/awt/FlowLayout.java (FlowLayout(), FlowLayout(int)): Set diff --git a/libjava/java/lang/Class.h b/libjava/java/lang/Class.h index 73d81daad16..0f36f25eacf 100644 --- a/libjava/java/lang/Class.h +++ b/libjava/java/lang/Class.h @@ -134,10 +134,7 @@ public: static jclass forName (jstring className); JArray *getClasses (void); - java::lang::ClassLoader *getClassLoader (void) - { - return loader; - } + java::lang::ClassLoader *getClassLoader (void); java::lang::reflect::Constructor *getConstructor (JArray *); JArray *getConstructors (void); diff --git a/libjava/java/lang/natClass.cc b/libjava/java/lang/natClass.cc index 6dfe14bab71..0e34f323eb4 100644 --- a/libjava/java/lang/natClass.cc +++ b/libjava/java/lang/natClass.cc @@ -43,6 +43,7 @@ details. */ #include #include #include +#include #include #include #include @@ -102,6 +103,29 @@ java::lang::Class::forName (jstring className) return forName (className, true, NULL); } +java::lang::ClassLoader * +java::lang::Class::getClassLoader (void) +{ +#if 0 + // FIXME: the checks we need to do are more complex. See the spec. + // Currently we can't implement them. + java::lang::SecurityManager *s = java::lang::System::getSecurityManager(); + if (s != NULL) + s->checkPermission (new RuntimePermission (JvNewStringLatin1 ("getClassLoader"))); +#endif + + // The spec requires us to return `null' for primitive classes. In + // other cases we have the option of returning `null' for classes + // loaded with the bootstrap loader. All gcj-compiled classes which + // are linked into the application used to return `null' here, but + // that confuses some poorly-written applications. It is a useful + // and apparently harmless compatibility hack to simply never return + // `null' instead. + if (isPrimitive ()) + return NULL; + return loader ? loader : ClassLoader::getSystemClassLoader (); +} + java::lang::reflect::Constructor * java::lang::Class::getConstructor (JArray *param_types) { @@ -373,6 +397,8 @@ java::lang::Class::getName (void) JArray * java::lang::Class::getClasses (void) { + // FIXME: security checking. + // Until we have inner classes, it always makes sense to return an // empty array. JArray *result @@ -440,6 +466,8 @@ java::lang::Class::_getFields (JArray *result, JArray * java::lang::Class::getFields (void) { + // FIXME: security checking. + using namespace java::lang::reflect; int count = _getFields (NULL, 0);