mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-04 03:17:45 +03:00
only show inline diagnostics after a delay
This commit is contained in:
parent
d8a115641d
commit
7283ef881f
12 changed files with 219 additions and 17 deletions
|
@ -11,6 +11,7 @@ use helix_view::{
|
|||
align_view,
|
||||
document::{DocumentOpenError, DocumentSavedEventResult},
|
||||
editor::{ConfigEvent, EditorEvent},
|
||||
events::DiagnosticsDidChange,
|
||||
graphics::Rect,
|
||||
theme,
|
||||
tree::Layout,
|
||||
|
@ -834,6 +835,12 @@ impl Application {
|
|||
&unchanged_diag_sources,
|
||||
Some(server_id),
|
||||
);
|
||||
|
||||
let doc = doc.id();
|
||||
helix_event::dispatch(DiagnosticsDidChange {
|
||||
editor: &mut self.editor,
|
||||
doc,
|
||||
});
|
||||
}
|
||||
}
|
||||
Notification::ShowMessage(params) => {
|
||||
|
|
|
@ -3550,6 +3550,8 @@ fn goto_first_diag(cx: &mut Context) {
|
|||
None => return,
|
||||
};
|
||||
doc.set_selection(view.id, selection);
|
||||
view.diagnostics_handler
|
||||
.immediately_show_diagnostic(doc, view.id);
|
||||
}
|
||||
|
||||
fn goto_last_diag(cx: &mut Context) {
|
||||
|
@ -3559,6 +3561,8 @@ fn goto_last_diag(cx: &mut Context) {
|
|||
None => return,
|
||||
};
|
||||
doc.set_selection(view.id, selection);
|
||||
view.diagnostics_handler
|
||||
.immediately_show_diagnostic(doc, view.id);
|
||||
}
|
||||
|
||||
fn goto_next_diag(cx: &mut Context) {
|
||||
|
@ -3581,6 +3585,8 @@ fn goto_next_diag(cx: &mut Context) {
|
|||
None => return,
|
||||
};
|
||||
doc.set_selection(view.id, selection);
|
||||
view.diagnostics_handler
|
||||
.immediately_show_diagnostic(doc, view.id);
|
||||
};
|
||||
|
||||
cx.editor.apply_motion(motion);
|
||||
|
@ -3609,6 +3615,8 @@ fn goto_prev_diag(cx: &mut Context) {
|
|||
None => return,
|
||||
};
|
||||
doc.set_selection(view.id, selection);
|
||||
view.diagnostics_handler
|
||||
.immediately_show_diagnostic(doc, view.id);
|
||||
};
|
||||
cx.editor.apply_motion(motion)
|
||||
}
|
||||
|
|
|
@ -271,7 +271,10 @@ fn diag_picker(
|
|||
let Some(path) = uri.as_path() else {
|
||||
return;
|
||||
};
|
||||
jump_to_position(cx.editor, path, diag.range, *offset_encoding, action)
|
||||
jump_to_position(cx.editor, path, diag.range, *offset_encoding, action);
|
||||
let (view, doc) = current!(cx.editor);
|
||||
view.diagnostics_handler
|
||||
.immediately_show_diagnostic(doc, view.id);
|
||||
},
|
||||
)
|
||||
.with_preview(move |_editor, PickerDiagnostic { uri, diag, .. }| {
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
use helix_event::{events, register_event};
|
||||
use helix_view::document::Mode;
|
||||
use helix_view::events::{DocumentDidChange, SelectionDidChange};
|
||||
use helix_view::events::{DiagnosticsDidChange, DocumentDidChange, SelectionDidChange};
|
||||
|
||||
use crate::commands;
|
||||
use crate::keymap::MappableCommand;
|
||||
|
@ -17,4 +17,5 @@ pub fn register() {
|
|||
register_event::<PostCommand>();
|
||||
register_event::<DocumentDidChange>();
|
||||
register_event::<SelectionDidChange>();
|
||||
register_event::<DiagnosticsDidChange>();
|
||||
}
|
||||
|
|
|
@ -14,6 +14,7 @@ pub use helix_view::handlers::Handlers;
|
|||
|
||||
mod auto_save;
|
||||
pub mod completion;
|
||||
mod diagnostics;
|
||||
mod signature_help;
|
||||
|
||||
pub fn setup(config: Arc<ArcSwap<Config>>) -> Handlers {
|
||||
|
@ -32,5 +33,6 @@ pub fn setup(config: Arc<ArcSwap<Config>>) -> Handlers {
|
|||
completion::register_hooks(&handlers);
|
||||
signature_help::register_hooks(&handlers);
|
||||
auto_save::register_hooks(&handlers);
|
||||
diagnostics::register_hooks(&handlers);
|
||||
handlers
|
||||
}
|
||||
|
|
24
helix-term/src/handlers/diagnostics.rs
Normal file
24
helix-term/src/handlers/diagnostics.rs
Normal file
|
@ -0,0 +1,24 @@
|
|||
use helix_event::{register_hook, send_blocking};
|
||||
use helix_view::document::Mode;
|
||||
use helix_view::events::DiagnosticsDidChange;
|
||||
use helix_view::handlers::diagnostics::DiagnosticEvent;
|
||||
use helix_view::handlers::Handlers;
|
||||
|
||||
use crate::events::OnModeSwitch;
|
||||
|
||||
pub(super) fn register_hooks(_handlers: &Handlers) {
|
||||
register_hook!(move |event: &mut DiagnosticsDidChange<'_>| {
|
||||
if event.editor.mode != Mode::Insert {
|
||||
for (view, _) in event.editor.tree.views_mut() {
|
||||
send_blocking(&view.diagnostics_handler.events, DiagnosticEvent::Refresh)
|
||||
}
|
||||
}
|
||||
Ok(())
|
||||
});
|
||||
register_hook!(move |event: &mut OnModeSwitch<'_, '_>| {
|
||||
for (view, _) in event.cx.editor.tree.views_mut() {
|
||||
view.diagnostics_handler.active = event.new_mode != Mode::Insert;
|
||||
}
|
||||
Ok(())
|
||||
});
|
||||
}
|
|
@ -186,11 +186,18 @@ impl EditorView {
|
|||
primary_cursor,
|
||||
});
|
||||
}
|
||||
let width = view.inner_width(doc);
|
||||
let config = doc.config.load();
|
||||
let enable_cursor_line = view
|
||||
.diagnostics_handler
|
||||
.show_cursorline_diagnostics(doc, view.id);
|
||||
let inline_diagnostic_config = config.inline_diagnostics.prepare(width, enable_cursor_line);
|
||||
decorations.add_decoration(InlineDiagnostics::new(
|
||||
doc,
|
||||
theme,
|
||||
primary_cursor,
|
||||
config.lsp.inline_diagnostics.clone(),
|
||||
inline_diagnostic_config,
|
||||
config.end_of_line_diagnostics,
|
||||
));
|
||||
render_document(
|
||||
surface,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue