Веб-сайт самохостера Lotigara

summaryrefslogtreecommitdiff
path: root/source/core
diff options
context:
space:
mode:
authorKae <80987908+Novaenia@users.noreply.github.com>2025-04-30 15:14:49 +1000
committerKae <80987908+Novaenia@users.noreply.github.com>2025-04-30 15:14:49 +1000
commita521dc5c74d54466dd3fc432057b96c30504a748 (patch)
tree8240eff0bdf1aba309c27ed0a9e772a2db43e425 /source/core
parentd8db6199e13b5405123f18cc1a9631f7e7f4794a (diff)
Guarantee stack space in exception handling so printing stack overflows doesn't fail
Diffstat (limited to 'source/core')
-rw-r--r--source/core/StarSignalHandler_windows.cpp4
-rw-r--r--source/core/StarThread_windows.cpp2
2 files changed, 4 insertions, 2 deletions
diff --git a/source/core/StarSignalHandler_windows.cpp b/source/core/StarSignalHandler_windows.cpp
index 676734c..2fbde88 100644
--- a/source/core/StarSignalHandler_windows.cpp
+++ b/source/core/StarSignalHandler_windows.cpp
@@ -28,7 +28,7 @@ static DWORD WINAPI writeMiniDump(void* ExceptionInfo) {
NULL);
CloseHandle(hFile);
if (dumpExceptionInfo.ExceptionPointers->ExceptionRecord->ExceptionCode == EXCEPTION_STACK_OVERFLOW) {
- MessageBoxA(NULL, "Stack overflow encountered\nA minidump has been generated", NULL, MB_OK | MB_ICONERROR | MB_SETFOREGROUND);
+ MessageBoxA(NULL, "Fatal stack overflow encountered\nA minidump has been generated", NULL, MB_OK | MB_ICONERROR | MB_SETFOREGROUND);
}
return 0;
};
@@ -166,7 +166,7 @@ struct SignalHandlerImpl {
|| (ExceptionInfo->ExceptionRecord->ExceptionCode == EXCEPTION_NONCONTINUABLE_EXCEPTION)
|| (ExceptionInfo->ExceptionRecord->ExceptionCode == EXCEPTION_INVALID_DISPOSITION)
|| (ExceptionInfo->ExceptionRecord->ExceptionCode == EXCEPTION_INVALID_HANDLE)) {
- handleFatalError("Error occured", ExceptionInfo);
+ handleFatalError("Error occurred", ExceptionInfo);
result = EXCEPTION_CONTINUE_EXECUTION;
}
if (thread != NULL) {
diff --git a/source/core/StarThread_windows.cpp b/source/core/StarThread_windows.cpp
index a7d09be..b63101d 100644
--- a/source/core/StarThread_windows.cpp
+++ b/source/core/StarThread_windows.cpp
@@ -46,6 +46,8 @@ struct ThreadImpl {
static DWORD WINAPI runThread(void* data) {
ThreadImpl* ptr = static_cast<ThreadImpl*>(data);
try {
+ unsigned long exceptionStackSize = 16384;
+ SetThreadStackGuarantee(&exceptionStackSize);
ptr->function();
} catch (std::exception const& e) {
if (ptr->name.empty())