Add Interface Test
[cacao.git] / nat / VMThrowable.c
index 15693326fe1d90502ba59190807dd9ce049ffd7f..41e68b69f513c8b3d4898a55620ea08dea7c5992 100644 (file)
@@ -26,7 +26,7 @@
 
    Authors: Joseph Wenninger
 
-   $Id: VMThrowable.c 973 2004-03-25 15:19:16Z twisti $
+   $Id: VMThrowable.c 1448 2004-11-05 14:06:38Z twisti $
 
 */
 
 #include "builtin.h"
 #include "tables.h"
 #include "native.h"
-#include "java_lang_Throwable.h"
-#include "java_lang_VMThrowable.h"
+#include "nat/java_lang_Class.h"
+#include "nat/java_lang_Throwable.h"
+#include "nat/java_lang_VMClass.h"
+#include "nat/java_lang_VMThrowable.h"
 
 
 /*
@@ -74,34 +76,46 @@ JNIEXPORT java_lang_VMThrowable* JNICALL Java_java_lang_VMThrowable_fillInStackT
 
 
 
-java_objectarray* generateStackTraceArray(JNIEnv *env,stacktraceelement *source,long size)
+java_objectarray* generateStackTraceArray(JNIEnv *env,stacktraceelement *source,long pos,long size)
 {
        long resultPos;
-       methodinfo *constructor;
-       classinfo *class_stacktraceelement;
-       java_objectarray *array_stacktraceelement;
-       class_stacktraceelement = (classinfo *) loader_load(utf_new_char ("java/lang/StackTraceElement"));
+       methodinfo *m;
+       classinfo *c;
+       java_objectarray *oa;
 
-       if (!class_stacktraceelement)
-               return 0;
+       c = class_new(utf_new_char("java/lang/StackTraceElement"));
+
+       if (!c->loaded)
+               class_load(c);
+
+       if (!c->linked)
+               class_link(c);
 
+       m = class_findmethod(c,
+                                                utf_new_char("<init>"),
+                                                utf_new_char("(Ljava/lang/String;ILjava/lang/String;Ljava/lang/String;Z)V"));
 
-       constructor=class_findmethod(class_stacktraceelement,utf_new_char("<init>"),
-               utf_new_char("(Ljava/lang/String;ILjava/lang/String;Ljava/lang/String;Z)V"));
-       if (!constructor)
+       if (!m)
                panic("java.lang.StackTraceElement misses needed constructor"); 
 
-       array_stacktraceelement = builtin_anewarray(size, class_stacktraceelement);
+       oa = builtin_anewarray(size, c);
 
-       if (!array_stacktraceelement)
-                return 0;
+       if (!oa)
+               return 0;
 
 /*     printf("Should return an array with %ld element(s)\n",size);*/
-       size--;
+       pos--;
        
        
-       for(resultPos=0;size>=0;resultPos++,size--) {
-               java_objectheader *element=builtin_new(class_stacktraceelement);
+       for(resultPos=0;pos>=0;resultPos++,pos--) {
+               java_objectheader *element;
+
+               if (source[pos].method==0) {
+                       resultPos--;
+                       continue;
+               }
+
+               element=builtin_new(c);
                if (!element) {
                        panic("Memory for stack trace element could not be allocated");
                }
@@ -109,32 +123,34 @@ java_objectarray* generateStackTraceArray(JNIEnv *env,stacktraceelement *source,
 #warning call constructor once jni is fixed to allow more than three parameters
 #endif
 #if 0
-               (*env)->CallVoidMethod(env,element,constructor,
-                       javastring_new(source[size].method->class->sourcefile),
+               (*env)->CallVoidMethod(env,element,m,
+                       javastring_new(source[pos].method->class->sourcefile),
                        source[size].linenumber,
-                       javastring_new(source[size].method->class->name),
-                       javastring_new(source[size].method->name),
-                       source[size].method->flags & ACC_NATIVE);
+                       javastring_new(source[pos].method->class->name),
+                       javastring_new(source[pos].method->name),
+                       source[pos].method->flags & ACC_NATIVE);
 #else
-               if (!(source[size].method->flags & ACC_NATIVE))setfield_critical(class_stacktraceelement,element,"fileName",          
+               if (!(source[pos].method->flags & ACC_NATIVE))setfield_critical(c,element,"fileName",          
                "Ljava/lang/String;",  jobject, 
-               (jobject) javastring_new(source[size].method->class->sourcefile));
-               setfield_critical(class_stacktraceelement,element,"className",          "Ljava/lang/String;",  jobject, 
-               (jobject) javastring_new(source[size].method->class->name));
-               setfield_critical(class_stacktraceelement,element,"methodName",          "Ljava/lang/String;",  jobject, 
-               (jobject) javastring_new(source[size].method->name));
-               setfield_critical(class_stacktraceelement,element,"lineNumber",          "I",  jint, 
-               (jint) ((source[size].method->flags & ACC_NATIVE) ? -1:(source[size].linenumber)));
-               setfield_critical(class_stacktraceelement,element,"isNative",          "Z",  jboolean, 
-               (jboolean) ((source[size].method->flags & ACC_NATIVE) ? 1:0));
+               (jobject) javastring_new(source[pos].method->class->sourcefile));
+/*             setfield_critical(c,element,"className",          "Ljava/lang/String;",  jobject,  */
+/*             (jobject) javastring_new(source[pos].method->class->name)); */
+               setfield_critical(c,element,"className",          "Ljava/lang/String;",  jobject, 
+               (jobject) Java_java_lang_VMClass_getName(env, NULL, (java_lang_Class *) source[pos].method->class));
+               setfield_critical(c,element,"methodName",          "Ljava/lang/String;",  jobject, 
+               (jobject) javastring_new(source[pos].method->name));
+               setfield_critical(c,element,"lineNumber",          "I",  jint, 
+               (jint) ((source[pos].method->flags & ACC_NATIVE) ? -1:(source[pos].linenumber)));
+               setfield_critical(c,element,"isNative",          "Z",  jboolean, 
+               (jboolean) ((source[pos].method->flags & ACC_NATIVE) ? 1:0));
 
 
 #endif                 
 
-               array_stacktraceelement->data[resultPos]=element;
+               oa->data[resultPos]=element;
        }
 
-       return array_stacktraceelement;
+       return oa;
 
 }
 
@@ -148,6 +164,7 @@ JNIEXPORT java_objectarray* JNICALL Java_java_lang_VMThrowable_getStackTrace(JNI
 {
        long  pos;
        long  maxpos;
+       long  sizediff;
        utf*  classname=par1->header.vftbl->class->name;
        utf*  init=utf_new_char("<init>");
        utf*  throwable=utf_new_char("java/lang/Throwable");
@@ -157,11 +174,14 @@ JNIEXPORT java_objectarray* JNICALL Java_java_lang_VMThrowable_getStackTrace(JNI
        utf_display(par1->header.vftbl->class->name);
        printf("\n----------------------------------------------\n");*/
 
+       sizediff=0;
        if (el == 0) {
-               return generateStackTraceArray(env, el, 0);
+               return generateStackTraceArray(env, el, 0,0);
        }       
 
-       for (pos = 0; el[pos].method != 0; pos++);
+       for (pos = 0; !((el[pos].method == 0) && (el[pos].linenumber ==-1)); pos++) {
+               if (el[pos].method==0) sizediff++;
+       }
 
        if (pos == 0) {
                panic("Stacktrace cannot have zero length");
@@ -170,18 +190,28 @@ JNIEXPORT java_objectarray* JNICALL Java_java_lang_VMThrowable_getStackTrace(JNI
        pos--;
        pos--;
        maxpos = pos;
-       if (el[pos].method->class->name == throwable && el[pos].method->name == init) {
-               for (; pos >= 0 && el[pos].method->name == init && el[pos].method->class->name != classname; pos--);
-               pos--;
-               if (pos < 0) {
-                       panic("Invalid stack trace for Throwable.getStackTrace()");
+       if (el[pos].method!=0) { /* if == 0 -> some builtin native */
+               if (el[pos].method->class->name == throwable && el[pos].method->name == init) {
+                       for (; pos >= 0 && el[pos].method->name == init && el[pos].method->class->name != classname; pos--) {
+/*                             log_text("ignoring:");
+                               utf_display(el[pos].method->name);
+                               log_text("");
+                               utf_display(el[pos].method->class->name);
+                               log_text("");*/
+
+                       };
+                       pos--;
+                       if (pos < 0) {
+                               log_text("Invalid stack trace for Throwable.getStackTrace()");
+
+                       }
                }
        }
        
        /* build the result array*/
        pos++; /*arraysize*/
 
-       return generateStackTraceArray(env,el,pos);     
+       return generateStackTraceArray(env,el,pos,pos-sizediff);        
 }