diff options
author | Tom Tromey <tromey@redhat.com> | 2002-09-03 21:33:46 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2002-09-03 21:33:46 +0000 |
commit | f4701961145138742997ead9600196211450c9d9 (patch) | |
tree | b89c68832aa1f41f6cad7d80d73b8ae5813779c8 /libjava | |
parent | 57016b4723d40263c4765d0c94ab20a0e3c2335f (diff) | |
download | gcc-f4701961145138742997ead9600196211450c9d9.zip gcc-f4701961145138742997ead9600196211450c9d9.tar.gz gcc-f4701961145138742997ead9600196211450c9d9.tar.bz2 |
Class.h (_getDeclaredMethod): Declare.
* java/lang/Class.h (_getDeclaredMethod): Declare.
(_getMethod): Now private.
* java/lang/natClass.cc (_getDeclaredMethod): Renamed from
getDeclaredMethod. Now returns NULL on failure.
* java/lang/Class.java (_getDeclaredMethod): Declare.
(getDeclaredMethod): No longer native; implements access checks.
From-SVN: r56772
Diffstat (limited to 'libjava')
-rw-r--r-- | libjava/ChangeLog | 9 | ||||
-rw-r--r-- | libjava/java/lang/Class.h | 4 | ||||
-rw-r--r-- | libjava/java/lang/Class.java | 28 | ||||
-rw-r--r-- | libjava/java/lang/natClass.cc | 7 |
4 files changed, 40 insertions, 8 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog index dabee51..22c7ddb 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,12 @@ +2002-09-03 Tom Tromey <tromey@redhat.com> + + * java/lang/Class.h (_getDeclaredMethod): Declare. + (_getMethod): Now private. + * java/lang/natClass.cc (_getDeclaredMethod): Renamed from + getDeclaredMethod. Now returns NULL on failure. + * java/lang/Class.java (_getDeclaredMethod): Declare. + (getDeclaredMethod): No longer native; implements access checks. + 2002-09-01 Mark Wielaard <mark@klomp.org> * gnu/gcj/runtime/NameFinder.java (remove_interpreter): New field. diff --git a/libjava/java/lang/Class.h b/libjava/java/lang/Class.h index 253aa64..9a8d418 100644 --- a/libjava/java/lang/Class.h +++ b/libjava/java/lang/Class.h @@ -160,6 +160,9 @@ private: 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); @@ -167,7 +170,6 @@ public: void getSignature (java::lang::StringBuffer *buffer); static jstring getSignature (JArray<jclass> *, jboolean is_constructor); - java::lang::reflect::Method *_getMethod (jstring, JArray<jclass> *); JArray<java::lang::reflect::Method *> *getMethods (void); inline jint getModifiers (void) diff --git a/libjava/java/lang/Class.java b/libjava/java/lang/Class.java index 12306da..cc1cc40 100644 --- a/libjava/java/lang/Class.java +++ b/libjava/java/lang/Class.java @@ -65,9 +65,31 @@ public final class Class implements Serializable public native Field getDeclaredField (String fieldName) throws NoSuchFieldException, SecurityException; public native Field[] getDeclaredFields () throws SecurityException; - public native Method getDeclaredMethod (String methodName, - Class[] parameterTypes) - throws NoSuchMethodException, SecurityException; + + private native Method _getDeclaredMethod (String methodName, + Class[] parameterTypes); + + public Method getDeclaredMethod (String methodName, Class[] parameterTypes) + throws NoSuchMethodException, SecurityException + { + SecurityManager sm = System.getSecurityManager(); + if (sm != null) + { + sm.checkMemberAccess(this, Member.DECLARED); + Package p = getPackage(); + if (p != null) + sm.checkPackageAccess(p.getName()); + } + + if ("<init>".equals(methodName) || "<clinit>".equals(methodName)) + throw new NoSuchMethodException(methodName); + + Method m = _getDeclaredMethod(methodName, parameterTypes); + if (m == null) + throw new NoSuchMethodException (methodName); + return m; + } + public native Method[] getDeclaredMethods () throws SecurityException; // This is marked as unimplemented in the JCL book. diff --git a/libjava/java/lang/natClass.cc b/libjava/java/lang/natClass.cc index 43b79ad..fca0741 100644 --- a/libjava/java/lang/natClass.cc +++ b/libjava/java/lang/natClass.cc @@ -315,8 +315,8 @@ java::lang::Class::getSignature (JArray<jclass> *param_types, } java::lang::reflect::Method * -java::lang::Class::getDeclaredMethod (jstring name, - JArray<jclass> *param_types) +java::lang::Class::_getDeclaredMethod (jstring name, + JArray<jclass> *param_types) { jstring partial_sig = getSignature (param_types, false); jint p_len = partial_sig->length(); @@ -324,7 +324,6 @@ java::lang::Class::getDeclaredMethod (jstring name, int i = isPrimitive () ? 0 : method_count; while (--i >= 0) { - // FIXME: access checks. if (_Jv_equalUtf8Consts (methods[i].name, utf_name) && _Jv_equaln (methods[i].signature, partial_sig, p_len)) { @@ -336,7 +335,7 @@ java::lang::Class::getDeclaredMethod (jstring name, return rmethod; } } - throw new java::lang::NoSuchMethodException; + return NULL; } JArray<java::lang::reflect::Method *> * |