mirror of
https://github.com/corda/corda.git
synced 2025-01-01 02:36:44 +00:00
implement more helper functions; add fields to class, field, and method types
This commit is contained in:
parent
587fb18685
commit
8cc54280d9
@ -8,17 +8,22 @@
|
|||||||
(object interfaceTable)
|
(object interfaceTable)
|
||||||
(object fieldTable)
|
(object fieldTable)
|
||||||
(object methodTable)
|
(object methodTable)
|
||||||
(object staticTable))
|
(object staticTable)
|
||||||
|
(object initializers))
|
||||||
|
|
||||||
(type field
|
(type field
|
||||||
(uint16_t flags)
|
(uint16_t flags)
|
||||||
|
(uint16_t offset)
|
||||||
(object name)
|
(object name)
|
||||||
(object class))
|
(object class))
|
||||||
|
|
||||||
(type method
|
(type method
|
||||||
(uint16_t flags)
|
(uint16_t flags)
|
||||||
|
(uint16_t offset)
|
||||||
|
(uint16_t parameterCount)
|
||||||
(object name)
|
(object name)
|
||||||
(object spec)
|
(object spec)
|
||||||
|
(object class)
|
||||||
(object code))
|
(object code))
|
||||||
|
|
||||||
(pod exceptionHandler
|
(pod exceptionHandler
|
||||||
|
85
src/vm.cpp
85
src/vm.cpp
@ -423,6 +423,32 @@ isLongOrDouble(object o)
|
|||||||
return typeOf(o) == LongType or typeOf(o) == DoubleType;
|
return typeOf(o) == LongType or typeOf(o) == DoubleType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline object
|
||||||
|
getField(Thread* t, object instance, object field)
|
||||||
|
{
|
||||||
|
return cast<object>(instance, fieldOffset(t, field) * sizeof(object));
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void
|
||||||
|
setField(Thread* t, object o, object field, object value)
|
||||||
|
{
|
||||||
|
set(t, cast<object>(o, fieldOffset(t, field) * sizeof(object)), value);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline object
|
||||||
|
getStatic(Thread* t, object field)
|
||||||
|
{
|
||||||
|
return rawArrayBody(t, classStaticTable(t, fieldClass(t, field)))
|
||||||
|
[fieldOffset(t, field)];
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void
|
||||||
|
setStatic(Thread* t, object field, object value)
|
||||||
|
{
|
||||||
|
set(t, rawArrayBody(t, classStaticTable(t, fieldClass(t, field)))
|
||||||
|
[fieldOffset(t, field)], value);
|
||||||
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
instanceOf(Thread* t, object class_, object o)
|
instanceOf(Thread* t, object class_, object o)
|
||||||
{
|
{
|
||||||
@ -452,6 +478,27 @@ instanceOf(Thread* t, object class_, object o)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
object
|
||||||
|
findInterfaceMethod(Thread* t, object method, object o)
|
||||||
|
{
|
||||||
|
Type id = interfaceId(t, methodClass(t, method));
|
||||||
|
object itable = classInterfaceTable(t, objectClass(o));
|
||||||
|
for (unsigned i = 0; i < rawArrayLength(t, itable); i += 2) {
|
||||||
|
if (interfaceId(t, rawArrayBody(t, itable)[i]) == id) {
|
||||||
|
return rawArrayBody(t, rawArrayBody(t, itable)[i + 1])
|
||||||
|
[methodOffset(t, method)];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
abort(t);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline object
|
||||||
|
findVirtualMethod(Thread* t, object method, object o)
|
||||||
|
{
|
||||||
|
return rawArrayBody(t, classMethodTable(t, objectClass(o)))
|
||||||
|
[methodOffset(t, method)];
|
||||||
|
}
|
||||||
|
|
||||||
object
|
object
|
||||||
run(Thread* t)
|
run(Thread* t)
|
||||||
{
|
{
|
||||||
@ -855,7 +902,7 @@ run(Thread* t)
|
|||||||
object field = resolveField(t, codePool(t, code), index);
|
object field = resolveField(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
push(t, getField(instance, field));
|
push(t, getField(t, instance, field));
|
||||||
} else {
|
} else {
|
||||||
exception = makeNullPointerException(t);
|
exception = makeNullPointerException(t);
|
||||||
goto throw_;
|
goto throw_;
|
||||||
@ -870,14 +917,16 @@ run(Thread* t)
|
|||||||
object field = resolveField(t, codePool(t, code), index);
|
object field = resolveField(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
if (not classInitialized(fieldClass(t, field))) {
|
object p = classInitializers(t, fieldClass(t, field));
|
||||||
code = classInitializer(fieldClass(t, field));
|
if (p) {
|
||||||
|
set(t, classInitializers(t, fieldClass(t, field)), pairSecond(t, p));
|
||||||
|
code = pairFirst(t, p);
|
||||||
ip -= 3;
|
ip -= 3;
|
||||||
parameterCount = 0;
|
parameterCount = 0;
|
||||||
goto invoke;
|
goto invoke;
|
||||||
}
|
}
|
||||||
|
|
||||||
push(t, getStatic(field));
|
push(t, getStatic(t, field));
|
||||||
} goto loop;
|
} goto loop;
|
||||||
|
|
||||||
case goto_: {
|
case goto_: {
|
||||||
@ -1246,7 +1295,7 @@ run(Thread* t)
|
|||||||
object method = resolveMethod(t, codePool(t, code), index);
|
object method = resolveMethod(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
parameterCount = methodParameterCount(method);
|
parameterCount = methodParameterCount(t, method);
|
||||||
if (LIKELY(stack[sp - parameterCount])) {
|
if (LIKELY(stack[sp - parameterCount])) {
|
||||||
code = findInterfaceMethod(t, method, stack[sp - parameterCount]);
|
code = findInterfaceMethod(t, method, stack[sp - parameterCount]);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
@ -1266,7 +1315,7 @@ run(Thread* t)
|
|||||||
object method = resolveMethod(t, codePool(t, code), index);
|
object method = resolveMethod(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
parameterCount = methodParameterCount(method);
|
parameterCount = methodParameterCount(t, method);
|
||||||
if (LIKELY(stack[sp - parameterCount])) {
|
if (LIKELY(stack[sp - parameterCount])) {
|
||||||
if (isSpecialMethod(method, stack[sp - parameterCount])) {
|
if (isSpecialMethod(method, stack[sp - parameterCount])) {
|
||||||
code = findSpecialMethod(t, method, stack[sp - parameterCount]);
|
code = findSpecialMethod(t, method, stack[sp - parameterCount]);
|
||||||
@ -1290,14 +1339,16 @@ run(Thread* t)
|
|||||||
object method = resolveMethod(t, codePool(t, code), index);
|
object method = resolveMethod(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
if (not classInitialized(methodClass(t, method))) {
|
object p = classInitializers(t, methodClass(t, method));
|
||||||
code = classInitializer(methodClass(t, method));
|
if (p) {
|
||||||
ip -= 2;
|
set(t, classInitializers(t, methodClass(t, method)), pairSecond(t, p));
|
||||||
|
code = pairFirst(t, p);
|
||||||
|
ip -= 3;
|
||||||
parameterCount = 0;
|
parameterCount = 0;
|
||||||
goto invoke;
|
goto invoke;
|
||||||
}
|
}
|
||||||
|
|
||||||
parameterCount = methodParameterCount(method);
|
parameterCount = methodParameterCount(t, method);
|
||||||
code = method;
|
code = method;
|
||||||
} goto invoke;
|
} goto invoke;
|
||||||
|
|
||||||
@ -1309,7 +1360,7 @@ run(Thread* t)
|
|||||||
object method = resolveMethod(t, codePool(t, code), index);
|
object method = resolveMethod(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
parameterCount = methodParameterCount(method);
|
parameterCount = methodParameterCount(t, method);
|
||||||
if (LIKELY(stack[sp - parameterCount])) {
|
if (LIKELY(stack[sp - parameterCount])) {
|
||||||
code = findVirtualMethod(t, method, stack[sp - parameterCount]);
|
code = findVirtualMethod(t, method, stack[sp - parameterCount]);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
@ -1560,8 +1611,10 @@ run(Thread* t)
|
|||||||
object class_ = resolveClass(t, codePool(t, code), index);
|
object class_ = resolveClass(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
if (not classInitialized(class_)) {
|
object p = classInitializers(t, class_);
|
||||||
code = classInitializer(class_);
|
if (p) {
|
||||||
|
set(t, classInitializers(t, class_), pairSecond(t, p));
|
||||||
|
code = pairFirst(t, p);
|
||||||
ip -= 3;
|
ip -= 3;
|
||||||
parameterCount = 0;
|
parameterCount = 0;
|
||||||
goto invoke;
|
goto invoke;
|
||||||
@ -1676,8 +1729,10 @@ run(Thread* t)
|
|||||||
object field = resolveField(t, codePool(t, code), index);
|
object field = resolveField(t, codePool(t, code), index);
|
||||||
if (UNLIKELY(exception)) goto throw_;
|
if (UNLIKELY(exception)) goto throw_;
|
||||||
|
|
||||||
if (not classInitialized(fieldClass(t, field))) {
|
object p = classInitializers(t, fieldClass(t, field));
|
||||||
code = classInitializer(fieldClass(t, field));
|
if (p) {
|
||||||
|
set(t, classInitializers(t, fieldClass(t, field)), pairSecond(t, p));
|
||||||
|
code = pairFirst(t, p);
|
||||||
ip -= 3;
|
ip -= 3;
|
||||||
parameterCount = 0;
|
parameterCount = 0;
|
||||||
goto invoke;
|
goto invoke;
|
||||||
|
Loading…
Reference in New Issue
Block a user