mirror of
https://github.com/corda/corda.git
synced 2025-01-28 15:14:48 +00:00
flesh out classpath enough to test threading; fix indexing bug in parsePool()
This commit is contained in:
parent
1182ea9540
commit
c3320c2c97
@ -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();
|
||||||
|
@ -4,4 +4,6 @@ public final class Class <T> {
|
|||||||
private Object body;
|
private Object body;
|
||||||
|
|
||||||
private Class() { }
|
private Class() { }
|
||||||
|
|
||||||
|
public native String getName();
|
||||||
}
|
}
|
||||||
|
19
classpath/java/lang/InterruptedException.java
Normal file
19
classpath/java/lang/InterruptedException.java
Normal 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);
|
||||||
|
}
|
||||||
|
}
|
13
classpath/java/lang/Long.java
Normal file
13
classpath/java/lang/Long.java
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
5
classpath/java/lang/Runnable.java
Normal file
5
classpath/java/lang/Runnable.java
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
package java.lang;
|
||||||
|
|
||||||
|
public interface Runnable {
|
||||||
|
public void run();
|
||||||
|
}
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
42
classpath/java/lang/StringBuilder.java
Normal file
42
classpath/java/lang/StringBuilder.java
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -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"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
20
classpath/java/lang/Thread.java
Normal file
20
classpath/java/lang/Thread.java
Normal 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;
|
||||||
|
}
|
@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
5
classpath/vm/Strings.java
Normal file
5
classpath/vm/Strings.java
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
package vm;
|
||||||
|
|
||||||
|
public abstract class Strings {
|
||||||
|
public static native String wrap(char[] array, int offset, int length);
|
||||||
|
}
|
2
makefile
2
makefile
@ -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)
|
||||||
|
10
src/vm.cpp
10
src/vm.cpp
@ -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:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user