mirror of
https://github.com/Eaglercraft-TeaVM-Fork/eagler-teavm.git
synced 2025-01-23 23:04:50 -08:00
C: fix exception when marshalling string from native code to Java and GC is triggered
This commit is contained in:
parent
c05f40cc6a
commit
3335b86619
|
@ -99,6 +99,7 @@ public final class ExceptionHandling {
|
|||
int handlerId = 0;
|
||||
stackLoop: while (stackFrame != null) {
|
||||
int callSiteId = ShadowStack.getCallSiteId(stackFrame);
|
||||
if (callSiteId >= 0) {
|
||||
CallSite callSite = findCallSiteById(callSiteId, stackFrame);
|
||||
ExceptionHandler handler = callSite.firstHandler;
|
||||
|
||||
|
@ -112,6 +113,7 @@ public final class ExceptionHandling {
|
|||
}
|
||||
|
||||
ShadowStack.setExceptionHandlerId(stackFrame, callSiteId - 1);
|
||||
}
|
||||
stackFrame = ShadowStack.getNextStackFrame(stackFrame);
|
||||
}
|
||||
|
||||
|
@ -151,6 +153,7 @@ public final class ExceptionHandling {
|
|||
int size = 0;
|
||||
while (stackFrame != null) {
|
||||
int callSiteId = ShadowStack.getCallSiteId(stackFrame);
|
||||
if (callSiteId >= 0) {
|
||||
CallSite callSite = findCallSiteById(callSiteId, stackFrame);
|
||||
CallSiteLocation location = callSite.location;
|
||||
if (isObfuscated() || location == null) {
|
||||
|
@ -161,6 +164,7 @@ public final class ExceptionHandling {
|
|||
location = location.next;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
stackFrame = ShadowStack.getNextStackFrame(stackFrame);
|
||||
}
|
||||
|
@ -179,6 +183,7 @@ public final class ExceptionHandling {
|
|||
int index = 0;
|
||||
while (stackFrame != null) {
|
||||
int callSiteId = ShadowStack.getCallSiteId(stackFrame);
|
||||
if (callSiteId >= 0) {
|
||||
CallSite callSite = findCallSiteById(callSiteId, stackFrame);
|
||||
CallSiteLocation location = callSite.location;
|
||||
if (isObfuscated()) {
|
||||
|
@ -202,6 +207,7 @@ public final class ExceptionHandling {
|
|||
location = location.next;
|
||||
}
|
||||
}
|
||||
}
|
||||
stackFrame = ShadowStack.getNextStackFrame(stackFrame);
|
||||
}
|
||||
ShadowStack.releaseStack(1);
|
||||
|
|
|
@ -1,6 +1,12 @@
|
|||
#include "string.h"
|
||||
#include "stack.h"
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <stddef.h>
|
||||
|
||||
#if TEAVM_INCREMENTAL
|
||||
#define TEAVM_ALLOC_STACK(sz) TEAVM_ALLOC_STACK_DEF(sz, NULL)
|
||||
#endif
|
||||
|
||||
int32_t teavm_hashCode(TeaVM_String* string) {
|
||||
int32_t hashCode = INT32_C(0);
|
||||
|
@ -106,9 +112,15 @@ TeaVM_String* teavm_cToString(char* cstring) {
|
|||
return NULL;
|
||||
}
|
||||
|
||||
TEAVM_ALLOC_STACK(1);
|
||||
TEAVM_CALL_SITE(-1);
|
||||
TEAVM_GC_ROOT_RELEASE(0);
|
||||
|
||||
size_t clen = strlen(cstring);
|
||||
int32_t size = teavm_c16Size(cstring, clen);
|
||||
TeaVM_Array* charArray = teavm_allocateCharArray(size);
|
||||
TEAVM_GC_ROOT(0, charArray);
|
||||
|
||||
char16_t* javaChars = TEAVM_ARRAY_DATA(charArray, char16_t);
|
||||
mbstate_t state = {0};
|
||||
for (int32_t i = 0; i < size; ++i) {
|
||||
|
@ -120,7 +132,10 @@ TeaVM_String* teavm_cToString(char* cstring) {
|
|||
cstring += result;
|
||||
}
|
||||
}
|
||||
return teavm_createString(charArray);
|
||||
|
||||
TeaVM_String* result = teavm_createString(charArray);
|
||||
TEAVM_RELEASE_STACK;
|
||||
return result;
|
||||
}
|
||||
|
||||
TeaVM_String* teavm_c16ToString(char16_t* cstring) {
|
||||
|
@ -128,14 +143,23 @@ TeaVM_String* teavm_c16ToString(char16_t* cstring) {
|
|||
return NULL;
|
||||
}
|
||||
|
||||
|
||||
TEAVM_ALLOC_STACK(1);
|
||||
TEAVM_CALL_SITE(-1);
|
||||
TEAVM_GC_ROOT_RELEASE(0);
|
||||
|
||||
int32_t size = 0;
|
||||
while (cstring[size] != 0) {
|
||||
++size;
|
||||
}
|
||||
TeaVM_Array* charArray = teavm_allocateCharArray(size);
|
||||
TEAVM_GC_ROOT(0, charArray);
|
||||
char16_t* javaChars = TEAVM_ARRAY_DATA(charArray, char16_t);
|
||||
memcpy(javaChars, cstring, size * sizeof(char16_t));
|
||||
return teavm_createString(charArray);
|
||||
|
||||
TeaVM_String* result = teavm_createString(charArray);
|
||||
TEAVM_RELEASE_STACK;
|
||||
return result;
|
||||
}
|
||||
|
||||
char16_t* teavm_mbToChar16(char* cstring, int32_t* length) {
|
||||
|
|
Loading…
Reference in New Issue
Block a user