Own Win32 main window session explicitly
This commit is contained in:
@@ -18,6 +18,11 @@ agent or engineer to remove them without reconstructing context from chat.
|
|||||||
|
|
||||||
## Reductions
|
## Reductions
|
||||||
|
|
||||||
|
- 2026-06-17: `DEBT-0003` was narrowed again.
|
||||||
|
`src/platform_windows/windows_runtime_shell.cpp` now binds a local
|
||||||
|
`MainWindowSession` object for the live Win32 session, and the window handle,
|
||||||
|
title buffer, and sandbox flag now live on that explicit runtime-owned
|
||||||
|
session instead of the retired retained accessor pocket.
|
||||||
- 2026-06-17: `DEBT-0016`/`DEBT-0017`/`DEBT-0050`/`DEBT-0051`/`DEBT-0053`/
|
- 2026-06-17: `DEBT-0016`/`DEBT-0017`/`DEBT-0050`/`DEBT-0051`/`DEBT-0053`/
|
||||||
`DEBT-0057` were narrowed again. `src/platform_web/web_platform_services.*`
|
`DEBT-0057` were narrowed again. `src/platform_web/web_platform_services.*`
|
||||||
now owns the concrete Web `PlatformServices` implementation and
|
now owns the concrete Web `PlatformServices` implementation and
|
||||||
|
|||||||
@@ -209,9 +209,10 @@ Latest slice:
|
|||||||
`windows_platform_services.cpp`.
|
`windows_platform_services.cpp`.
|
||||||
- `src/platform_windows/windows_platform_services.cpp` now keeps the VR/runtime
|
- `src/platform_windows/windows_platform_services.cpp` now keeps the VR/runtime
|
||||||
adapter surface without also owning the async GL context pocket.
|
adapter surface without also owning the async GL context pocket.
|
||||||
- `src/platform_windows/windows_main_window_session.*` now owns the retained
|
- `src/platform_windows/windows_main_window_session.*` now owns the explicit
|
||||||
Win32 main-window session fields (`HWND`, title buffer, sandbox flag)
|
Win32 `MainWindowSession` object (`HWND`, title buffer, sandbox flag) that
|
||||||
instead of leaving them inside `windows_runtime_shell.cpp`.
|
the runtime shell binds for the live session instead of leaving those fields
|
||||||
|
behind retained accessors inside `windows_runtime_shell.cpp`.
|
||||||
- `src/platform_windows/windows_runtime_shell.cpp` now keeps Windows runtime
|
- `src/platform_windows/windows_runtime_shell.cpp` now keeps Windows runtime
|
||||||
ownership focused on `App` and tablet lifetime rather than also owning
|
ownership focused on `App` and tablet lifetime rather than also owning
|
||||||
main-window session metadata.
|
main-window session metadata.
|
||||||
|
|||||||
@@ -211,8 +211,9 @@ Current slice:
|
|||||||
Win32 async GL context lock/swap state.
|
Win32 async GL context lock/swap state.
|
||||||
- `src/platform_windows/windows_platform_services.cpp` no longer carries the
|
- `src/platform_windows/windows_platform_services.cpp` no longer carries the
|
||||||
retained async render-context pocket.
|
retained async render-context pocket.
|
||||||
- `src/platform_windows/windows_main_window_session.*` now owns the retained
|
- `src/platform_windows/windows_main_window_session.*` now owns the explicit
|
||||||
Win32 main-window session fields.
|
Win32 `MainWindowSession` object that the runtime shell binds for the live
|
||||||
|
session.
|
||||||
- `src/platform_windows/windows_runtime_shell.cpp` no longer carries the
|
- `src/platform_windows/windows_runtime_shell.cpp` no longer carries the
|
||||||
retained `HWND` / title-buffer / sandbox pocket.
|
retained `HWND` / title-buffer / sandbox pocket.
|
||||||
- `src/platform_legacy/legacy_platform_services.*` now takes Android storage
|
- `src/platform_legacy/legacy_platform_services.*` now takes Android storage
|
||||||
|
|||||||
@@ -164,6 +164,7 @@ void setup_exception_handler(const App& app)
|
|||||||
BT_SetPreErrHandler([](INT_PTR nErrHandlerParam){
|
BT_SetPreErrHandler([](INT_PTR nErrHandlerParam){
|
||||||
const auto* app = reinterpret_cast<const App*>(nErrHandlerParam);
|
const auto* app = reinterpret_cast<const App*>(nErrHandlerParam);
|
||||||
auto* canvas_document = app && app->canvas ? app->canvas->m_canvas.get() : nullptr;
|
auto* canvas_document = app && app->canvas ? app->canvas->m_canvas.get() : nullptr;
|
||||||
|
const auto* session = bound_main_window_session();
|
||||||
if (canvas_document && canvas_document->m_unsaved)
|
if (canvas_document && canvas_document->m_unsaved)
|
||||||
{
|
{
|
||||||
auto t = std::time(nullptr);
|
auto t = std::time(nullptr);
|
||||||
@@ -177,7 +178,7 @@ void setup_exception_handler(const App& app)
|
|||||||
GetFullPathNameA(path.c_str(), MAX_PATH, abspath, NULL);
|
GetFullPathNameA(path.c_str(), MAX_PATH, abspath, NULL);
|
||||||
static char message[4096];
|
static char message[4096];
|
||||||
snprintf(message, sizeof(message), "File recovered in: %s", abspath);
|
snprintf(message, sizeof(message), "File recovered in: %s", abspath);
|
||||||
MessageBoxA(retained_main_window_handle_ref(), message, "File Recovery", MB_OK | MB_ICONWARNING);
|
MessageBoxA(session ? session->handle : nullptr, message, "File Recovery", MB_OK | MB_ICONWARNING);
|
||||||
}
|
}
|
||||||
LogRemote::I.file_close();
|
LogRemote::I.file_close();
|
||||||
}, reinterpret_cast<INT_PTR>(&app));
|
}, reinterpret_cast<INT_PTR>(&app));
|
||||||
@@ -339,7 +340,8 @@ int read_WMI_info()
|
|||||||
if (get_int(clsObj, L"CodeIntegrityPolicyEnforcementStatus") > 0)
|
if (get_int(clsObj, L"CodeIntegrityPolicyEnforcementStatus") > 0)
|
||||||
{
|
{
|
||||||
LOG("SANDBOX DETECTED");
|
LOG("SANDBOX DETECTED");
|
||||||
set_retained_main_window_sandboxed(true);
|
if (auto* session = bound_main_window_session())
|
||||||
|
session->sandboxed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
SAFEARRAY *psaNames = NULL;
|
SAFEARRAY *psaNames = NULL;
|
||||||
@@ -427,11 +429,11 @@ MainWindowStartupState initialize_main_window_startup_state(App& app)
|
|||||||
return startup;
|
return startup;
|
||||||
}
|
}
|
||||||
|
|
||||||
void create_main_window(const MainWindowStartupState& startup, HWND& hWnd, HINSTANCE hInst, const wchar_t* window_title)
|
void create_main_window(const MainWindowStartupState& startup, MainWindowSession& session, HINSTANCE hInst, const wchar_t* window_title)
|
||||||
{
|
{
|
||||||
const int window_width = startup.client_rect.right - startup.client_rect.left;
|
const int window_width = startup.client_rect.right - startup.client_rect.left;
|
||||||
const int window_height = startup.client_rect.bottom - startup.client_rect.top;
|
const int window_height = startup.client_rect.bottom - startup.client_rect.top;
|
||||||
hWnd = CreateWindow(
|
session.handle = CreateWindow(
|
||||||
startup.window_class.lpszClassName,
|
startup.window_class.lpszClassName,
|
||||||
window_title,
|
window_title,
|
||||||
startup.window_style,
|
startup.window_style,
|
||||||
@@ -492,7 +494,11 @@ pp::renderer::gl::OpenGlRuntimeInfo log_runtime_info()
|
|||||||
return runtime_info;
|
return runtime_info;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool upgrade_to_core_gl_context(const MainWindowStartupState& startup, HWND& hWnd, HINSTANCE hInst, const wchar_t* window_title, OpenGlWindowContext& context)
|
bool upgrade_to_core_gl_context(
|
||||||
|
const MainWindowStartupState& startup,
|
||||||
|
MainWindowSession& session,
|
||||||
|
HINSTANCE hInst,
|
||||||
|
OpenGlWindowContext& context)
|
||||||
{
|
{
|
||||||
if (!GLAD_WGL_ARB_create_context)
|
if (!GLAD_WGL_ARB_create_context)
|
||||||
{
|
{
|
||||||
@@ -506,11 +512,10 @@ bool upgrade_to_core_gl_context(const MainWindowStartupState& startup, HWND& hWn
|
|||||||
|
|
||||||
wglMakeCurrent(NULL, NULL);
|
wglMakeCurrent(NULL, NULL);
|
||||||
wglDeleteContext(context.render_context);
|
wglDeleteContext(context.render_context);
|
||||||
DestroyWindow(hWnd);
|
DestroyWindow(session.handle);
|
||||||
|
create_main_window(startup, session, hInst, session.title);
|
||||||
|
|
||||||
create_main_window(startup, hWnd, hInst, window_title);
|
context.device_context = GetDC(session.handle);
|
||||||
|
|
||||||
context.device_context = GetDC(hWnd);
|
|
||||||
int pixel_format = 0;
|
int pixel_format = 0;
|
||||||
wglChoosePixelFormatARB(
|
wglChoosePixelFormatARB(
|
||||||
context.device_context,
|
context.device_context,
|
||||||
@@ -529,12 +534,12 @@ bool upgrade_to_core_gl_context(const MainWindowStartupState& startup, HWND& hWn
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
MainStartupResult initialize_main_window_and_gl(MainWindowStartupState& startup, HWND& hWnd, HINSTANCE hInst, wchar_t* window_title, OpenGlWindowContext& context)
|
MainStartupResult initialize_main_window_and_gl(MainWindowStartupState& startup, MainWindowSession& session, HINSTANCE hInst, OpenGlWindowContext& context)
|
||||||
{
|
{
|
||||||
create_main_window(startup, hWnd, hInst, L"PanoPainter");
|
create_main_window(startup, session, hInst, L"PanoPainter");
|
||||||
initialize_pixel_format_descriptor(startup.pixel_format);
|
initialize_pixel_format_descriptor(startup.pixel_format);
|
||||||
|
|
||||||
context.device_context = GetDC(hWnd);
|
context.device_context = GetDC(session.handle);
|
||||||
const int pixel_format = ChoosePixelFormat(context.device_context, &startup.pixel_format);
|
const int pixel_format = ChoosePixelFormat(context.device_context, &startup.pixel_format);
|
||||||
SetPixelFormat(context.device_context, pixel_format, &startup.pixel_format);
|
SetPixelFormat(context.device_context, pixel_format, &startup.pixel_format);
|
||||||
context.render_context = wglCreateContext(context.device_context);
|
context.render_context = wglCreateContext(context.device_context);
|
||||||
@@ -553,13 +558,13 @@ MainStartupResult initialize_main_window_and_gl(MainWindowStartupState& startup,
|
|||||||
|
|
||||||
const auto renderer_name = std::string(context.runtime_info.renderer != nullptr ? context.runtime_info.renderer : "");
|
const auto renderer_name = std::string(context.runtime_info.renderer != nullptr ? context.runtime_info.renderer : "");
|
||||||
swprintf_s(
|
swprintf_s(
|
||||||
window_title,
|
session.title,
|
||||||
512,
|
512,
|
||||||
L"PanoPainter %s (%s)",
|
L"PanoPainter %s (%s)",
|
||||||
g_version_number_w,
|
g_version_number_w,
|
||||||
str2wstr(renderer_name).c_str());
|
str2wstr(renderer_name).c_str());
|
||||||
|
|
||||||
if (!upgrade_to_core_gl_context(startup, hWnd, hInst, window_title, context))
|
if (!upgrade_to_core_gl_context(startup, session, hInst, context))
|
||||||
return MainStartupResult::MissingCoreContextSupport;
|
return MainStartupResult::MissingCoreContextSupport;
|
||||||
|
|
||||||
return MainStartupResult::Ok;
|
return MainStartupResult::Ok;
|
||||||
|
|||||||
@@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
#include "platform_windows/windows_main_window_session.h"
|
||||||
#include "renderer_gl/opengl_capabilities.h"
|
#include "renderer_gl/opengl_capabilities.h"
|
||||||
|
|
||||||
class App;
|
class App;
|
||||||
@@ -52,11 +53,11 @@ void ensure_runtime_data_directory();
|
|||||||
void setup_exception_handler(const App& app);
|
void setup_exception_handler(const App& app);
|
||||||
int run_winmain_entry(int (*entry_point)(int, char**));
|
int run_winmain_entry(int (*entry_point)(int, char**));
|
||||||
MainWindowStartupState initialize_main_window_startup_state(App& app);
|
MainWindowStartupState initialize_main_window_startup_state(App& app);
|
||||||
void create_main_window(const MainWindowStartupState& startup, HWND& hWnd, HINSTANCE hInst, const wchar_t* window_title);
|
void create_main_window(const MainWindowStartupState& startup, MainWindowSession& session, HINSTANCE hInst, const wchar_t* window_title);
|
||||||
void initialize_pixel_format_descriptor(PIXELFORMATDESCRIPTOR& pixel_format);
|
void initialize_pixel_format_descriptor(PIXELFORMATDESCRIPTOR& pixel_format);
|
||||||
bool load_glad_entry_points(HDC device_context);
|
bool load_glad_entry_points(HDC device_context);
|
||||||
pp::renderer::gl::OpenGlRuntimeInfo log_runtime_info();
|
pp::renderer::gl::OpenGlRuntimeInfo log_runtime_info();
|
||||||
bool upgrade_to_core_gl_context(const MainWindowStartupState& startup, HWND& hWnd, HINSTANCE hInst, const wchar_t* window_title, OpenGlWindowContext& context);
|
bool upgrade_to_core_gl_context(const MainWindowStartupState& startup, MainWindowSession& session, HINSTANCE hInst, OpenGlWindowContext& context);
|
||||||
MainStartupResult initialize_main_window_and_gl(MainWindowStartupState& startup, HWND& hWnd, HINSTANCE hInst, wchar_t* window_title, OpenGlWindowContext& context);
|
MainStartupResult initialize_main_window_and_gl(MainWindowStartupState& startup, MainWindowSession& session, HINSTANCE hInst, OpenGlWindowContext& context);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,6 @@
|
|||||||
|
|
||||||
#include "legacy_preference_storage.h"
|
#include "legacy_preference_storage.h"
|
||||||
#include "platform_windows/windows_lifecycle_state.h"
|
#include "platform_windows/windows_lifecycle_state.h"
|
||||||
#include "platform_windows/windows_main_window_session.h"
|
|
||||||
#include "platform_windows/windows_stylus_input.h"
|
#include "platform_windows/windows_stylus_input.h"
|
||||||
|
|
||||||
namespace pp::platform::windows {
|
namespace pp::platform::windows {
|
||||||
|
|||||||
@@ -5,43 +5,18 @@
|
|||||||
namespace pp::platform::windows {
|
namespace pp::platform::windows {
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
struct RetainedMainWindowSessionState final {
|
MainWindowSession* retained_main_window_session = nullptr;
|
||||||
HWND handle{};
|
|
||||||
wchar_t title[512]{};
|
|
||||||
bool sandboxed = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
[[nodiscard]] RetainedMainWindowSessionState& retained_main_window_session_state() noexcept
|
}
|
||||||
|
|
||||||
|
void bind_main_window_session(MainWindowSession* session) noexcept
|
||||||
{
|
{
|
||||||
static RetainedMainWindowSessionState state;
|
retained_main_window_session = session;
|
||||||
return state;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
MainWindowSession* bound_main_window_session() noexcept
|
||||||
|
|
||||||
HWND& retained_main_window_handle_ref() noexcept
|
|
||||||
{
|
{
|
||||||
return retained_main_window_session_state().handle;
|
return retained_main_window_session;
|
||||||
}
|
|
||||||
|
|
||||||
wchar_t* retained_main_window_title_buffer() noexcept
|
|
||||||
{
|
|
||||||
return retained_main_window_session_state().title;
|
|
||||||
}
|
|
||||||
|
|
||||||
const wchar_t* retained_main_window_title() noexcept
|
|
||||||
{
|
|
||||||
return retained_main_window_session_state().title;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool retained_main_window_sandboxed() noexcept
|
|
||||||
{
|
|
||||||
return retained_main_window_session_state().sandboxed;
|
|
||||||
}
|
|
||||||
|
|
||||||
void set_retained_main_window_sandboxed(bool sandboxed) noexcept
|
|
||||||
{
|
|
||||||
retained_main_window_session_state().sandboxed = sandboxed;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,10 +4,13 @@
|
|||||||
|
|
||||||
namespace pp::platform::windows {
|
namespace pp::platform::windows {
|
||||||
|
|
||||||
[[nodiscard]] HWND& retained_main_window_handle_ref() noexcept;
|
struct MainWindowSession final {
|
||||||
[[nodiscard]] wchar_t* retained_main_window_title_buffer() noexcept;
|
HWND handle{};
|
||||||
[[nodiscard]] const wchar_t* retained_main_window_title() noexcept;
|
wchar_t title[512]{};
|
||||||
[[nodiscard]] bool retained_main_window_sandboxed() noexcept;
|
bool sandboxed = false;
|
||||||
void set_retained_main_window_sandboxed(bool sandboxed) noexcept;
|
};
|
||||||
|
|
||||||
|
void bind_main_window_session(MainWindowSession* session) noexcept;
|
||||||
|
[[nodiscard]] MainWindowSession* bound_main_window_session() noexcept;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -34,12 +34,18 @@ HWND pp_windows_main_window_handle();
|
|||||||
|
|
||||||
HWND pp_windows_main_window_handle()
|
HWND pp_windows_main_window_handle()
|
||||||
{
|
{
|
||||||
return pp::platform::windows::retained_main_window_handle_ref();
|
if (const auto* session = pp::platform::windows::bound_main_window_session())
|
||||||
|
return session->handle;
|
||||||
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void destroy_window()
|
void destroy_window()
|
||||||
{
|
{
|
||||||
pp::platform::windows::enqueue_main_thread_task(std::packaged_task<void()>([hWnd = pp::platform::windows::retained_main_window_handle_ref()] {
|
const auto* session = pp::platform::windows::bound_main_window_session();
|
||||||
|
if (!session)
|
||||||
|
return;
|
||||||
|
|
||||||
|
pp::platform::windows::enqueue_main_thread_task(std::packaged_task<void()>([hWnd = session->handle] {
|
||||||
pp::platform::windows::request_window_close(hWnd);
|
pp::platform::windows::request_window_close(hWnd);
|
||||||
}));
|
}));
|
||||||
}
|
}
|
||||||
@@ -71,9 +77,13 @@ void win32_update_stylus(float dt)
|
|||||||
|
|
||||||
void win32_update_fps(int frames)
|
void win32_update_fps(int frames)
|
||||||
{
|
{
|
||||||
|
const auto* session = pp::platform::windows::bound_main_window_session();
|
||||||
|
if (!session)
|
||||||
|
return;
|
||||||
|
|
||||||
pp::platform::windows::enqueue_main_thread_task(std::packaged_task<void()>([
|
pp::platform::windows::enqueue_main_thread_task(std::packaged_task<void()>([
|
||||||
hWnd = pp::platform::windows::retained_main_window_handle_ref(),
|
hWnd = session->handle,
|
||||||
window_title = pp::platform::windows::retained_main_window_title(),
|
window_title = session->title,
|
||||||
vr = &pp::platform::windows::platform_vr_state(),
|
vr = &pp::platform::windows::platform_vr_state(),
|
||||||
frames] {
|
frames] {
|
||||||
pp::platform::windows::update_window_fps(hWnd, window_title, *vr, frames);
|
pp::platform::windows::update_window_fps(hWnd, window_title, *vr, frames);
|
||||||
@@ -82,9 +92,13 @@ void win32_update_fps(int frames)
|
|||||||
|
|
||||||
bool win32_vr_start()
|
bool win32_vr_start()
|
||||||
{
|
{
|
||||||
|
const auto* session = pp::platform::windows::bound_main_window_session();
|
||||||
|
if (!session)
|
||||||
|
return false;
|
||||||
|
|
||||||
return pp::platform::windows::start_window_vr(
|
return pp::platform::windows::start_window_vr(
|
||||||
pp::platform::windows::platform_vr_state(),
|
pp::platform::windows::platform_vr_state(),
|
||||||
pp::platform::windows::retained_main_window_sandboxed());
|
session->sandboxed);
|
||||||
}
|
}
|
||||||
|
|
||||||
void win32_vr_stop()
|
void win32_vr_stop()
|
||||||
@@ -94,7 +108,8 @@ void win32_vr_stop()
|
|||||||
|
|
||||||
void win32_save_window_state()
|
void win32_save_window_state()
|
||||||
{
|
{
|
||||||
pp::platform::windows::save_window_preferences(pp::platform::windows::retained_main_window_handle_ref());
|
if (const auto* session = pp::platform::windows::bound_main_window_session())
|
||||||
|
pp::platform::windows::save_window_preferences(session->handle);
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace pp::platform::windows {
|
namespace pp::platform::windows {
|
||||||
|
|||||||
@@ -8,11 +8,12 @@ namespace pp::platform::windows {
|
|||||||
|
|
||||||
void run_bound_main_window_runtime(
|
void run_bound_main_window_runtime(
|
||||||
const MainWindowStartupState& startup,
|
const MainWindowStartupState& startup,
|
||||||
|
MainWindowSession& session,
|
||||||
bool start_in_vr,
|
bool start_in_vr,
|
||||||
HINSTANCE instance,
|
HINSTANCE instance,
|
||||||
SplashScreen& splash)
|
SplashScreen& splash)
|
||||||
{
|
{
|
||||||
run_main_window_runtime_session(startup, start_in_vr, instance, splash);
|
run_main_window_runtime_session(startup, session, start_in_vr, instance, splash);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "platform_windows/windows_bootstrap_helpers.h"
|
#include "platform_windows/windows_bootstrap_helpers.h"
|
||||||
|
#include "platform_windows/windows_main_window_session.h"
|
||||||
#include "platform_windows/windows_splash.h"
|
#include "platform_windows/windows_splash.h"
|
||||||
|
|
||||||
namespace pp::platform::windows {
|
namespace pp::platform::windows {
|
||||||
|
|
||||||
void run_bound_main_window_runtime(
|
void run_bound_main_window_runtime(
|
||||||
const MainWindowStartupState& startup,
|
const MainWindowStartupState& startup,
|
||||||
|
MainWindowSession& session,
|
||||||
bool start_in_vr,
|
bool start_in_vr,
|
||||||
HINSTANCE instance,
|
HINSTANCE instance,
|
||||||
SplashScreen& splash);
|
SplashScreen& splash);
|
||||||
|
|||||||
@@ -108,26 +108,26 @@ void shutdown_main_window_runtime(const MainWindowStartupState& startup, HINSTAN
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void run_main_window_runtime_session(const MainWindowStartupState& startup, bool start_in_vr, HINSTANCE instance, SplashScreen& splash)
|
void run_main_window_runtime_session(const MainWindowStartupState& startup, MainWindowSession& session, bool start_in_vr, HINSTANCE instance, SplashScreen& splash)
|
||||||
{
|
{
|
||||||
auto* app = bound_app();
|
auto* app = bound_app();
|
||||||
register_touch_window(retained_main_window_handle_ref());
|
register_touch_window(session.handle);
|
||||||
|
|
||||||
wglMakeCurrent(NULL, NULL);
|
wglMakeCurrent(NULL, NULL);
|
||||||
|
|
||||||
initialize_runtime_threads();
|
initialize_runtime_threads();
|
||||||
install_debug_gl_callbacks();
|
install_debug_gl_callbacks();
|
||||||
initialize_wintab(retained_main_window_handle_ref(), retained_main_window_sandboxed());
|
initialize_wintab(session.handle, session.sandboxed);
|
||||||
set_main_window_icon(retained_main_window_handle_ref());
|
set_main_window_icon(session.handle);
|
||||||
|
|
||||||
app->ui_sync();
|
app->ui_sync();
|
||||||
restore_window_placement(retained_main_window_handle_ref(), startup.show_command);
|
restore_window_placement(session.handle, startup.show_command);
|
||||||
|
|
||||||
if (start_in_vr)
|
if (start_in_vr)
|
||||||
app->vr_start();
|
app->vr_start();
|
||||||
|
|
||||||
LOG("show main window");
|
LOG("show main window");
|
||||||
SetForegroundWindow(retained_main_window_handle_ref());
|
SetForegroundWindow(session.handle);
|
||||||
|
|
||||||
splash.dismiss();
|
splash.dismiss();
|
||||||
|
|
||||||
|
|||||||
@@ -1,12 +1,14 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "platform_windows/windows_bootstrap_helpers.h"
|
#include "platform_windows/windows_bootstrap_helpers.h"
|
||||||
|
#include "platform_windows/windows_main_window_session.h"
|
||||||
#include "platform_windows/windows_splash.h"
|
#include "platform_windows/windows_splash.h"
|
||||||
|
|
||||||
namespace pp::platform::windows {
|
namespace pp::platform::windows {
|
||||||
|
|
||||||
void run_main_window_runtime_session(
|
void run_main_window_runtime_session(
|
||||||
const MainWindowStartupState& startup,
|
const MainWindowStartupState& startup,
|
||||||
|
MainWindowSession& session,
|
||||||
bool start_in_vr,
|
bool start_in_vr,
|
||||||
HINSTANCE instance,
|
HINSTANCE instance,
|
||||||
SplashScreen& splash);
|
SplashScreen& splash);
|
||||||
|
|||||||
@@ -16,6 +16,8 @@ namespace pp::platform::windows {
|
|||||||
int run_main_application(int argc, char** argv)
|
int run_main_application(int argc, char** argv)
|
||||||
{
|
{
|
||||||
const auto instance = GetModuleHandle(NULL);
|
const auto instance = GetModuleHandle(NULL);
|
||||||
|
auto session = MainWindowSession {};
|
||||||
|
bind_main_window_session(&session);
|
||||||
|
|
||||||
auto& app = initialize_bound_app_runtime();
|
auto& app = initialize_bound_app_runtime();
|
||||||
app.set_platform_services(&pp::platform::windows::platform_services());
|
app.set_platform_services(&pp::platform::windows::platform_services());
|
||||||
@@ -43,18 +45,19 @@ int run_main_application(int argc, char** argv)
|
|||||||
auto context = pp::platform::windows::OpenGlWindowContext {};
|
auto context = pp::platform::windows::OpenGlWindowContext {};
|
||||||
switch (pp::platform::windows::initialize_main_window_and_gl(
|
switch (pp::platform::windows::initialize_main_window_and_gl(
|
||||||
startup,
|
startup,
|
||||||
retained_main_window_handle_ref(),
|
session,
|
||||||
instance,
|
instance,
|
||||||
retained_main_window_title_buffer(),
|
|
||||||
context))
|
context))
|
||||||
{
|
{
|
||||||
case pp::platform::windows::MainStartupResult::Ok:
|
case pp::platform::windows::MainStartupResult::Ok:
|
||||||
break;
|
break;
|
||||||
case pp::platform::windows::MainStartupResult::GladLoadFailure:
|
case pp::platform::windows::MainStartupResult::GladLoadFailure:
|
||||||
release_bound_app();
|
release_bound_app();
|
||||||
|
bind_main_window_session(nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
case pp::platform::windows::MainStartupResult::MissingCoreContextSupport:
|
case pp::platform::windows::MainStartupResult::MissingCoreContextSupport:
|
||||||
release_bound_app();
|
release_bound_app();
|
||||||
|
bind_main_window_session(nullptr);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -69,6 +72,7 @@ int run_main_application(int argc, char** argv)
|
|||||||
app.initShaders();
|
app.initShaders();
|
||||||
app.cmd_convert(argv[2], argv[3]);
|
app.cmd_convert(argv[2], argv[3]);
|
||||||
release_bound_app();
|
release_bound_app();
|
||||||
|
bind_main_window_session(nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
case const_hash("-vrmode"):
|
case const_hash("-vrmode"):
|
||||||
start_in_vr = true;
|
start_in_vr = true;
|
||||||
@@ -78,8 +82,9 @@ int run_main_application(int argc, char** argv)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pp::platform::windows::run_bound_main_window_runtime(startup, start_in_vr, instance, splash);
|
pp::platform::windows::run_bound_main_window_runtime(startup, session, start_in_vr, instance, splash);
|
||||||
release_bound_app();
|
release_bound_app();
|
||||||
|
bind_main_window_session(nullptr);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -5,7 +5,6 @@
|
|||||||
#include "app.h"
|
#include "app.h"
|
||||||
#include "platform_windows/windows_lifecycle_state.h"
|
#include "platform_windows/windows_lifecycle_state.h"
|
||||||
#include "platform_windows/windows_lifecycle_shell.h"
|
#include "platform_windows/windows_lifecycle_shell.h"
|
||||||
#include "platform_windows/windows_main_window_session.h"
|
|
||||||
#include "platform_windows/windows_platform_services.h"
|
#include "platform_windows/windows_platform_services.h"
|
||||||
#include "platform_windows/windows_runtime_shell.h"
|
#include "platform_windows/windows_runtime_shell.h"
|
||||||
#include "platform_windows/windows_stylus_input.h"
|
#include "platform_windows/windows_stylus_input.h"
|
||||||
|
|||||||
Reference in New Issue
Block a user