From 82d9b033f276f71a1f0d116784787c3bc61630ee Mon Sep 17 00:00:00 2001 From: fufesou Date: Sat, 30 Mar 2024 13:39:34 +0800 Subject: [PATCH] Fix. Custom client, get app name (#7562) Signed-off-by: fufesou --- flutter/windows/runner/main.cpp | 21 ++++++++++++--------- flutter/windows/runner/win32_window.cpp | 4 ++++ 2 files changed, 16 insertions(+), 9 deletions(-) diff --git a/flutter/windows/runner/main.cpp b/flutter/windows/runner/main.cpp index 2e6a9c0ce..7547f5e92 100644 --- a/flutter/windows/runner/main.cpp +++ b/flutter/windows/runner/main.cpp @@ -16,6 +16,8 @@ typedef int (*FUNC_RUSTDESK_GET_APP_NAME)(wchar_t*, int); /// Note: `--server`, `--service` are already handled in [core_main.rs]. const std::vector parameters_white_list = {"--install", "--cm"}; +const wchar_t* getWindowClassName(); + int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev, _In_ wchar_t *command_line, _In_ int show_command) { @@ -39,14 +41,6 @@ int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev, std::cout << "Failed to get free_c_args." << std::endl; return EXIT_FAILURE; } - std::wstring app_name = L"RustDesk"; - FUNC_RUSTDESK_GET_APP_NAME get_rustdesk_app_name = (FUNC_RUSTDESK_GET_APP_NAME)GetProcAddress(hInstance, "get_rustdesk_app_name"); - if (get_rustdesk_app_name) { - wchar_t app_name_buffer[512] = {0}; - if (get_rustdesk_app_name(app_name_buffer, 512) == 0) { - app_name = std::wstring(app_name_buffer); - } - } std::vector command_line_arguments = GetCommandLineArguments(); // Remove possible trailing whitespace from command line arguments @@ -68,8 +62,17 @@ int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev, std::vector rust_args(c_args, c_args + args_len); free_c_args(c_args, args_len); + std::wstring app_name = L"RustDesk"; + FUNC_RUSTDESK_GET_APP_NAME get_rustdesk_app_name = (FUNC_RUSTDESK_GET_APP_NAME)GetProcAddress(hInstance, "get_rustdesk_app_name"); + if (get_rustdesk_app_name) { + wchar_t app_name_buffer[512] = {0}; + if (get_rustdesk_app_name(app_name_buffer, 512) == 0) { + app_name = std::wstring(app_name_buffer); + } + } + // Uri links dispatch - HWND hwnd = ::FindWindow(_T("FLUTTER_RUNNER_WIN32_WINDOW"), app_name.c_str()); + HWND hwnd = ::FindWindowW(getWindowClassName(), app_name.c_str()); if (hwnd != NULL) { // Allow multiple flutter instances when being executed by parameters // contained in whitelists. diff --git a/flutter/windows/runner/win32_window.cpp b/flutter/windows/runner/win32_window.cpp index c15819df0..5c09f6500 100644 --- a/flutter/windows/runner/win32_window.cpp +++ b/flutter/windows/runner/win32_window.cpp @@ -257,3 +257,7 @@ bool Win32Window::OnCreate() { void Win32Window::OnDestroy() { // No-op; provided for subclasses. } + +const wchar_t* getWindowClassName() { + return kWindowClassName; +}