* Updated header: Added 2006. Changed address of FSF. Changed email
[cacao.git] / src / native / vm / VMThrowable.c
index c512b6a7275f8275edb8302754dc65cbb93b22ba..e15ee36aca7771164b296e5fead27043798ffede 100644 (file)
@@ -1,9 +1,9 @@
 /* src/native/vm/VMThrowable.c - java/lang/VMThrowable
 
-   Copyright (C) 1996-2005 R. Grafl, A. Krall, C. Kruegel, C. Oates,
-   R. Obermaisser, M. Platter, M. Probst, S. Ring, E. Steiner,
-   C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich, J. Wenninger,
-   Institut f. Computersprachen - TU Wien
+   Copyright (C) 1996-2005, 2006 R. Grafl, A. Krall, C. Kruegel,
+   C. Oates, R. Obermaisser, M. Platter, M. Probst, S. Ring,
+   E. Steiner, C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich,
+   J. Wenninger, Institut f. Computersprachen - TU Wien
 
    This file is part of CACAO.
 
 
    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
-   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
-   02111-1307, USA.
+   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+   02110-1301, USA.
 
-   Contact: cacao@complang.tuwien.ac.at
+   Contact: cacao@cacaojvm.org
 
    Authors: Joseph Wenninger
 
    Changes: Christian Thalinger
 
-   $Id: VMThrowable.c 2945 2005-07-09 12:16:18Z twisti $
+   $Id: VMThrowable.c 4357 2006-01-22 23:33:38Z twisti $
 
 */
 
 
 #include <assert.h>
 
+#include "config.h"
+#include "vm/types.h"
+
 #include "native/jni.h"
 #include "native/native.h"
 #include "native/include/java_lang_Class.h"
+#include "native/include/java_lang_StackTraceElement.h"
 #include "native/include/java_lang_Throwable.h"
 #include "native/include/java_lang_VMClass.h"
 #include "native/include/java_lang_VMThrowable.h"
 #include "vm/builtin.h"
 #include "vm/class.h"
+#include "vm/exceptions.h"
 #include "vm/loader.h"
 #include "vm/stringlocal.h"
-#include "vm/tables.h"
-#include "vm/jit/asmpart.h"
 #include "vm/jit/stacktrace.h"
-#include "vm/exceptions.h"
 
 
 /*
@@ -60,11 +62,6 @@ JNIEXPORT java_lang_VMThrowable* JNICALL Java_java_lang_VMThrowable_fillInStackT
 {
        java_lang_VMThrowable *vmthrow;
 
-       if ((*dontfillinexceptionstacktrace) == true) {
-               /*log_text("dontfillinexceptionstacktrace");*/
-               return 0;
-       }
-
        vmthrow = (java_lang_VMThrowable *)
                native_new_and_init(class_java_lang_VMThrowable);
 
@@ -73,104 +70,12 @@ JNIEXPORT java_lang_VMThrowable* JNICALL Java_java_lang_VMThrowable_fillInStackT
                assert(0);
        }
 
-#if defined(__ALPHA__) || defined(__I386__) || defined(__POWERPC__) || defined(__X86_64__)
-       cacao_stacktrace_NormalTrace((void **) &(vmthrow->vmData));
+#if defined(__ALPHA__) || defined(__ARM__) || defined(__I386__) || defined(__MIPS__) || defined(__POWERPC__) || defined(__X86_64__)
+       if (!cacao_stacktrace_NormalTrace((void **) &(vmthrow->vmData)))
+               return NULL;
 #endif
-       return vmthrow;
-}
-
-
-static java_objectarray *generateStackTraceArray(JNIEnv *env,stacktraceelement *el, s4 size)
-{
-       long resultPos;
-       methodinfo *m;
-       java_objectarray *oa;
-
-       m = class_findmethod(class_java_lang_StackTraceElement,
-                                                utf_init,
-                                                utf_new_char("(Ljava/lang/String;ILjava/lang/String;Ljava/lang/String;Z)V"));
-
-       if (!m) {
-               log_text("java.lang.StackTraceElement misses needed constructor");      
-               assert(0);
-       }
 
-       oa = builtin_anewarray(size, class_java_lang_StackTraceElement);
-
-       if (!oa)
-               return 0;
-
-/*     printf("Should return an array with %ld element(s)\n",size);*/
-       /*pos--;*/
-       
-       for(resultPos = 0; size > 0; size--, el++, resultPos++) {
-               java_objectheader *element;
-
-               if (el->method == NULL) {
-                       resultPos--;
-                       continue;
-               }
-
-               element = builtin_new(class_java_lang_StackTraceElement);
-               if (!element) {
-                       log_text("Memory for stack trace element could not be allocated");
-                       assert(0);
-               }
-
-               /* XXX call constructor once jni is fixed to allow more than three parameters */
-
-#if 0
-               (*env)->CallVoidMethod(env,element,m,
-                       javastring_new(el->method->class->sourcefile),
-                       source[size].linenumber,
-                       javastring_new(el->method->class->name),
-                       javastring_new(el->method->name),
-                       el->method->flags & ACC_NATIVE);
-#else
-               if (!(el->method->flags & ACC_NATIVE))
-                       setfield_critical(class_java_lang_StackTraceElement,
-                                                         element,
-                                                         "fileName",
-                                                         "Ljava/lang/String;",
-                                                         jobject,
-                                                         (jobject) javastring_new(el->method->class->sourcefile));
-
-/*             setfield_critical(c,element,"className",          "Ljava/lang/String;",  jobject,  */
-/*             (jobject) javastring_new(el->method->class->name)); */
-
-               setfield_critical(class_java_lang_StackTraceElement,
-                                                 element,
-                                                 "declaringClass",
-                                                 "Ljava/lang/String;",
-                                                 jobject, 
-                                                 (jobject) Java_java_lang_VMClass_getName(env, NULL, (java_lang_Class *) el->method->class));
-
-               setfield_critical(class_java_lang_StackTraceElement,
-                                                 element,
-                                                 "methodName",
-                                                 "Ljava/lang/String;",
-                                                 jobject,
-                                                 (jobject) javastring_new(el->method->name));
-
-               setfield_critical(class_java_lang_StackTraceElement,
-                                                 element,
-                                                 "lineNumber",
-                                                 "I",
-                                                 jint, 
-                                                 (jint) ((el->method->flags & ACC_NATIVE) ? -1 : (el->linenumber)));
-
-               setfield_critical(class_java_lang_StackTraceElement,
-                                                 element,
-                                                 "isNative",
-                                                 "Z",
-                                                 jboolean, 
-                                                 (jboolean) ((el->method->flags & ACC_NATIVE) ? 1 : 0));
-#endif                 
-
-               oa->data[resultPos] = element;
-       }
-
-       return oa;
+       return vmthrow;
 }
 
 
@@ -181,15 +86,23 @@ static java_objectarray *generateStackTraceArray(JNIEnv *env,stacktraceelement *
  */
 JNIEXPORT java_objectarray* JNICALL Java_java_lang_VMThrowable_getStackTrace(JNIEnv *env, java_lang_VMThrowable *this, java_lang_Throwable *t)
 {
-#if defined(__ALPHA__) || defined(__I386__) || defined(__POWERPC__) || defined(__X86_64__)
-       stackTraceBuffer  *buf;
-       stacktraceelement *elem;
-       stacktraceelement *tmpelem;
-       u8                 size;
-       s4                 elemcount;
-       classinfo         *c;
-       bool               inexceptionclass;
-       bool               leftexceptionclass;
+#if defined(__ALPHA__) || defined(__ARM__) || defined(__I386__) || defined(__MIPS__) || defined(__POWERPC__) || defined(__X86_64__)
+       stackTraceBuffer            *buf;
+       stacktraceelement           *elem;
+       stacktraceelement           *tmpelem;
+       s4                           size;
+       s4                           i;
+       classinfo                   *c;
+       bool                         inexceptionclass;
+       bool                         leftexceptionclass;
+
+       methodinfo                  *m;
+       java_objectarray            *oa;
+       s4                           oalength;
+       java_lang_StackTraceElement *ste;
+       java_lang_String            *filename;
+       s4                           linenumber;
+       java_lang_String            *declaringclass;
 
        buf = (stackTraceBuffer *) this->vmData;
        c = t->header.vftbl->class;
@@ -248,15 +161,82 @@ JNIEXPORT java_objectarray* JNICALL Java_java_lang_VMThrowable_getStackTrace(JNI
                        }
                }
        }
-       
-       for (elemcount = 0, tmpelem = elem; size > 0; size--, tmpelem++) {
+
+
+       /* now fill the stacktrace into java objects */
+
+       m = class_findmethod(class_java_lang_StackTraceElement,
+                                                utf_init,
+                                                utf_new_char("(Ljava/lang/String;ILjava/lang/String;Ljava/lang/String;Z)V"));
+
+       if (!m)
+               return NULL;
+
+       /* count entries with a method name */
+
+       for (oalength = 0, i = size, tmpelem = elem; i > 0; i--, tmpelem++)
                if (tmpelem->method)
-                       elemcount++;
+                       oalength++;
+
+       /* create the stacktrace element array */
+
+       oa = builtin_anewarray(oalength, class_java_lang_StackTraceElement);
+
+       if (!oa)
+               return NULL;
+
+       for (i = 0; size > 0; size--, elem++, i++) {
+               if (elem->method == NULL) {
+                       i--;
+                       continue;
+               }
+
+               /* allocate a new stacktrace element */
+
+               ste = (java_lang_StackTraceElement *)
+                       builtin_new(class_java_lang_StackTraceElement);
+
+               if (!ste)
+                       return NULL;
+
+               /* get filename */
+
+               if (!(elem->method->flags & ACC_NATIVE)) {
+                       if (elem->method->class->sourcefile)
+                               filename = javastring_new(elem->method->class->sourcefile);
+                       else
+                               filename = NULL;
+
+               } else {
+                       filename = NULL;
+               }
+
+               /* get line number */
+
+               if (elem->method->flags & ACC_NATIVE)
+                       linenumber = -1;
+               else
+                       linenumber = (elem->linenumber == 0) ? -1 : elem->linenumber;
+
+               /* get declaring class name */
+
+               declaringclass = Java_java_lang_VMClass_getName(env, NULL, (java_lang_Class *) elem->method->class);
+
+
+               /* fill the stacktrace element */
+
+               ste->fileName       = filename;
+               ste->lineNumber     = linenumber;
+               ste->declaringClass = declaringclass;
+               ste->methodName     = javastring_new(elem->method->name);
+               ste->isNative       = (elem->method->flags & ACC_NATIVE) ? 1 : 0;
+
+               oa->data[i] = (java_objectheader *) ste;
        }
 
-       return generateStackTraceArray(env, elem, elemcount);
+       return oa;
 #else
-       return 0;
+       return NULL;
 #endif
 }