aboutsummaryrefslogtreecommitdiff
path: root/helix-term/src
diff options
context:
space:
mode:
authorGokul Soumya2022-02-14 16:41:53 +0000
committerGitHub2022-02-14 16:41:53 +0000
commit4c424d5ee442788b32eaaee67b4256aaa93aafa2 (patch)
tree7ea2a8e579b16400ae9573264c96b82123e1c828 /helix-term/src
parente267dc834a815ae2dd9d04c9e81fb206f81a2c99 (diff)
Refactor language config loading (#1658)
Diffstat (limited to 'helix-term/src')
-rw-r--r--helix-term/src/application.rs38
1 files changed, 12 insertions, 26 deletions
diff --git a/helix-term/src/application.rs b/helix-term/src/application.rs
index 52a5321f..6ba05498 100644
--- a/helix-term/src/application.rs
+++ b/helix-term/src/application.rs
@@ -1,4 +1,7 @@
-use helix_core::{merge_toml_values, pos_at_coords, syntax, Selection};
+use helix_core::{
+ config::{default_syntax_loader, user_syntax_loader},
+ pos_at_coords, syntax, Selection,
+};
use helix_dap::{self as dap, Payload, Request};
use helix_lsp::{lsp, util::lsp_pos_to_pos, LspProgressMap};
use helix_view::{editor::Breakpoint, theme, Editor};
@@ -69,21 +72,6 @@ impl Application {
std::sync::Arc::new(theme::Loader::new(&conf_dir, &helix_core::runtime_dir()));
// load default and user config, and merge both
- let builtin_err_msg =
- "Could not parse built-in languages.toml, something must be very wrong";
- let def_lang_conf: toml::Value =
- toml::from_slice(include_bytes!("../../languages.toml")).expect(builtin_err_msg);
- let def_syn_loader_conf: helix_core::syntax::Configuration =
- def_lang_conf.clone().try_into().expect(builtin_err_msg);
- let user_lang_conf = std::fs::read(conf_dir.join("languages.toml"))
- .ok()
- .map(|raw| toml::from_slice(&raw));
- let lang_conf = match user_lang_conf {
- Some(Ok(value)) => Ok(merge_toml_values(def_lang_conf, value)),
- Some(err @ Err(_)) => err,
- None => Ok(def_lang_conf),
- };
-
let true_color = config.editor.true_color || crate::true_color();
let theme = config
.theme
@@ -106,16 +94,14 @@ impl Application {
}
});
- let syn_loader_conf: helix_core::syntax::Configuration = lang_conf
- .and_then(|conf| conf.try_into())
- .unwrap_or_else(|err| {
- eprintln!("Bad language config: {}", err);
- eprintln!("Press <ENTER> to continue with default language config");
- use std::io::Read;
- // This waits for an enter press.
- let _ = std::io::stdin().read(&mut []);
- def_syn_loader_conf
- });
+ let syn_loader_conf = user_syntax_loader().unwrap_or_else(|err| {
+ eprintln!("Bad language config: {}", err);
+ eprintln!("Press <ENTER> to continue with default language config");
+ use std::io::Read;
+ // This waits for an enter press.
+ let _ = std::io::stdin().read(&mut []);
+ default_syntax_loader()
+ });
let syn_loader = std::sync::Arc::new(syntax::Loader::new(syn_loader_conf));
let mut editor = Editor::new(