Switch to Result for invalid language

This commit is contained in:
A-Walrus 2022-08-09 10:43:27 +03:00 committed by Blaž Hrastnik
parent e8add6f46d
commit 75e6a64327
2 changed files with 8 additions and 13 deletions

View File

@ -1254,14 +1254,10 @@ fn language(
let doc = doc_mut!(cx.editor);
let loader = cx.editor.syn_loader.clone();
if args[0] == "text" {
doc.set_language(None, Some(loader))
doc.set_language(None, None)
} else {
let ok = doc.set_language_by_language_id(&args[0], loader);
if !ok {
anyhow::bail!("invalid language: {}", args[0]);
}
doc.set_language_by_language_id(&args[0], cx.editor.syn_loader.clone())?;
}
doc.detect_indent_and_line_ending();

View File

@ -683,13 +683,12 @@ pub fn set_language_by_language_id(
&mut self,
language_id: &str,
config_loader: Arc<syntax::Loader>,
) -> bool {
let language_config = config_loader.language_config_for_language_id(language_id);
if language_config.is_none() {
return false;
}
self.set_language(language_config, Some(config_loader));
true
) -> anyhow::Result<()> {
let language_config = config_loader
.language_config_for_language_id(language_id)
.ok_or_else(|| anyhow!("invalid language id: {}", language_id))?;
self.set_language(Some(language_config), Some(config_loader));
Ok(())
}
/// Set the LSP.