Merge pull request #656 from SoLongAndThanksForAllThePizza/flutter_desktop
feat: insert core entry before launching flutter
This commit is contained in:
commit
5e2be73466
@ -1,17 +1,41 @@
|
|||||||
#include <flutter/dart_project.h>
|
#include <flutter/dart_project.h>
|
||||||
#include <flutter/flutter_view_controller.h>
|
#include <flutter/flutter_view_controller.h>
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
#include "flutter_window.h"
|
#include "flutter_window.h"
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
#include <bitsdojo_window_windows/bitsdojo_window_plugin.h>
|
#include <bitsdojo_window_windows/bitsdojo_window_plugin.h>
|
||||||
|
|
||||||
|
typedef bool (*FUNC_RUSTDESK_CORE_MAIN)(void);
|
||||||
|
|
||||||
auto bdw = bitsdojo_window_configure(BDW_CUSTOM_FRAME | BDW_HIDE_ON_STARTUP);
|
auto bdw = bitsdojo_window_configure(BDW_CUSTOM_FRAME | BDW_HIDE_ON_STARTUP);
|
||||||
int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev,
|
int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev,
|
||||||
_In_ wchar_t *command_line, _In_ int show_command) {
|
_In_ wchar_t *command_line, _In_ int show_command)
|
||||||
|
{
|
||||||
|
HINSTANCE hInstance = LoadLibraryA("librustdesk.dll");
|
||||||
|
if (!hInstance)
|
||||||
|
{
|
||||||
|
std::cout << "Failed to load librustdesk.dll" << std::endl;
|
||||||
|
return EXIT_FAILURE;
|
||||||
|
}
|
||||||
|
FUNC_RUSTDESK_CORE_MAIN rustdesk_core_main =
|
||||||
|
(FUNC_RUSTDESK_CORE_MAIN)GetProcAddress(hInstance, "rustdesk_core_main");
|
||||||
|
if (!rustdesk_core_main)
|
||||||
|
{
|
||||||
|
std::cout << "Failed to get rustdesk_core_main" << std::endl;
|
||||||
|
return EXIT_FAILURE;
|
||||||
|
}
|
||||||
|
if (!rustdesk_core_main())
|
||||||
|
{
|
||||||
|
std::cout << "Rustdesk core returns false, exiting without launching Flutter app" << std::endl;
|
||||||
|
return EXIT_SUCCESS;
|
||||||
|
}
|
||||||
|
|
||||||
// Attach to console when present (e.g., 'flutter run') or create a
|
// Attach to console when present (e.g., 'flutter run') or create a
|
||||||
// new console when running with a debugger.
|
// new console when running with a debugger.
|
||||||
if (!::AttachConsole(ATTACH_PARENT_PROCESS) && ::IsDebuggerPresent()) {
|
if (!::AttachConsole(ATTACH_PARENT_PROCESS) && ::IsDebuggerPresent())
|
||||||
|
{
|
||||||
CreateAndAttachConsole();
|
CreateAndAttachConsole();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -29,13 +53,15 @@ int APIENTRY wWinMain(_In_ HINSTANCE instance, _In_opt_ HINSTANCE prev,
|
|||||||
FlutterWindow window(project);
|
FlutterWindow window(project);
|
||||||
Win32Window::Point origin(10, 10);
|
Win32Window::Point origin(10, 10);
|
||||||
Win32Window::Size size(1280, 720);
|
Win32Window::Size size(1280, 720);
|
||||||
if (!window.CreateAndShow(L"flutter_hbb", origin, size)) {
|
if (!window.CreateAndShow(L"flutter_hbb", origin, size))
|
||||||
|
{
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
window.SetQuitOnClose(true);
|
window.SetQuitOnClose(true);
|
||||||
|
|
||||||
::MSG msg;
|
::MSG msg;
|
||||||
while (::GetMessage(&msg, nullptr, 0, 0)) {
|
while (::GetMessage(&msg, nullptr, 0, 0))
|
||||||
|
{
|
||||||
::TranslateMessage(&msg);
|
::TranslateMessage(&msg);
|
||||||
::DispatchMessage(&msg);
|
::DispatchMessage(&msg);
|
||||||
}
|
}
|
||||||
|
13
src/core_main.rs
Normal file
13
src/core_main.rs
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
/// Main entry of the RustDesk Core.
|
||||||
|
/// Return true if the app should continue running with UI(possibly Flutter), false if the app should exit.
|
||||||
|
pub fn core_main() -> bool {
|
||||||
|
let args = std::env::args().collect::<Vec<_>>();
|
||||||
|
// TODO: implement core_main()
|
||||||
|
if args.len() > 1 {
|
||||||
|
if args[1] == "--cm" {
|
||||||
|
// For test purpose only, this should stop any new window from popping up when a new connection is established.
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
true
|
||||||
|
}
|
@ -52,6 +52,13 @@ fn initialize(app_dir: &str) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// FFI for rustdesk core's main entry.
|
||||||
|
/// Return true if the app should continue running with UI(possibly Flutter), false if the app should exit.
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern "C" fn rustdesk_core_main() -> bool {
|
||||||
|
crate::core_main::core_main()
|
||||||
|
}
|
||||||
|
|
||||||
pub fn start_event_stream(s: StreamSink<String>) -> ResultType<()> {
|
pub fn start_event_stream(s: StreamSink<String>) -> ResultType<()> {
|
||||||
let _ = flutter::EVENT_STREAM.write().unwrap().insert(s);
|
let _ = flutter::EVENT_STREAM.write().unwrap().insert(s);
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -28,6 +28,11 @@ pub mod flutter;
|
|||||||
#[cfg(any(target_os = "android", target_os = "ios", feature = "flutter"))]
|
#[cfg(any(target_os = "android", target_os = "ios", feature = "flutter"))]
|
||||||
pub mod flutter_ffi;
|
pub mod flutter_ffi;
|
||||||
use common::*;
|
use common::*;
|
||||||
|
#[cfg(all(
|
||||||
|
not(any(target_os = "android", target_os = "ios")),
|
||||||
|
feature = "flutter"
|
||||||
|
))]
|
||||||
|
pub mod core_main;
|
||||||
#[cfg(feature = "cli")]
|
#[cfg(feature = "cli")]
|
||||||
pub mod cli;
|
pub mod cli;
|
||||||
#[cfg(all(windows, feature = "hbbs"))]
|
#[cfg(all(windows, feature = "hbbs"))]
|
||||||
|
Loading…
x
Reference in New Issue
Block a user