From 39d6b3367bab7b8c10b9cda2aa942964a62b1440 Mon Sep 17 00:00:00 2001 From: EriKWDev Date: Mon, 9 Dec 2024 11:58:33 +0100 Subject: [PATCH 1/3] Support wgpu-tracing with same mechanism as wgpu examples (#5450) Gets the WGPU_TRACE env variable and gives it as an optional argument to request_device. Same mechanism as the wgpu-examples: https://github.com/gfx-rs/wgpu/blob/11b51693d3dc883b55b5ec0e30c340e43e6fac50/examples/src/framework.rs#L316 --- crates/egui-wgpu/src/lib.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/crates/egui-wgpu/src/lib.rs b/crates/egui-wgpu/src/lib.rs index e2c22a5cffc..8628bd06652 100644 --- a/crates/egui-wgpu/src/lib.rs +++ b/crates/egui-wgpu/src/lib.rs @@ -159,10 +159,11 @@ impl RenderState { ); } + let trace_path = std::env::var("WGPU_TRACE"); let (device, queue) = { crate::profile_scope!("request_device"); adapter - .request_device(&(*device_descriptor)(&adapter), None) + .request_device(&(*device_descriptor)(&adapter), trace_path.ok().as_ref().map(std::path::Path::new)) .await? }; From 5384600fa237266e8ecfdb4a0f109b0d94bf6849 Mon Sep 17 00:00:00 2001 From: Emil Ernerfeldt Date: Mon, 9 Dec 2024 12:11:27 +0100 Subject: [PATCH 2/3] cargo fmt --- crates/egui-wgpu/src/lib.rs | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/crates/egui-wgpu/src/lib.rs b/crates/egui-wgpu/src/lib.rs index 8628bd06652..29dc8d8f5c2 100644 --- a/crates/egui-wgpu/src/lib.rs +++ b/crates/egui-wgpu/src/lib.rs @@ -163,7 +163,10 @@ impl RenderState { let (device, queue) = { crate::profile_scope!("request_device"); adapter - .request_device(&(*device_descriptor)(&adapter), trace_path.ok().as_ref().map(std::path::Path::new)) + .request_device( + &(*device_descriptor)(&adapter), + trace_path.ok().as_ref().map(std::path::Path::new), + ) .await? }; From 13352d606496d7b1c5fd6fcfbe3c85baae39c040 Mon Sep 17 00:00:00 2001 From: Antoine Beyeler <49431240+abey79@users.noreply.github.com> Date: Mon, 9 Dec 2024 12:12:14 +0100 Subject: [PATCH 3/3] Fix drag-and-drop termination condition bug (#5452) I introduced this in #5433. TL;DR: there are two termination conditions for drag-and-drop operations: - ESC - release mouse The former _must_ happen at frame start (to properly capture the keystroke). The latter _must_ happen at end-of-frame (to _not_ shadow the mouse release event from user code). This is now properly documented. --- crates/egui/src/drag_and_drop.rs | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/crates/egui/src/drag_and_drop.rs b/crates/egui/src/drag_and_drop.rs index c58a5a48f64..e1997800834 100644 --- a/crates/egui/src/drag_and_drop.rs +++ b/crates/egui/src/drag_and_drop.rs @@ -27,31 +27,38 @@ impl DragAndDrop { ctx.on_end_pass("drag_and_drop_end_pass", Arc::new(Self::end_pass)); } + /// Interrupt drag-and-drop if the user presses the escape key. + /// + /// This needs to happen at frame start so we can properly capture the escape key. fn begin_pass(ctx: &Context) { let has_any_payload = Self::has_any_payload(ctx); if has_any_payload { - let abort_dnd = ctx.input_mut(|i| { - i.pointer.any_released() - || i.consume_key(crate::Modifiers::NONE, crate::Key::Escape) - }); + let abort_dnd_due_to_escape_key = + ctx.input_mut(|i| i.consume_key(crate::Modifiers::NONE, crate::Key::Escape)); - if abort_dnd { + if abort_dnd_due_to_escape_key { Self::clear_payload(ctx); } } } + /// Interrupt drag-and-drop if the user releases the mouse button. + /// + /// This is a catch-all safety net in case user code doesn't capture the drag payload itself. + /// This must happen at end-of-frame such that we don't shadow the mouse release event from user + /// code. fn end_pass(ctx: &Context) { - let mut is_dragging = false; + let has_any_payload = Self::has_any_payload(ctx); - ctx.data_mut(|data| { - let state = data.get_temp_mut_or_default::(Id::NULL); - is_dragging = state.payload.is_some(); - }); + if has_any_payload { + let abort_dnd_due_to_mouse_release = ctx.input_mut(|i| i.pointer.any_released()); - if is_dragging { - ctx.set_cursor_icon(CursorIcon::Grabbing); + if abort_dnd_due_to_mouse_release { + Self::clear_payload(ctx); + } else { + ctx.set_cursor_icon(CursorIcon::Grabbing); + } } }