summaryrefslogtreecommitdiffstats
path: root/libjava/java/lang/reflect/natMethod.cc
diff options
context:
space:
mode:
authortromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2000-03-02 20:25:20 +0000
committertromey <tromey@138bc75d-0d04-0410-961f-82ee72b054a4>2000-03-02 20:25:20 +0000
commita30cc9d9edb056cbd8673014456b6cfc3b03b3f7 (patch)
treedd49bb49b56ee51fa4bbd2a20cc08ae6eefa6306 /libjava/java/lang/reflect/natMethod.cc
parentd2e850c1ebd9bb4d8d5f9fed01bd3bce6a40130e (diff)
downloadppe42-gcc-a30cc9d9edb056cbd8673014456b6cfc3b03b3f7.tar.gz
ppe42-gcc-a30cc9d9edb056cbd8673014456b6cfc3b03b3f7.zip
* include/java-interp.h: Don't include MethodInvocation.h.
(class _Jv_InterpMethod): Don't make MethodInvocation a friend. * Makefile.in: Rebuilt. * Makefile.am (gnu/gcj/runtime/MethodInvocation.h): Removed. (ordinary_java_source_files): Don't mention MethodInvocation.java. * gnu/gcj/runtime/MethodInvocation.java: Removed. * interpret.cc (MethodInvocation::continue1): Removed. (run): Handle exceptions here. * java/lang/ClassLoader.java (defineClass1, defineClass2): Removed. * java/lang/natClassLoader.cc (defineClass0): Catch exceptions here. (defineClass2): Removed. * java/lang/reflect/Method.java (hack_trampoline, hack_call): Removed. * java/lang/reflect/natMethod.cc (_Jv_CallAnyMethodA): Catch exceptions here. (hack_call): Removed. * java/lang/Class.h (Class): Removed hackRunInitializers, hackTrampoline. * java/lang/natClass.cc (hackRunInitializers): Removed. (initializeClass): Catch exceptions here. Include ExceptionInInitializerError.h. * java/lang/Class.java (hackTrampoline, hackRunInitializers): Removed. * java/lang/Object.h (Object): Don't mention hack12_6. * java/lang/natObject.cc (_Jv_FinalizeObject): Catch exceptions here. * java/lang/Object.java (hack12_6): Removed. * java/lang/natThread.cc (run_): Renamed. Catch exceptions here. (start): Use run_, not run__. * java/lang/Thread.java (run_): Renamed from run__; old run_ removed. * jni.cc (_Jv_JNI_FindClass): Handle exceptions. (_Jv_JNI_EnsureLocalCapacity): Likewise. (_Jv_JNI_DefineClass): Likewise. (_Jv_JNI_ThrowNew): Likewise. (_Jv_JNI_AllocObject): Likewise. (_Jv_JNI_GetAnyMethodID): Likewise. (_Jv_JNI_CallAnyMethodV): Likewise. (_Jv_JNI_CallAnyMethodA): Likewise. (_Jv_JNI_CallAnyVoidMethodV): Likewise. (_Jv_JNI_CallAnyVoidMethodA): Likewise. (_Jv_JNI_GetAnyFieldID): Likewise. (_Jv_JNI_NewString): Likewise. (_Jv_JNI_NewStringUTF): Likewise. (_Jv_JNI_GetStringUTFChars): Likewise. (_Jv_JNI_NewObjectArray): Likewise. (_Jv_JNI_NewPrimitiveArray): Likewise. (_Jv_JNI_GetPrimitiveArrayRegion): Likewise. (_Jv_JNI_GetStringRegion): Likewise. (_Jv_JNI_GetStringUTFRegion): Likewise. (_Jv_JNI_SetPrimitiveArrayRegion): Likewise. (_Jv_JNI_MonitorEnter): Likewise. (_Jv_JNI_MonitorExit): Likewise. (_Jv_JNI_ToReflectedField): Likewise. (_Jv_JNI_ToReflectedMethod): Likewise. (_Jv_JNI_RegisterNatives): Likewise. (_Jv_JNI_AttachCurrentThread): Likewise. (_Jv_JNI_DestroyJavaVM): Likewise. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@32294 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libjava/java/lang/reflect/natMethod.cc')
-rw-r--r--libjava/java/lang/reflect/natMethod.cc39
1 files changed, 14 insertions, 25 deletions
diff --git a/libjava/java/lang/reflect/natMethod.cc b/libjava/java/lang/reflect/natMethod.cc
index 988fa1e00fb..c4482ee7933 100644
--- a/libjava/java/lang/reflect/natMethod.cc
+++ b/libjava/java/lang/reflect/natMethod.cc
@@ -152,21 +152,6 @@ get_ffi_type (jclass klass)
return r;
}
-// Actually perform an FFI call.
-void
-java::lang::reflect::Method::hack_call (gnu::gcj::RawData *rcif,
- gnu::gcj::RawData *rmethod,
- gnu::gcj::RawData *rret_value,
- gnu::gcj::RawData *rvalues)
-{
- ffi_cif *cif = (ffi_cif *) rcif;
- void (*method) (...) = (void (*) (...)) rmethod;
- void *ret_value = (void *) rret_value;
- void **values = (void **) rvalues;
-
- ffi_call (cif, method, ret_value, values);
-}
-
jobject
java::lang::reflect::Method::invoke (jobject obj, jobjectArray args)
{
@@ -419,19 +404,23 @@ _Jv_CallAnyMethodA (jobject obj,
// FIXME: initialize class here.
- java::lang::Throwable *ex;
using namespace java::lang;
using namespace java::lang::reflect;
- ex = Method::hack_trampoline ((gnu::gcj::RawData *) &cif,
- (gnu::gcj::RawData *) meth->ncode,
- (gnu::gcj::RawData *) result,
- (gnu::gcj::RawData *) values);
- if (ex)
- // FIXME: this is wrong for JNI. But if we just return the
- // exception, then the non-JNI cases won't be able to distinguish
- // it from exceptions we might generate ourselves. Sigh.
- ex = new InvocationTargetException (ex);
+ Throwable *ex = NULL;
+
+ try
+ {
+ ffi_call (&cif, (void (*) (...)) meth->ncode, result, values);
+ }
+ catch (Throwable *ex2)
+ {
+ // FIXME: this is wrong for JNI. But if we just return the
+ // exception, then the non-JNI cases won't be able to
+ // distinguish it from exceptions we might generate ourselves.
+ // Sigh.
+ ex = new InvocationTargetException (ex2);
+ }
if (is_constructor)
result->l = obj;
OpenPOWER on IntegriCloud