From 4ba27bd85ca9a4aeed540b82bc8c7ea6cebb6266 Mon Sep 17 00:00:00 2001 From: Emil Ernerfeldt Date: Mon, 13 Nov 2023 20:25:02 +0100 Subject: [PATCH] Lock once up-front --- crates/eframe/src/native/run.rs | 50 +++++++++++++-------------------- 1 file changed, 20 insertions(+), 30 deletions(-) diff --git a/crates/eframe/src/native/run.rs b/crates/eframe/src/native/run.rs index 3ef4f1d7fb4..f73ebd35328 100644 --- a/crates/eframe/src/native/run.rs +++ b/crates/eframe/src/native/run.rs @@ -1878,7 +1878,14 @@ mod wgpu_integration { event: &winit::event::WindowEvent<'_>, focused_viewport: &mut Option, ) -> EventResult { - let viewport_id = self.shared.borrow().viewport_maps.get(&window_id).copied(); + let Self { + integration, + app, + shared, + } = self; + let mut shared = shared.borrow_mut(); + + let viewport_id = shared.viewport_maps.get(&window_id).copied(); // On Windows, if a window is resized by the user, it should repaint synchronously, inside the // event handler. @@ -1911,11 +1918,7 @@ mod wgpu_integration { NonZeroU32::new(physical_size.width), NonZeroU32::new(physical_size.height), ) { - self.shared.borrow_mut().painter.on_window_resized( - viewport_id, - width, - height, - ); + shared.painter.on_window_resized(viewport_id, width, height); } } } @@ -1924,41 +1927,28 @@ mod wgpu_integration { if let (Some(width), Some(height), Some(viewport_id)) = ( NonZeroU32::new(new_inner_size.width), NonZeroU32::new(new_inner_size.height), - self.shared.borrow().viewport_maps.get(&window_id).copied(), + shared.viewport_maps.get(&window_id).copied(), ) { repaint_asap = true; - self.shared.borrow_mut().painter.on_window_resized( - viewport_id, - width, - height, - ); + shared.painter.on_window_resized(viewport_id, width, height); } } - winit::event::WindowEvent::CloseRequested if self.integration.should_close() => { + winit::event::WindowEvent::CloseRequested if integration.should_close() => { log::debug!("Received WindowEvent::CloseRequested"); return EventResult::Exit; } _ => {} }; - let mut shared = self.shared.borrow_mut(); - - let event_response = if let Some((id, viewport)) = viewport_id - .and_then(|id| shared.viewports.get_mut(&id).map(|viewport| (id, viewport))) - { - if let Some(egui_winit) = &mut viewport.egui_winit { - Some( - self.integration - .on_event(self.app.as_mut(), event, egui_winit, id), - ) - } else { - None - } - } else { - None - }; + let event_response = viewport_id.and_then(|viewport_id| { + shared.viewports.get_mut(&viewport_id).and_then(|viewport| { + viewport.egui_winit.as_mut().map(|egui_winit| { + integration.on_event(app.as_mut(), event, egui_winit, viewport_id) + }) + }) + }); - if self.integration.should_close() { + if integration.should_close() { EventResult::Exit } else if let Some(event_response) = event_response { if event_response.repaint {