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"
/*
-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");
}
#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;
}
{
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");
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");
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);
}