+2004-04-09 Ranjit Mathew <rmathew@hotmail.com>
+
+ * java/lang/VMThrowable.java (getStackTrace): Pass trace as-is to
+ modified lookup().
+ * gnu/gcj/runtime/NameFinder.java (lookup): Change to take in a
+ StackTraceElement directly.
+ (newElement): New native helper method to create StackTraceElement
+ bypassing Java access control.
+ (createStackTraceElement): Use newElement() instead of directly
+ calling StackTraceElement's constructor.
+ * gnu/gcj/runtime/natNameFinder.cc (newElement): New method.
+
2004-04-01 Michael Koch <konqueror@gmx.de>
* java/lang/SecurityManager.java
/* NameFinder.java -- Translates addresses to StackTraceElements.
- Copyright (C) 2002 Free Software Foundation, Inc.
+ Copyright (C) 2002, 2004 Free Software Foundation, Inc.
This file is part of libgcj.
* Given an Throwable and a native stacktrace returns an array of
* StackTraceElement containing class, method, file and linenumbers.
*/
- public StackTraceElement[] lookup(Throwable t, RawData addrs, int length)
+ public StackTraceElement[] lookup(Throwable t, StackTrace trace)
{
+ RawData addrs = trace.stackTraceAddrs();
+ int length = trace.length();
+
StackTraceElement[] elements = new StackTraceElement[length];
for (int i=0; i < length; i++)
elements[i] = lookup(addrs, i);
return stack;
}
+ /**
+ * Native helper method to create a StackTraceElement. Needed to work
+ * around normal Java access restrictions.
+ */
+ native private StackTraceElement newElement(String fileName,
+ int lineNumber,
+ String className,
+ String methName,
+ boolean isNative);
+
/**
* Creates a StackTraceElement given a string and a filename.
* Splits the given string into the class and method part.
private StackTraceElement createStackTraceElement(String name, String file)
{
if (!demangle)
- return new StackTraceElement(file, -1, null, name, false);
+ return newElement(file, -1, null, name, false);
String s = demangleName(name);
String methodName = s;
}
}
- return new StackTraceElement(fileName, line, className, methodName, false);
+ return newElement(fileName, line, className, methodName, false);
}
/**
// natNameFinder.cc - native helper methods for NameFinder.java
-/* Copyright (C) 2002, 2003 Free Software Foundation, Inc
+/* Copyright (C) 2002, 2003, 2004 Free Software Foundation, Inc
This file is part of libgcj.
#endif /* ! __USER_LABEL_PREFIX__ */
+java::lang::StackTraceElement*
+gnu::gcj::runtime::NameFinder::newElement (java::lang::String* fileName,
+ jint lineNumber,
+ java::lang::String* className,
+ java::lang::String* methName,
+ jboolean isNative)
+{
+ return new java::lang::StackTraceElement( fileName, lineNumber,
+ className, methName, isNative);
+}
+
java::lang::String*
gnu::gcj::runtime::NameFinder::getExternalLabel (java::lang::String* name)
{
/* java.lang.VMThrowable -- VM support methods for Throwable.
- Copyright (C) 1998, 1999, 2002 Free Software Foundation, Inc.
+ Copyright (C) 1998, 1999, 2002, 2004 Free Software Foundation, Inc.
This file is part of GNU Classpath.
if (trace != null)
{
NameFinder nameFinder = new NameFinder();
- result = nameFinder.lookup(t, trace.stackTraceAddrs(),
- trace.length());
+ result = nameFinder.lookup(t, trace);
nameFinder.close();
}
else