flesh out classpath enough to test threading; fix indexing bug in parsePool()

This commit is contained in:
Joel Dice 2007-07-04 16:27:08 -06:00
parent 1182ea9540
commit c3320c2c97
14 changed files with 240 additions and 12 deletions

View File

@ -1,4 +1,4 @@
public class TestThreads { public class TestThreads implements Runnable {
public static void main(String[] args) { public static void main(String[] args) {
TestThreads test = new TestThreads(); TestThreads test = new TestThreads();

View File

@ -4,4 +4,6 @@ public final class Class <T> {
private Object body; private Object body;
private Class() { } private Class() { }
public native String getName();
} }

View File

@ -0,0 +1,19 @@
package java.lang;
public class InterruptedException extends Exception {
public InterruptedException(String message, Throwable cause) {
super(message, cause);
}
public InterruptedException(String message) {
this(message, null);
}
public InterruptedException(Throwable cause) {
this(null, cause);
}
public InterruptedException() {
this(null, null);
}
}

View File

@ -0,0 +1,13 @@
package java.lang;
public class Long {
private final long value;
public Long(long value) {
this.value = value;
}
public long longValue() {
return value;
}
}

View File

@ -0,0 +1,5 @@
package java.lang;
public interface Runnable {
public void run();
}

View File

@ -1,8 +1,39 @@
package java.lang; package java.lang;
public class StackTraceElement { public class StackTraceElement {
private Object method; private static int NativeLine = -2;
private int ip;
private StackTraceElement() { } private String class_;
private String method;
private String file;
private int line;
private StackTraceElement(String class_, String method, String file,
int line)
{
this.class_ = class_;
this.method = method;
this.file = file;
this.line = line;
}
public String getClassName() {
return class_;
}
public String getMethodName() {
return method;
}
public String getFileName() {
return file;
}
public int getLineNumber() {
return line;
}
public boolean isNativeMethod() {
return line == NativeLine;
}
} }

View File

@ -1,8 +1,41 @@
package java.lang; package java.lang;
public final class String { public final class String {
private byte[] bytes; private Object data;
private int offset; private int offset;
private int length; private int length;
private int hash; private int hash;
public int length() {
return length;
}
public static String valueOf(int v) {
return valueOf((long) v);
}
public native void getChars(int offset, int length,
char[] dst, int dstLength);
public static String valueOf(long v) {
if (v == 0) {
return valueOf('0');
} else {
final int Max = 21;
char[] array = new char[Max];
int index = Max;
long x = (v >= 0 ? v : -v);
while (x != 0) {
array[--index] = (char) ('0' + (x % 10));
x /= 10;
}
if (v < 0) {
array[--index] = '-';
}
return vm.Strings.wrap(array, index, Max - index);
}
}
} }

View File

@ -0,0 +1,42 @@
package java.lang;
public class StringBuilder {
private Cell chain;
private int length;
public StringBuilder append(String s) {
chain = new Cell(s, chain);
length += s.length();
return this;
}
public StringBuilder append(int v) {
append(String.valueOf(v));
return this;
}
public StringBuilder append(long v) {
append(String.valueOf(v));
return this;
}
public String toString() {
char[] array = new char[length];
int index = length;
for (Cell c = chain; c != null; c = c.next) {
index -= c.value.length();
c.value.getChars(0, c.value.length(), array, index);
}
return vm.Strings.wrap(array, 0, array.length);
}
private static class Cell {
public final String value;
public final Cell next;
public Cell(String value, Cell next) {
this.value = value;
this.next = next;
}
}
}

View File

@ -2,6 +2,7 @@ package java.lang;
public abstract class System { public abstract class System {
public static final Output out = new Output(); public static final Output out = new Output();
public static final Output err = out;
static { static {
loadLibrary("natives"); loadLibrary("natives");
@ -9,7 +10,14 @@ public abstract class System {
public static native void loadLibrary(String name); public static native void loadLibrary(String name);
public static native String getProperty(String name);
public static class Output { public static class Output {
public native void println(String s); public native void print(String s);
public void println(String s) {
print(s);
print(getProperty("line.separator"));
}
} }
} }

View File

@ -0,0 +1,20 @@
package java.lang;
public class Thread implements Runnable {
private final Runnable task;
public Thread(Runnable task) {
this.task = task;
}
public native void start();
public void run() {
if (task != null) {
task.run();
}
}
public static native void sleep(long milliseconds)
throws InterruptedException;
}

View File

@ -2,7 +2,7 @@ package java.lang;
public class Throwable { public class Throwable {
private String message; private String message;
private StackTraceElement[] trace; private Object trace;
private Throwable cause; private Throwable cause;
public Throwable(String message, Throwable cause) { public Throwable(String message, Throwable cause) {
@ -23,5 +23,51 @@ public class Throwable {
this(null, null); this(null, null);
} }
private static native StackTraceElement[] trace(int skipCount); private static native Object trace(int skipCount);
private static native StackTraceElement[] resolveTrace(Object trace);
private StackTraceElement[] resolveTrace() {
if (! (trace instanceof StackTraceElement[])) {
trace = resolveTrace(trace);
}
return (StackTraceElement[]) trace;
}
public void printStackTrace() {
StringBuilder sb = new StringBuilder();
printStackTrace(sb, System.getProperty("line.separator"));
System.err.print(sb.toString());
}
private void printStackTrace(StringBuilder sb, String nl) {
sb.append(getClass().getName());
if (message != null) {
sb.append(": ").append(message);
}
sb.append(nl);
StackTraceElement[] trace = resolveTrace();
for (int i = 0; i < trace.length; ++i) {
sb.append(" at ")
.append(trace[i].getClassName())
.append(trace[i].getMethodName());
if (trace[i].isNativeMethod()) {
sb.append(" (native)");
} else {
int line = trace[i].getLineNumber();
if (line >= 0) {
sb.append(" (line ").append(line).append(")");
}
}
sb.append(nl);
}
if (cause != null) {
sb.append("caused by: ");
cause.printStackTrace(sb, nl);
}
}
} }

View File

@ -0,0 +1,5 @@
package vm;
public abstract class Strings {
public static native String wrap(char[] array, int offset, int length);
}

View File

@ -127,7 +127,7 @@ fast-cflags = $(fast) $(cflags)
classpath-sources = $(shell find $(classpath)/java -name '*.java') classpath-sources = $(shell find $(classpath)/java -name '*.java')
classpath-classes = $(call java-classes,$(classpath-sources),$(classpath)) classpath-classes = $(call java-classes,$(classpath-sources),$(classpath))
input = $(bld)/classes/Hello.class input = $(bld)/classes/TestThreads.class
input-depends = \ input-depends = \
$(classpath-classes) \ $(classpath-classes) \
$(jni-library) $(jni-library)

View File

@ -20,7 +20,7 @@ using namespace vm;
namespace { namespace {
const bool Verbose = false; const bool Verbose = true;
const bool Debug = false; const bool Debug = false;
const bool DebugRun = false; const bool DebugRun = false;
const bool DebugStack = false; const bool DebugStack = false;
@ -1542,11 +1542,13 @@ parsePool(Thread* t, Stream& s)
case CONSTANT_Long: { case CONSTANT_Long: {
object value = makeLong(t, s.read8()); object value = makeLong(t, s.read8());
set(t, arrayBody(t, pool, i), value); set(t, arrayBody(t, pool, i), value);
++i;
} break; } break;
case CONSTANT_Double: { case CONSTANT_Double: {
object value = makeLong(t, s.readDouble()); object value = makeLong(t, s.readDouble());
set(t, arrayBody(t, pool, i), value); set(t, arrayBody(t, pool, i), value);
++i;
} break; } break;
case CONSTANT_Utf8: { case CONSTANT_Utf8: {
@ -1595,7 +1597,8 @@ parsePool(Thread* t, Stream& s)
for (unsigned i = 0; i < poolCount; ++i) { for (unsigned i = 0; i < poolCount; ++i) {
object o = arrayBody(t, pool, i); object o = arrayBody(t, pool, i);
if (objectClass(t, o) == arrayBody(t, t->vm->types, Machine::IntArrayType)) if (o and objectClass(t, o)
== arrayBody(t, t->vm->types, Machine::IntArrayType))
{ {
switch (intArrayBody(t, o, 0)) { switch (intArrayBody(t, o, 0)) {
case CONSTANT_Class: { case CONSTANT_Class: {
@ -1621,7 +1624,8 @@ parsePool(Thread* t, Stream& s)
for (unsigned i = 0; i < poolCount; ++i) { for (unsigned i = 0; i < poolCount; ++i) {
object o = arrayBody(t, pool, i); object o = arrayBody(t, pool, i);
if (objectClass(t, o) == arrayBody(t, t->vm->types, Machine::IntArrayType)) if (o and objectClass(t, o)
== arrayBody(t, t->vm->types, Machine::IntArrayType))
{ {
switch (intArrayBody(t, o, 0)) { switch (intArrayBody(t, o, 0)) {
case CONSTANT_Fieldref: case CONSTANT_Fieldref: