rewrite InitApartment and protect callers from (the rest of the) exceptions
Initializing COM by calling `winrt::init_apartment()` would always cause stack unwinding *in practice*, which is suboptimal at best, and even using `apartment_type::single_threaded` still would require exception filtering *just in case*.
This commit is contained in:
parent
c855d5e7cb
commit
f1bcb6604f
|
@ -15,7 +15,7 @@
|
||||||
#define NOEXCEPT
|
#define NOEXCEPT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
EXTERN gboolean winrt_InitApartment();
|
EXTERN gboolean winrt_InitApartment() NOEXCEPT;
|
||||||
EXTERN char* winrt_windows_ui_notifications_toast_notification_manager_GetTemplateContent(winrtWindowsUINotificationsToastTemplateType type) NOEXCEPT;
|
EXTERN char* winrt_windows_ui_notifications_toast_notification_manager_GetTemplateContent(winrtWindowsUINotificationsToastTemplateType type) NOEXCEPT;
|
||||||
|
|
||||||
#undef EXTERN
|
#undef EXTERN
|
||||||
|
|
|
@ -1,28 +1,26 @@
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
#include "gobject/winrt-private.h"
|
#include "gobject/winrt-private.h"
|
||||||
#include "converter.hpp"
|
#include "converter.hpp"
|
||||||
#include "ginvoke.hpp"
|
#include "ginvoke.hpp"
|
||||||
|
|
||||||
gboolean winrt_InitApartment()
|
#include <windows.h>
|
||||||
|
|
||||||
|
static void ImplInitApartment()
|
||||||
{
|
{
|
||||||
try
|
const auto res = ::CoInitializeEx(nullptr, COINIT_APARTMENTTHREADED);
|
||||||
|
if (FAILED(res))
|
||||||
{
|
{
|
||||||
winrt::init_apartment();
|
if (res == RPC_E_CHANGED_MODE) // seems harmless
|
||||||
return true;
|
g_info("attempted to change COM apartment mode of thread %" PRIu32,
|
||||||
}
|
::GetCurrentThreadId());
|
||||||
catch(const winrt::hresult_error& e)
|
else
|
||||||
{
|
winrt::throw_hresult(res);
|
||||||
auto message = wsview_to_char(e.message());
|
|
||||||
std::cerr << message << '\n';
|
|
||||||
g_free(message);
|
|
||||||
if (e.code() == -2147417850 /* RPC_E_CHANGED_MODE */) // harmless
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
gboolean winrt_InitApartment() noexcept
|
||||||
|
{
|
||||||
|
return g_try_invoke0(ImplInitApartment).has_value();
|
||||||
}
|
}
|
||||||
|
|
||||||
static char* ImplGetTemplateContent(winrtWindowsUINotificationsToastTemplateType type)
|
static char* ImplGetTemplateContent(winrtWindowsUINotificationsToastTemplateType type)
|
||||||
|
|
Loading…
Reference in a new issue