Speed up snapshoting

Config can be fairly big, no need to deep clone it frequently
This commit is contained in:
Aleksey Kladov 2021-01-06 15:46:31 +03:00
parent f7a15b5cd1
commit 66ed821e18
3 changed files with 6 additions and 6 deletions

View file

@ -67,7 +67,7 @@ pub(crate) struct GlobalState {
pub(crate) flycheck: Vec<FlycheckHandle>, pub(crate) flycheck: Vec<FlycheckHandle>,
pub(crate) flycheck_sender: Sender<flycheck::Message>, pub(crate) flycheck_sender: Sender<flycheck::Message>,
pub(crate) flycheck_receiver: Receiver<flycheck::Message>, pub(crate) flycheck_receiver: Receiver<flycheck::Message>,
pub(crate) config: Config, pub(crate) config: Arc<Config>,
pub(crate) analysis_host: AnalysisHost, pub(crate) analysis_host: AnalysisHost,
pub(crate) diagnostics: DiagnosticCollection, pub(crate) diagnostics: DiagnosticCollection,
pub(crate) mem_docs: FxHashMap<VfsPath, DocumentData>, pub(crate) mem_docs: FxHashMap<VfsPath, DocumentData>,
@ -83,7 +83,7 @@ pub(crate) struct GlobalState {
/// An immutable snapshot of the world's state at a point in time. /// An immutable snapshot of the world's state at a point in time.
pub(crate) struct GlobalStateSnapshot { pub(crate) struct GlobalStateSnapshot {
pub(crate) config: Config, pub(crate) config: Arc<Config>,
pub(crate) analysis: Analysis, pub(crate) analysis: Analysis,
pub(crate) check_fixes: CheckFixes, pub(crate) check_fixes: CheckFixes,
pub(crate) latest_requests: Arc<RwLock<LatestRequests>>, pub(crate) latest_requests: Arc<RwLock<LatestRequests>>,
@ -119,7 +119,7 @@ impl GlobalState {
flycheck: Vec::new(), flycheck: Vec::new(),
flycheck_sender, flycheck_sender,
flycheck_receiver, flycheck_receiver,
config, config: Arc::new(config),
analysis_host, analysis_host,
diagnostics: Default::default(), diagnostics: Default::default(),
mem_docs: FxHashMap::default(), mem_docs: FxHashMap::default(),
@ -184,7 +184,7 @@ impl GlobalState {
pub(crate) fn snapshot(&self) -> GlobalStateSnapshot { pub(crate) fn snapshot(&self) -> GlobalStateSnapshot {
GlobalStateSnapshot { GlobalStateSnapshot {
config: self.config.clone(), config: Arc::clone(&self.config),
workspaces: Arc::clone(&self.workspaces), workspaces: Arc::clone(&self.workspaces),
analysis: self.analysis_host.analysis(), analysis: self.analysis_host.analysis(),
vfs: Arc::clone(&self.vfs), vfs: Arc::clone(&self.vfs),

View file

@ -609,7 +609,7 @@ impl GlobalState {
if let Some(json) = configs.get_mut(0) { if let Some(json) = configs.get_mut(0) {
// Note that json can be null according to the spec if the client can't // Note that json can be null according to the spec if the client can't
// provide a configuration. This is handled in Config::update below. // provide a configuration. This is handled in Config::update below.
let mut config = this.config.clone(); let mut config = Config::clone(&*this.config);
config.update(json.take()); config.update(json.take());
this.update_configuration(config); this.update_configuration(config);
} }

View file

@ -18,7 +18,7 @@ use lsp_ext::StatusParams;
impl GlobalState { impl GlobalState {
pub(crate) fn update_configuration(&mut self, config: Config) { pub(crate) fn update_configuration(&mut self, config: Config) {
let _p = profile::span("GlobalState::update_configuration"); let _p = profile::span("GlobalState::update_configuration");
let old_config = mem::replace(&mut self.config, config); let old_config = mem::replace(&mut self.config, Arc::new(config));
if self.config.lru_capacity() != old_config.lru_capacity() { if self.config.lru_capacity() != old_config.lru_capacity() {
self.analysis_host.update_lru_capacity(self.config.lru_capacity()); self.analysis_host.update_lru_capacity(self.config.lru_capacity());
} }