mirror of
https://github.com/helix-editor/helix.git
synced 2025-01-18 21:17:08 +04:00
refactor DocumentDidChange events
in the past DocumentDidChange and SelectionDidChange events were implemented in a simplistic manner to get a simple prototype out. However, if you want to use these events in more complex scenarios with interdependencies between the two handlers the system fell short. The `SelectionDidChange` event was dispatched before the DocumentDidChange (and not at all if the selection wasn't manually set) so any handlers that wants to track selection was not able to map their ranges yet. The reason for this was actually the way that apply_impl was structured. The function was slightly refactored to address these problems and enable moving other range mappings to event handlers.
This commit is contained in:
parent
3c8e41d9e2
commit
9c08ef4f15
@ -353,7 +353,7 @@ pub(super) fn register_hooks(handlers: &Handlers) {
|
||||
|
||||
let tx = handlers.signature_hints.clone();
|
||||
register_hook!(move |event: &mut DocumentDidChange<'_>| {
|
||||
if event.doc.config.load().lsp.auto_signature_help {
|
||||
if event.doc.config.load().lsp.auto_signature_help && !event.ghost_transaction {
|
||||
send_blocking(&tx, SignatureHelpEvent::ReTrigger);
|
||||
}
|
||||
Ok(())
|
||||
|
@ -1412,6 +1412,8 @@ fn apply_impl(
|
||||
doc: self,
|
||||
view: view_id,
|
||||
old_text: &old_doc,
|
||||
changes,
|
||||
ghost_transaction: !emit_lsp_notification,
|
||||
});
|
||||
|
||||
// if specified, the current selection should instead be replaced by transaction.selection
|
||||
|
@ -1,10 +1,16 @@
|
||||
use helix_core::Rope;
|
||||
use helix_core::{ChangeSet, Rope};
|
||||
use helix_event::events;
|
||||
|
||||
use crate::{Document, DocumentId, Editor, ViewId};
|
||||
|
||||
events! {
|
||||
DocumentDidChange<'a> { doc: &'a mut Document, view: ViewId, old_text: &'a Rope }
|
||||
DocumentDidChange<'a> {
|
||||
doc: &'a mut Document,
|
||||
view: ViewId,
|
||||
old_text: &'a Rope,
|
||||
changes: &'a ChangeSet,
|
||||
ghost_transaction: bool
|
||||
}
|
||||
SelectionDidChange<'a> { doc: &'a mut Document, view: ViewId }
|
||||
DiagnosticsDidChange<'a> { editor: &'a mut Editor, doc: DocumentId }
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user