From 757babb1b4390a7446a2a4f3efb1d9302961a1f6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Bla=C5=BE=20Hrastnik?= Date: Sun, 7 Nov 2021 18:56:09 +0900 Subject: [PATCH] dap: Avoid cloning *entire* stack frames when picking a thread --- helix-term/src/commands/dap.rs | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/helix-term/src/commands/dap.rs b/helix-term/src/commands/dap.rs index 5c45b2d6..57459779 100644 --- a/helix-term/src/commands/dap.rs +++ b/helix-term/src/commands/dap.rs @@ -115,7 +115,6 @@ fn thread_picker(cx: &mut Context, callback_fn: impl Fn(&mut Editor, &dap::Threa } let thread_states = debugger.thread_states.clone(); - let frames = debugger.stack_frames.clone(); let picker = FilePicker::new( threads, move |thread| { @@ -129,8 +128,14 @@ fn thread_picker(cx: &mut Context, callback_fn: impl Fn(&mut Editor, &dap::Threa .into() }, move |cx, thread, _action| callback_fn(cx.editor, thread), - move |_editor, thread| { - if let Some(frame) = frames.get(&thread.id).and_then(|bt| bt.get(0)) { + move |editor, thread| { + let frame = editor + .debugger + .as_ref() + .and_then(|debugger| debugger.stack_frames.get(&thread.id)) + .and_then(|bt| bt.get(0)); + + if let Some(frame) = frame { frame .source .as_ref()