mirror of
https://github.com/helix-editor/helix
synced 2024-05-21 04:06:06 +02:00
Do not stop reloading docs on error (#9870)
In the `reload-all` command, we should not stop reloading the documents if one error is found. Instead, we should report the error and continue trying to reload the current open documents. This is useful in cases where a backing file does not exist temporarily (e.g. when editing a git patch in the outstanding chain that doesn't have a file just yet). This change also remove the error messages in the cases where the backing is `None`, like in new docs or `tutor`.
This commit is contained in:
parent
4d2282cbcc
commit
6a22d7d1ca
|
@ -1318,7 +1318,11 @@ fn reload_all(
|
|||
// Ensure that the view is synced with the document's history.
|
||||
view.sync_changes(doc);
|
||||
|
||||
doc.reload(view, &cx.editor.diff_providers)?;
|
||||
if let Err(error) = doc.reload(view, &cx.editor.diff_providers) {
|
||||
cx.editor.set_error(format!("{}", error));
|
||||
continue;
|
||||
}
|
||||
|
||||
if let Some(path) = doc.path() {
|
||||
cx.editor
|
||||
.language_servers
|
||||
|
|
|
@ -993,11 +993,13 @@ pub fn reload(
|
|||
provider_registry: &DiffProviderRegistry,
|
||||
) -> Result<(), Error> {
|
||||
let encoding = self.encoding;
|
||||
let path = self
|
||||
.path()
|
||||
.filter(|path| path.exists())
|
||||
.ok_or_else(|| anyhow!("can't find file to reload from {:?}", self.display_name()))?
|
||||
.to_owned();
|
||||
let path = match self.path() {
|
||||
None => return Ok(()),
|
||||
Some(path) => match path.exists() {
|
||||
true => path.to_owned(),
|
||||
false => bail!("can't find file to reload from {:?}", self.display_name()),
|
||||
},
|
||||
};
|
||||
|
||||
// Once we have a valid path we check if its readonly status has changed
|
||||
self.detect_readonly();
|
||||
|
|
Loading…
Reference in New Issue