From 35623058dfb4558746375cf2c5f404cffcaa3e37 Mon Sep 17 00:00:00 2001 From: kirawi <67773714+kirawi@users.noreply.github.com> Date: Sun, 18 Feb 2024 12:04:32 -0500 Subject: [PATCH] improve success message --- helix-term/src/commands.rs | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/helix-term/src/commands.rs b/helix-term/src/commands.rs index e8bb7e107eadc..12bf7f9a2f0a8 100644 --- a/helix-term/src/commands.rs +++ b/helix-term/src/commands.rs @@ -5524,16 +5524,24 @@ fn yank_diagnostic(cx: &mut Context) { let (view, doc) = current_ref!(cx.editor); let primary = doc.selection(view.id).primary(); - let diag = doc + let diag: Vec<_> = doc .diagnostics() .iter() .filter(|d| primary.overlaps(&helix_core::Range::new(d.range.start, d.range.end))) - .map(|d| d.message.clone()); + .map(|d| d.message.clone()) + .collect(); + let n = diag.len(); + if n == 0 { + cx.editor.set_error("No diagnostics under primary cursor"); + return; + } + let reg = cx.register.unwrap_or('+'); - match cx.editor.registers.write(reg, diag.collect()) { - Ok(_) => cx - .editor - .set_status(format!("Yanked diagnostic(s) to register {reg}")), + match cx.editor.registers.write(reg, diag) { + Ok(_) => cx.editor.set_status(format!( + "Yanked {n} diagnostic{} to register {reg}", + if n == 1 { "" } else { "s" } + )), Err(err) => cx.editor.set_error(err.to_string()), } }