From 24e8e2244b39abffe4df9ac650dcd1b8975326dd Mon Sep 17 00:00:00 2001 From: Donghyun Kim Date: Sun, 16 Jun 2024 15:47:02 +0900 Subject: [PATCH 1/6] Reduce memory copy on Dart signal --- flutter_ffi_plugin/bin/src/message.dart | 10 +++++----- rust_crate/src/macros.rs | 2 +- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/flutter_ffi_plugin/bin/src/message.dart b/flutter_ffi_plugin/bin/src/message.dart index 04e4e98f..e99fcfd3 100644 --- a/flutter_ffi_plugin/bin/src/message.dart +++ b/flutter_ffi_plugin/bin/src/message.dart @@ -418,20 +418,20 @@ use std::sync::OnceLock; use tokio::sync::mpsc::unbounded_channel; type SignalHandlers = OnceLock< - HashMap, Vec) + HashMap) -> Result<(), Box> + Send + Sync>>, >; static SIGNAL_HANDLERS: SignalHandlers = OnceLock::new(); pub fn handle_dart_signal( message_id: i32, - message_bytes: Vec, + message_bytes: &[u8], binary: Vec ) { let hash_map = SIGNAL_HANDLERS.get_or_init(|| { let mut new_hash_map = HashMap::< i32, - Box, Vec) + Box) -> Result<(), Box> + Send + Sync>, >::new(); '''; @@ -452,10 +452,10 @@ pub fn handle_dart_signal( rustReceiveScript += ''' new_hash_map.insert( ${markedMessage.id}, - Box::new(|message_bytes: Vec, binary: Vec| { + Box::new(|message_bytes: &[u8], binary: Vec| { use super::$modulePath$filename::*; let message = ${normalizePascal(messageName)}::decode( - message_bytes.as_slice() + message_bytes )?; let dart_signal = DartSignal { message, diff --git a/rust_crate/src/macros.rs b/rust_crate/src/macros.rs index 95e7739e..213d0365 100644 --- a/rust_crate/src/macros.rs +++ b/rust_crate/src/macros.rs @@ -33,7 +33,7 @@ macro_rules! write_interface { binary_size: usize, ) { let message_bytes = - unsafe { std::slice::from_raw_parts(message_pointer, message_size).to_vec() }; + unsafe { std::slice::from_raw_parts(message_pointer, message_size) }; let binary = unsafe { std::slice::from_raw_parts(binary_pointer, binary_size).to_vec() }; messages::generated::handle_dart_signal(message_id, message_bytes, binary); From 11b86f0574b6842ecf4950269c9e0ba5fc01ed24 Mon Sep 17 00:00:00 2001 From: Donghyun Kim Date: Sun, 16 Jun 2024 15:57:43 +0900 Subject: [PATCH 2/6] Fix a wrong type annotation --- rust_crate/src/macros.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rust_crate/src/macros.rs b/rust_crate/src/macros.rs index 213d0365..7a4bb0e3 100644 --- a/rust_crate/src/macros.rs +++ b/rust_crate/src/macros.rs @@ -42,7 +42,7 @@ macro_rules! write_interface { #[cfg(target_family = "wasm")] #[wasm_bindgen::prelude::wasm_bindgen] pub fn send_dart_signal_extern(message_id: i32, message_bytes: &[u8], binary: &[u8]) { - let message_bytes = message_bytes.to_vec(); + let message_bytes = message_bytes; let binary = binary.to_vec(); messages::generated::handle_dart_signal(message_id, message_bytes, binary); } From 3434b87c65460ca1de6b051b376a17dd1e0b2580 Mon Sep 17 00:00:00 2001 From: Donghyun Kim Date: Sun, 16 Jun 2024 16:48:11 +0900 Subject: [PATCH 3/6] Unify binary types --- flutter_ffi_plugin/bin/src/message.dart | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/flutter_ffi_plugin/bin/src/message.dart b/flutter_ffi_plugin/bin/src/message.dart index e99fcfd3..1b98a24b 100644 --- a/flutter_ffi_plugin/bin/src/message.dart +++ b/flutter_ffi_plugin/bin/src/message.dart @@ -418,7 +418,7 @@ use std::sync::OnceLock; use tokio::sync::mpsc::unbounded_channel; type SignalHandlers = OnceLock< - HashMap) + HashMap Result<(), Box> + Send + Sync>>, >; static SIGNAL_HANDLERS: SignalHandlers = OnceLock::new(); @@ -426,12 +426,12 @@ static SIGNAL_HANDLERS: SignalHandlers = OnceLock::new(); pub fn handle_dart_signal( message_id: i32, message_bytes: &[u8], - binary: Vec + binary: &[u8] ) { let hash_map = SIGNAL_HANDLERS.get_or_init(|| { let mut new_hash_map = HashMap::< i32, - Box) + Box Result<(), Box> + Send + Sync>, >::new(); '''; @@ -452,14 +452,14 @@ pub fn handle_dart_signal( rustReceiveScript += ''' new_hash_map.insert( ${markedMessage.id}, - Box::new(|message_bytes: &[u8], binary: Vec| { + Box::new(|message_bytes: &[u8], binary: &[u8]| { use super::$modulePath$filename::*; let message = ${normalizePascal(messageName)}::decode( message_bytes )?; let dart_signal = DartSignal { message, - binary, + binary: binary.to_vec(), }; let mut guard = ${snakeName.toUpperCase()}_CHANNEL.lock()?; if guard.is_none() { From 6223ea802159da677dc1b33e54e945f03a7050fd Mon Sep 17 00:00:00 2001 From: Donghyun Kim Date: Sun, 16 Jun 2024 16:48:33 +0900 Subject: [PATCH 4/6] Fix a type mismatch --- rust_crate/src/macros.rs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/rust_crate/src/macros.rs b/rust_crate/src/macros.rs index 7a4bb0e3..927bdada 100644 --- a/rust_crate/src/macros.rs +++ b/rust_crate/src/macros.rs @@ -34,8 +34,7 @@ macro_rules! write_interface { ) { let message_bytes = unsafe { std::slice::from_raw_parts(message_pointer, message_size) }; - let binary = - unsafe { std::slice::from_raw_parts(binary_pointer, binary_size).to_vec() }; + let binary = unsafe { std::slice::from_raw_parts(binary_pointer, binary_size) }; messages::generated::handle_dart_signal(message_id, message_bytes, binary); } From 3db2e4f24c02692812583c6971a12ced7305666d Mon Sep 17 00:00:00 2001 From: Donghyun Kim Date: Sun, 16 Jun 2024 17:10:54 +0900 Subject: [PATCH 5/6] Fix a type mismatch --- rust_crate/src/macros.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/rust_crate/src/macros.rs b/rust_crate/src/macros.rs index 927bdada..8dc6097a 100644 --- a/rust_crate/src/macros.rs +++ b/rust_crate/src/macros.rs @@ -42,7 +42,7 @@ macro_rules! write_interface { #[wasm_bindgen::prelude::wasm_bindgen] pub fn send_dart_signal_extern(message_id: i32, message_bytes: &[u8], binary: &[u8]) { let message_bytes = message_bytes; - let binary = binary.to_vec(); + let binary = binary; messages::generated::handle_dart_signal(message_id, message_bytes, binary); } }; From fb3b03bc1d146042f134b3a41df352fb8a346530 Mon Sep 17 00:00:00 2001 From: Donghyun Kim Date: Sun, 16 Jun 2024 20:00:43 +0900 Subject: [PATCH 6/6] Improve code readability --- documentation/docs/tutorial.md | 3 ++- .../example/native/hub/src/sample_functions.rs | 11 ++++++----- rust_crate/src/macros.rs | 6 +++--- 3 files changed, 11 insertions(+), 9 deletions(-) diff --git a/documentation/docs/tutorial.md b/documentation/docs/tutorial.md index 8669599e..c9741016 100644 --- a/documentation/docs/tutorial.md +++ b/documentation/docs/tutorial.md @@ -127,13 +127,14 @@ Define an async Rust function that runs forever, sending numbers to Dart every s ```rust title="native/hub/src/sample_functions.rs" ... use crate::messages; +use std::time::Duration; ... pub async fn stream_amazing_number() { use messages::tutorial_resource::*; let mut current_number: i32 = 1; loop { - tokio::time::sleep(std::time::Duration::from_secs(1)).await; + tokio::time::sleep(Duration::from_secs(1)).await; MyAmazingNumber { current_number }.send_signal_to_dart(); // GENERATED current_number += 1; } diff --git a/flutter_ffi_plugin/example/native/hub/src/sample_functions.rs b/flutter_ffi_plugin/example/native/hub/src/sample_functions.rs index 2205bb4b..981fbc49 100755 --- a/flutter_ffi_plugin/example/native/hub/src/sample_functions.rs +++ b/flutter_ffi_plugin/example/native/hub/src/sample_functions.rs @@ -3,6 +3,7 @@ use crate::messages; use crate::tokio; use rinf::debug_print; +use std::time::Duration; use tokio::sync::Mutex; // Using the `cfg` macro enables conditional statement. @@ -57,7 +58,7 @@ pub async fn stream_fractal() { tokio::spawn(async move { loop { // Wait for 40 milliseconds on each frame - tokio::time::sleep(std::time::Duration::from_millis(40)).await; + tokio::time::sleep(Duration::from_millis(40)).await; if sender.capacity() == 0 { continue; } @@ -120,7 +121,7 @@ pub async fn run_debug_tests() { return; } - tokio::time::sleep(std::time::Duration::from_secs(1)).await; + tokio::time::sleep(Duration::from_secs(1)).await; debug_print!("Starting debug tests."); // Get the current time. @@ -138,15 +139,15 @@ pub async fn run_debug_tests() { // Test `tokio::join!` for futures. let join_first = async { - tokio::time::sleep(std::time::Duration::from_secs(1)).await; + tokio::time::sleep(Duration::from_secs(1)).await; debug_print!("First future finished."); }; let join_second = async { - tokio::time::sleep(std::time::Duration::from_secs(2)).await; + tokio::time::sleep(Duration::from_secs(2)).await; debug_print!("Second future finished."); }; let join_third = async { - tokio::time::sleep(std::time::Duration::from_secs(3)).await; + tokio::time::sleep(Duration::from_secs(3)).await; debug_print!("Third future finished."); }; tokio::join!(join_first, join_second, join_third); diff --git a/rust_crate/src/macros.rs b/rust_crate/src/macros.rs index 8dc6097a..cdc5c8fd 100644 --- a/rust_crate/src/macros.rs +++ b/rust_crate/src/macros.rs @@ -32,9 +32,9 @@ macro_rules! write_interface { binary_pointer: *const u8, binary_size: usize, ) { - let message_bytes = - unsafe { std::slice::from_raw_parts(message_pointer, message_size) }; - let binary = unsafe { std::slice::from_raw_parts(binary_pointer, binary_size) }; + use std::slice::from_raw_parts; + let message_bytes = unsafe { from_raw_parts(message_pointer, message_size) }; + let binary = unsafe { from_raw_parts(binary_pointer, binary_size) }; messages::generated::handle_dart_signal(message_id, message_bytes, binary); }