mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-04 19:37:54 +03:00
fix lsp config reload (#9415)
`syn_loader` was replaced rather than interior value being replace, old value was still being referenced and not updated after `:config-refresh`. By using `ArcSwap` like for `config`, each `.load()` call will return the most updated value. Co-authored-by: kyfan <kyfan@email>
This commit is contained in:
parent
7934ac7714
commit
fe869e5dc7
13 changed files with 89 additions and 41 deletions
|
@ -1,4 +1,5 @@
|
|||
use crate::compositor::{Component, Context};
|
||||
use arc_swap::ArcSwap;
|
||||
use tui::{
|
||||
buffer::Buffer as Surface,
|
||||
text::{Span, Spans, Text},
|
||||
|
@ -31,7 +32,7 @@ pub fn highlighted_code_block<'a>(
|
|||
text: &str,
|
||||
language: &str,
|
||||
theme: Option<&Theme>,
|
||||
config_loader: Arc<syntax::Loader>,
|
||||
config_loader: Arc<ArcSwap<syntax::Loader>>,
|
||||
additional_highlight_spans: Option<Vec<(usize, std::ops::Range<usize>)>>,
|
||||
) -> Text<'a> {
|
||||
let mut spans = Vec::new();
|
||||
|
@ -48,6 +49,7 @@ pub fn highlighted_code_block<'a>(
|
|||
|
||||
let ropeslice = RopeSlice::from(text);
|
||||
let syntax = config_loader
|
||||
.load()
|
||||
.language_configuration_for_injection_string(&InjectionLanguageMarker::Name(
|
||||
language.into(),
|
||||
))
|
||||
|
@ -121,7 +123,7 @@ pub fn highlighted_code_block<'a>(
|
|||
pub struct Markdown {
|
||||
contents: String,
|
||||
|
||||
config_loader: Arc<syntax::Loader>,
|
||||
config_loader: Arc<ArcSwap<syntax::Loader>>,
|
||||
}
|
||||
|
||||
// TODO: pre-render and self reference via Pin
|
||||
|
@ -140,7 +142,7 @@ impl Markdown {
|
|||
];
|
||||
const INDENT: &'static str = " ";
|
||||
|
||||
pub fn new(contents: String, config_loader: Arc<syntax::Loader>) -> Self {
|
||||
pub fn new(contents: String, config_loader: Arc<ArcSwap<syntax::Loader>>) -> Self {
|
||||
Self {
|
||||
contents,
|
||||
config_loader,
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue