mirror of
https://github.com/corda/corda.git
synced 2025-01-22 04:18:31 +00:00
Merge pull request #363 from lostdj/patch-4
interpret.invokeNative(): call native function with a right signature
This commit is contained in:
commit
adcaeb513c
@ -1441,6 +1441,7 @@ Classpath* makeClasspath(System* system,
|
||||
const char* embedPrefix);
|
||||
|
||||
typedef uint64_t(JNICALL* FastNativeFunction)(Thread*, GcMethod*, uintptr_t*);
|
||||
typedef void(JNICALL* FastVoidNativeFunction)(Thread*, GcMethod*, uintptr_t*);
|
||||
|
||||
inline GcClass* objectClass(Thread*, object o)
|
||||
{
|
||||
|
@ -641,8 +641,15 @@ unsigned invokeNative(Thread* t, GcMethod* method)
|
||||
marshalArguments(
|
||||
t, RUNTIME_ARRAY_BODY(args) + argOffset, 0, sp, method, true);
|
||||
|
||||
result = reinterpret_cast<FastNativeFunction>(native->function())(
|
||||
if(method->returnCode() != VoidField) {
|
||||
result = reinterpret_cast<FastNativeFunction>(native->function())(
|
||||
t, method, RUNTIME_ARRAY_BODY(args));
|
||||
}
|
||||
else {
|
||||
result = 0;
|
||||
reinterpret_cast<FastVoidNativeFunction>(native->function())(
|
||||
t, method, RUNTIME_ARRAY_BODY(args));
|
||||
}
|
||||
}
|
||||
|
||||
pushResult(t, method->returnCode(), result, false);
|
||||
|
Loading…
Reference in New Issue
Block a user