mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-28 04:45:05 +00:00
Speed up snapshoting
Config can be fairly big, no need to deep clone it frequently
This commit is contained in:
parent
f7a15b5cd1
commit
66ed821e18
3 changed files with 6 additions and 6 deletions
|
@ -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),
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue