mirror of
https://github.com/corda/corda.git
synced 2025-01-14 16:59:52 +00:00
snapshot
This commit is contained in:
parent
9bc6b0db0b
commit
9076e2fbfa
64
src/vm.cpp
64
src/vm.cpp
@ -22,11 +22,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
objectArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -43,11 +43,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
objectArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -94,7 +94,7 @@ run(Thread* t)
|
||||
PUSH(array);
|
||||
} else {
|
||||
object message = makeString(t, "%d", c);
|
||||
t->exception = makeNASException(t, message);
|
||||
t->exception = makeNegativeArrayStoreException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -117,7 +117,7 @@ run(Thread* t)
|
||||
if (array) {
|
||||
PUSH(makeInt(t, arrayLength(array)));
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} UNREACHABLE;
|
||||
@ -150,7 +150,7 @@ run(Thread* t)
|
||||
case athrow: {
|
||||
POP(t->exception);
|
||||
if (t->exception == 0) {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
}
|
||||
goto throw_;
|
||||
} UNREACHABLE;
|
||||
@ -166,11 +166,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
byteArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -187,11 +187,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
byteArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -211,11 +211,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
charArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -232,11 +232,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
charArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -252,7 +252,7 @@ run(Thread* t)
|
||||
if (t->exception) goto throw_;
|
||||
|
||||
if (not instanceOf(t, class_, t->stack[t->sp - 1])) {
|
||||
t->exception = makeCCException(t, 0);
|
||||
t->exception = makeClassCastException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
}
|
||||
@ -360,7 +360,7 @@ run(Thread* t)
|
||||
|
||||
PUSH(getField(instance, field));
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -374,9 +374,18 @@ run(Thread* t)
|
||||
object field = resolveField(t, codePool(t->code), index);
|
||||
if (t->exception) goto throw_;
|
||||
|
||||
if (not classInitialized(fieldClass(field))) {
|
||||
frameIp(t->frame) = ip - 3;
|
||||
PUSH(t->frame);
|
||||
|
||||
t->code = classInitializer(fieldClass(field));
|
||||
t->frame = makeFrame(t, t->code);
|
||||
ip = 0;
|
||||
}
|
||||
|
||||
PUSH(getStatic(field));
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -440,11 +449,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
intArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -468,11 +477,11 @@ run(Thread* t)
|
||||
} else {
|
||||
object message = makeString(t, "%d not in [0,%d]", i,
|
||||
intArrayLength(array));
|
||||
t->exception = makeAIOOBException(t, message);
|
||||
t->exception = makeArrayIndexOutOfBoundsException(t, message);
|
||||
goto throw_;
|
||||
}
|
||||
} else {
|
||||
t->exception = makeNPException(t, 0);
|
||||
t->exception = makeNullPointerException(t, 0);
|
||||
goto throw_;
|
||||
}
|
||||
} goto loop;
|
||||
@ -753,14 +762,15 @@ run(Thread* t)
|
||||
}
|
||||
} goto loop;
|
||||
|
||||
case invokeinterface: {
|
||||
// todo
|
||||
} goto loop;
|
||||
|
||||
default: UNREACHABLE;
|
||||
}
|
||||
|
||||
throw_:
|
||||
PUSH(t->frame);
|
||||
for (; t->sp >= 0; --(t->sp)) {
|
||||
if (typeOf(t->stack[t->sp]) == FrameType) {
|
||||
t->frame = t->stack[t->sp];
|
||||
for (; t->frame; t->frame = frameNext(t->frame)) {
|
||||
t->code = frameCode(t->frame);
|
||||
object eht = codeExceptionHandlerTable(t->code);
|
||||
if (eht) {
|
||||
@ -780,9 +790,9 @@ run(Thread* t)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
t->code = defaultExceptionHandler(t);
|
||||
t->frame = makeFrame(t, t->code);
|
||||
t->sp = 0;
|
||||
ip = 0;
|
||||
PUSH(t->exception);
|
||||
|
Loading…
Reference in New Issue
Block a user