mirror of
https://github.com/corda/corda.git
synced 2025-01-22 12:28:11 +00:00
fix JVM_GetArrayElement and JVM_SetArrayElement
The old versions only handled object arrays properly, but they need to handle primitive arrays as well.
This commit is contained in:
parent
62e10cf992
commit
56e832d3e8
@ -3173,12 +3173,62 @@ EXPORT(JVM_GetArrayLength)(Thread* t, jobject array)
|
|||||||
return cast<uintptr_t>(*array, BytesPerWord);
|
return cast<uintptr_t>(*array, BytesPerWord);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint64_t
|
||||||
|
jvmGetArrayElement(Thread* t, uintptr_t* arguments)
|
||||||
|
{
|
||||||
|
jobject array = reinterpret_cast<jobject>(arguments[0]);
|
||||||
|
jint index = arguments[1];
|
||||||
|
|
||||||
|
switch (byteArrayBody(t, className(t, objectClass(t, *array)), 1)) {
|
||||||
|
case 'Z':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeBoolean(t, cast<int8_t>(*array, ArrayBody + index))));
|
||||||
|
case 'B':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeByte(t, cast<int8_t>(*array, ArrayBody + index))));
|
||||||
|
case 'C':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeChar(t, cast<int16_t>(*array, ArrayBody + (index * 2)))));
|
||||||
|
case 'S':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeShort(t, cast<int16_t>(*array, ArrayBody + (index * 2)))));
|
||||||
|
case 'I':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeInt(t, cast<int32_t>(*array, ArrayBody + (index * 4)))));
|
||||||
|
case 'F':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeFloat(t, cast<int32_t>(*array, ArrayBody + (index * 4)))));
|
||||||
|
case 'J':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeLong(t, cast<int64_t>(*array, ArrayBody + (index * 8)))));
|
||||||
|
case 'D':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, makeDouble(t, cast<int64_t>(*array, ArrayBody + (index * 8)))));
|
||||||
|
case 'L':
|
||||||
|
case '[':
|
||||||
|
return reinterpret_cast<intptr_t>
|
||||||
|
(makeLocalReference
|
||||||
|
(t, cast<object>(*array, ArrayBody + (index * BytesPerWord))));
|
||||||
|
default:
|
||||||
|
abort(t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jobject JNICALL
|
extern "C" JNIEXPORT jobject JNICALL
|
||||||
EXPORT(JVM_GetArrayElement)(Thread* t, jobject array, jint index)
|
EXPORT(JVM_GetArrayElement)(Thread* t, jobject array, jint index)
|
||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
uintptr_t arguments[] = { reinterpret_cast<uintptr_t>(array),
|
||||||
|
index };
|
||||||
|
|
||||||
return makeLocalReference(t, objectArrayBody(t, *array, index));
|
return reinterpret_cast<jobject>(run(t, jvmGetArrayElement, arguments));
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT jvalue JNICALL
|
extern "C" JNIEXPORT jvalue JNICALL
|
||||||
@ -3190,7 +3240,38 @@ EXPORT(JVM_SetArrayElement)(Thread* t, jobject array, jint index,
|
|||||||
{
|
{
|
||||||
ENTER(t, Thread::ActiveState);
|
ENTER(t, Thread::ActiveState);
|
||||||
|
|
||||||
set(t, *array, ArrayBody + (index * BytesPerWord), (value ? *value : 0));
|
switch (byteArrayBody(t, className(t, objectClass(t, *array)), 1)) {
|
||||||
|
case 'Z':
|
||||||
|
cast<int8_t>(*array, ArrayBody + index) = booleanValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'B':
|
||||||
|
cast<int8_t>(*array, ArrayBody + index) = byteValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'C':
|
||||||
|
cast<int16_t>(*array, ArrayBody + (index * 2)) = charValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'S':
|
||||||
|
cast<int16_t>(*array, ArrayBody + (index * 2)) = shortValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'I':
|
||||||
|
cast<int32_t>(*array, ArrayBody + (index * 4)) = intValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'F':
|
||||||
|
cast<int32_t>(*array, ArrayBody + (index * 4)) = floatValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'J':
|
||||||
|
cast<int64_t>(*array, ArrayBody + (index * 8)) = longValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'D':
|
||||||
|
cast<int64_t>(*array, ArrayBody + (index * 8)) = doubleValue(t, *value);
|
||||||
|
break;
|
||||||
|
case 'L':
|
||||||
|
case '[':
|
||||||
|
set(t, *array, ArrayBody + (index * BytesPerWord), (value ? *value : 0));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
abort(t);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
extern "C" JNIEXPORT void JNICALL
|
extern "C" JNIEXPORT void JNICALL
|
||||||
|
Loading…
Reference in New Issue
Block a user