mirror of
https://github.com/helix-editor/helix.git
synced 2025-01-18 21:17:08 +04:00
Add :reload-all
command (#4663)
This commit is contained in:
parent
46eb185d45
commit
8dac863a5b
@ -44,6 +44,7 @@
|
||||
| `:show-directory`, `:pwd` | Show the current working directory. |
|
||||
| `:encoding` | Set encoding. Based on `https://encoding.spec.whatwg.org`. |
|
||||
| `:reload` | Discard changes and reload from the source file. |
|
||||
| `:reload-all` | Discard changes and reload all documents from the source files. |
|
||||
| `:update` | Write changes only if the file has been modified. |
|
||||
| `:lsp-workspace-command` | Open workspace command picker |
|
||||
| `:lsp-restart` | Restarts the Language Server that is in use by the current doc |
|
||||
|
@ -1034,6 +1034,50 @@ fn reload(
|
||||
})
|
||||
}
|
||||
|
||||
fn reload_all(
|
||||
cx: &mut compositor::Context,
|
||||
_args: &[Cow<str>],
|
||||
event: PromptEvent,
|
||||
) -> anyhow::Result<()> {
|
||||
if event != PromptEvent::Validate {
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
let scrolloff = cx.editor.config().scrolloff;
|
||||
let view_id = view!(cx.editor).id;
|
||||
|
||||
let docs_view_ids: Vec<(DocumentId, Vec<ViewId>)> = cx
|
||||
.editor
|
||||
.documents_mut()
|
||||
.map(|doc| {
|
||||
let mut view_ids: Vec<_> = doc.selections().keys().cloned().collect();
|
||||
|
||||
if view_ids.is_empty() {
|
||||
doc.ensure_view_init(view_id);
|
||||
view_ids.push(view_id);
|
||||
};
|
||||
|
||||
(doc.id(), view_ids)
|
||||
})
|
||||
.collect();
|
||||
|
||||
for (doc_id, view_ids) in docs_view_ids {
|
||||
let doc = doc_mut!(cx.editor, &doc_id);
|
||||
|
||||
// Every doc is guaranteed to have at least 1 view at this point.
|
||||
let view = view_mut!(cx.editor, view_ids[0]);
|
||||
doc.reload(view)?;
|
||||
|
||||
for view_id in view_ids {
|
||||
let view = view_mut!(cx.editor, view_id);
|
||||
|
||||
view.ensure_cursor_in_view(doc, scrolloff);
|
||||
}
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
/// Update the [`Document`] if it has been modified.
|
||||
fn update(
|
||||
cx: &mut compositor::Context,
|
||||
@ -2051,6 +2095,13 @@ fn run_shell_command(
|
||||
fun: reload,
|
||||
completer: None,
|
||||
},
|
||||
TypableCommand {
|
||||
name: "reload-all",
|
||||
aliases: &[],
|
||||
doc: "Discard changes and reload all documents from the source files.",
|
||||
fun: reload_all,
|
||||
completer: None,
|
||||
},
|
||||
TypableCommand {
|
||||
name: "update",
|
||||
aliases: &[],
|
||||
|
Loading…
Reference in New Issue
Block a user