OpenTTD Source 20241224-master-gf74b0cf984
|
Windows implementation for the crash logger. More...
Public Member Functions | |
bool | TryExecute (std::string_view section_name, std::function< bool()> &&func) override |
Execute the func() and return its value. | |
CrashLogWindows (EXCEPTION_POINTERS *ep=nullptr) | |
A crash log is always generated when it's generated. | |
Public Member Functions inherited from CrashLog | |
virtual | ~CrashLog ()=default |
Stub destructor to silence some compilers. | |
void | FillCrashLog () |
Fill the crash log buffer with all data of a crash log. | |
void | PrintCrashLog () const |
bool | WriteCrashLog () |
Write the crash log to a file. | |
virtual bool | WriteCrashDump () |
Write the (crash) dump to a file. | |
bool | WriteSavegame () |
Write the (crash) savegame to a file. | |
bool | WriteScreenshot () |
Write the (crash) screenshot to a file. | |
void | SendSurvey () const |
Send the survey result, noting it was a crash. | |
void | MakeCrashLog () |
Makes the crash log, writes it to a file and then subsequently tries to make a crash dump and crash savegame. | |
Data Fields | |
jmp_buf | internal_fault_jmp_buf |
Buffer to track the long jump set setup. | |
bool | try_execute_active = false |
Whether we are in a TryExecute block. | |
Data Fields inherited from CrashLog | |
nlohmann::json | survey |
std::string | crashlog_filename |
std::string | crashdump_filename |
std::string | savegame_filename |
std::string | screenshot_filename |
Static Public Attributes | |
static CrashLogWindows * | current = nullptr |
Points to the current crash log. | |
Private Member Functions | |
void | SurveyCrash (nlohmann::json &survey) const override |
Convert system crash reason to JSON. | |
void | SurveyStacktrace (nlohmann::json &survey) const override |
Convert stacktrace to JSON. | |
Private Attributes | |
EXCEPTION_POINTERS * | ep |
Information about the encountered exception. | |
Additional Inherited Members | |
Static Public Member Functions inherited from CrashLog | |
static void | InitialiseCrashLog () |
Initialiser for crash logs; do the appropriate things so crashes are handled by our crash handler instead of returning straight to the OS. | |
static void | InitThread () |
Prepare crash log handler for a newly started thread. | |
static void | SetErrorMessage (const std::string &message) |
Sets a message for the error message handler. | |
static void | AfterCrashLogCleanup () |
Try to close the sound/video stuff so it doesn't keep lingering around incorrect video states or so, e.g. | |
Protected Member Functions inherited from CrashLog | |
std::string | CreateFileName (const char *ext, bool with_dir=true) const |
Create a timestamped filename. | |
Windows implementation for the crash logger.
Definition at line 84 of file crashlog_win.cpp.
|
inline |
A crash log is always generated when it's generated.
ep | the data related to the exception. |
Definition at line 156 of file crashlog_win.cpp.
|
inlineoverrideprivatevirtual |
Convert system crash reason to JSON.
survey | The JSON object. |
Implements CrashLog.
Definition at line 88 of file crashlog_win.cpp.
References ep, and exception_code_to_name.
|
overrideprivatevirtual |
Convert stacktrace to JSON.
survey | The JSON object. |
Implements CrashLog.
Definition at line 294 of file crashlog_win.cpp.
|
inlineoverridevirtual |
Execute the func() and return its value.
If any exception / signal / crash happens, catch it and return false. This function should, in theory, never not return, even in the worst conditions.
section_name | The name of the section to be executed. Printed when a crash happens. |
func | The function to call. |
Implements CrashLog.
Definition at line 134 of file crashlog_win.cpp.
References internal_fault_jmp_buf, and try_execute_active.
|
static |
Points to the current crash log.
Definition at line 170 of file crashlog_win.cpp.
|
private |
Information about the encountered exception.
Definition at line 86 of file crashlog_win.cpp.
Referenced by SurveyCrash().
jmp_buf CrashLogWindows::internal_fault_jmp_buf |
Buffer to track the long jump set setup.
Definition at line 163 of file crashlog_win.cpp.
Referenced by TryExecute().
bool CrashLogWindows::try_execute_active = false |
Whether we are in a TryExecute block.
Definition at line 167 of file crashlog_win.cpp.
Referenced by TryExecute().