1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-18 13:12:50 +00:00
OpenMW/components/crashcatcher/windows_crashmonitor.hpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

64 lines
1.3 KiB
C++
Raw Normal View History

#ifndef WINDOWS_CRASHMONITOR_HPP
#define WINDOWS_CRASHMONITOR_HPP
#include <components/misc/windows.hpp>
#include <atomic>
2022-01-13 22:46:00 +02:00
#include <unordered_map>
namespace Crash
{
struct CrashSHM;
class CrashMonitor final
{
public:
CrashMonitor(HANDLE shmHandle);
~CrashMonitor();
2022-09-22 21:26:05 +03:00
void run();
2022-09-22 21:26:05 +03:00
private:
HANDLE mAppProcessHandle = nullptr;
2021-12-18 21:34:15 +00:00
DWORD mAppMainThreadId = 0;
HWND mAppWindowHandle = nullptr;
// triggered when the monitor process wants to wake the parent process (received via SHM)
HANDLE mSignalAppEvent = nullptr;
// triggered when the application wants to wake the monitor process (received via SHM)
HANDLE mSignalMonitorEvent = nullptr;
CrashSHM* mShm = nullptr;
HANDLE mShmHandle = nullptr;
HANDLE mShmMutex = nullptr;
DWORD mFreezeMessageBoxThreadId = 0;
std::atomic_bool mFreezeAbort;
static std::unordered_map<HWINEVENTHOOK, CrashMonitor*> smEventHookOwners;
void signalApp() const;
bool waitApp() const;
bool isAppAlive() const;
2021-12-18 21:34:15 +00:00
bool isAppFrozen();
void shmLock();
void shmUnlock();
void handleCrash(bool isFreeze);
void showFreezeMessageBox();
void hideFreezeMessageBox();
};
} // namespace Crash
#endif // WINDOWS_CRASHMONITOR_HPP