diff options
author | Tom Tromey <tromey@redhat.com> | 2005-04-05 22:26:26 +0000 |
---|---|---|
committer | Tom Tromey <tromey@gcc.gnu.org> | 2005-04-05 22:26:26 +0000 |
commit | 8b6e76905300f33b868a3619d416cc9285cbfee1 (patch) | |
tree | 2e7ab5655ae0f92acaf1825446f2fec39bb2a56e /libjava/java/lang/reflect/natMethod.cc | |
parent | 13148dd26aafe25ef31d5303f6383d464cc8db61 (diff) | |
download | gcc-8b6e76905300f33b868a3619d416cc9285cbfee1.tar.gz |
jni.cc (_Jv_JNI_GetAnyFieldID): Throw ClassNotFoundException.
* jni.cc (_Jv_JNI_GetAnyFieldID): Throw ClassNotFoundException.
* java/lang/reflect/natMethod.cc (_Jv_GetTypesFromSignature):
Rewrote to use _Jv_FindClassFromSignature.
* verify.cc (resolve): throw NoClassDefFoundError.
* link.cc (resolve_field): Throw NoClassDefFoundError.
(find_field): Likewise.
* prims.cc (_Jv_FindClassFromSignature): Removed recursion.
Handle error cases. Added 'endp' argument.
* include/jvm.h (_Jv_FindClassFromSignature): Updated prototype.
From-SVN: r97660
Diffstat (limited to 'libjava/java/lang/reflect/natMethod.cc')
-rw-r--r-- | libjava/java/lang/reflect/natMethod.cc | 43 |
1 files changed, 14 insertions, 29 deletions
diff --git a/libjava/java/lang/reflect/natMethod.cc b/libjava/java/lang/reflect/natMethod.cc index 4329443146c..b616d1bab63 100644 --- a/libjava/java/lang/reflect/natMethod.cc +++ b/libjava/java/lang/reflect/natMethod.cc @@ -38,6 +38,7 @@ details. */ #include <java/lang/Class.h> #include <gcj/method.h> #include <gnu/gcj/RawData.h> +#include <java/lang/NoClassDefFoundError.h> #include <stdlib.h> @@ -235,6 +236,8 @@ _Jv_GetTypesFromSignature (jmethodID method, char *ptr = sig->chars(); int numArgs = 0; /* First just count the number of parameters. */ + // FIXME: should do some validation here, e.g., that there is only + // one return type. for (; ; ptr++) { switch (*ptr) @@ -271,44 +274,26 @@ _Jv_GetTypesFromSignature (jmethodID method, jclass* argPtr = elements (args); for (ptr = sig->chars(); *ptr != '\0'; ptr++) { - int num_arrays = 0; - jclass type; - for (; *ptr == '['; ptr++) - num_arrays++; - switch (*ptr) + if (*ptr == '(') + continue; + if (*ptr == ')') { - default: - return; - case ')': argPtr = return_type_out; continue; - case '(': - continue; - case 'V': - case 'B': - case 'C': - case 'D': - case 'F': - case 'S': - case 'I': - case 'J': - case 'Z': - type = _Jv_FindClassFromSignature(ptr, loader); - break; - case 'L': - type = _Jv_FindClassFromSignature(ptr, loader); - do - ptr++; - while (*ptr != ';' && ptr[1] != '\0'); - break; } - while (--num_arrays >= 0) - type = _Jv_GetArrayClass (type, loader); + char *end_ptr; + jclass type = _Jv_FindClassFromSignature (ptr, loader, &end_ptr); + if (type == NULL) + // FIXME: This isn't ideal. + throw new java::lang::NoClassDefFoundError (sig->toString()); + // ARGPTR can be NULL if we are processing the return value of a // call from Constructor. if (argPtr) *argPtr++ = type; + + ptr = end_ptr; } *arg_types_out = args; } |