mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 14:13:58 +00:00
internal: remove Default
from OpQueue
This commit is contained in:
parent
ac8509a74b
commit
fc6eb66450
4 changed files with 40 additions and 24 deletions
|
@ -46,6 +46,11 @@ pub(crate) struct FetchWorkspaceRequest {
|
||||||
pub(crate) force_crate_graph_reload: bool,
|
pub(crate) force_crate_graph_reload: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub(crate) struct FetchWorkspaceResponse {
|
||||||
|
pub(crate) workspaces: Vec<anyhow::Result<ProjectWorkspace>>,
|
||||||
|
pub(crate) force_crate_graph_reload: bool,
|
||||||
|
}
|
||||||
|
|
||||||
// Enforces drop order
|
// Enforces drop order
|
||||||
pub(crate) struct Handle<H, C> {
|
pub(crate) struct Handle<H, C> {
|
||||||
pub(crate) handle: H,
|
pub(crate) handle: H,
|
||||||
|
@ -146,8 +151,7 @@ pub(crate) struct GlobalState {
|
||||||
pub(crate) detached_files: FxHashSet<ManifestPath>,
|
pub(crate) detached_files: FxHashSet<ManifestPath>,
|
||||||
|
|
||||||
// op queues
|
// op queues
|
||||||
pub(crate) fetch_workspaces_queue:
|
pub(crate) fetch_workspaces_queue: OpQueue<FetchWorkspaceRequest, FetchWorkspaceResponse>,
|
||||||
OpQueue<FetchWorkspaceRequest, Option<(Vec<anyhow::Result<ProjectWorkspace>>, bool)>>,
|
|
||||||
pub(crate) fetch_build_data_queue:
|
pub(crate) fetch_build_data_queue:
|
||||||
OpQueue<(), (Arc<Vec<ProjectWorkspace>>, Vec<anyhow::Result<WorkspaceBuildScripts>>)>,
|
OpQueue<(), (Arc<Vec<ProjectWorkspace>>, Vec<anyhow::Result<WorkspaceBuildScripts>>)>,
|
||||||
pub(crate) fetch_proc_macros_queue: OpQueue<Vec<ProcMacroPaths>, bool>,
|
pub(crate) fetch_proc_macros_queue: OpQueue<Vec<ProcMacroPaths>, bool>,
|
||||||
|
@ -502,7 +506,7 @@ impl GlobalState {
|
||||||
mem_docs: self.mem_docs.clone(),
|
mem_docs: self.mem_docs.clone(),
|
||||||
semantic_tokens_cache: Arc::clone(&self.semantic_tokens_cache),
|
semantic_tokens_cache: Arc::clone(&self.semantic_tokens_cache),
|
||||||
proc_macros_loaded: !self.config.expand_proc_macros()
|
proc_macros_loaded: !self.config.expand_proc_macros()
|
||||||
|| *self.fetch_proc_macros_queue.last_op_result(),
|
|| self.fetch_proc_macros_queue.last_op_result().copied().unwrap_or(false),
|
||||||
flycheck: self.flycheck.clone(),
|
flycheck: self.flycheck.clone(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,7 +22,9 @@ use crate::{
|
||||||
diagnostics::{fetch_native_diagnostics, DiagnosticsGeneration, NativeDiagnosticsFetchKind},
|
diagnostics::{fetch_native_diagnostics, DiagnosticsGeneration, NativeDiagnosticsFetchKind},
|
||||||
discover::{DiscoverArgument, DiscoverCommand, DiscoverProjectMessage},
|
discover::{DiscoverArgument, DiscoverCommand, DiscoverProjectMessage},
|
||||||
flycheck::{self, FlycheckMessage},
|
flycheck::{self, FlycheckMessage},
|
||||||
global_state::{file_id_to_url, url_to_file_id, FetchWorkspaceRequest, GlobalState},
|
global_state::{
|
||||||
|
file_id_to_url, url_to_file_id, FetchWorkspaceRequest, FetchWorkspaceResponse, GlobalState,
|
||||||
|
},
|
||||||
hack_recover_crate_name,
|
hack_recover_crate_name,
|
||||||
handlers::dispatch::{NotificationDispatcher, RequestDispatcher},
|
handlers::dispatch::{NotificationDispatcher, RequestDispatcher},
|
||||||
lsp::{
|
lsp::{
|
||||||
|
@ -695,9 +697,9 @@ impl GlobalState {
|
||||||
let (state, msg) = match progress {
|
let (state, msg) = match progress {
|
||||||
ProjectWorkspaceProgress::Begin => (Progress::Begin, None),
|
ProjectWorkspaceProgress::Begin => (Progress::Begin, None),
|
||||||
ProjectWorkspaceProgress::Report(msg) => (Progress::Report, Some(msg)),
|
ProjectWorkspaceProgress::Report(msg) => (Progress::Report, Some(msg)),
|
||||||
ProjectWorkspaceProgress::End(workspaces, force_reload_crate_graph) => {
|
ProjectWorkspaceProgress::End(workspaces, force_crate_graph_reload) => {
|
||||||
self.fetch_workspaces_queue
|
let resp = FetchWorkspaceResponse { workspaces, force_crate_graph_reload };
|
||||||
.op_completed(Some((workspaces, force_reload_crate_graph)));
|
self.fetch_workspaces_queue.op_completed(resp);
|
||||||
if let Err(e) = self.fetch_workspace_error() {
|
if let Err(e) = self.fetch_workspace_error() {
|
||||||
error!("FetchWorkspaceError: {e}");
|
error!("FetchWorkspaceError: {e}");
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,12 +27,12 @@ pub(crate) type Cause = String;
|
||||||
pub(crate) struct OpQueue<Args = (), Output = ()> {
|
pub(crate) struct OpQueue<Args = (), Output = ()> {
|
||||||
op_requested: Option<(Cause, Args)>,
|
op_requested: Option<(Cause, Args)>,
|
||||||
op_in_progress: bool,
|
op_in_progress: bool,
|
||||||
last_op_result: Output,
|
last_op_result: Option<Output>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<Args, Output: Default> Default for OpQueue<Args, Output> {
|
impl<Args, Output> Default for OpQueue<Args, Output> {
|
||||||
fn default() -> Self {
|
fn default() -> Self {
|
||||||
Self { op_requested: None, op_in_progress: false, last_op_result: Default::default() }
|
Self { op_requested: None, op_in_progress: false, last_op_result: None }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -56,12 +56,12 @@ impl<Args, Output> OpQueue<Args, Output> {
|
||||||
pub(crate) fn op_completed(&mut self, result: Output) {
|
pub(crate) fn op_completed(&mut self, result: Output) {
|
||||||
assert!(self.op_in_progress);
|
assert!(self.op_in_progress);
|
||||||
self.op_in_progress = false;
|
self.op_in_progress = false;
|
||||||
self.last_op_result = result;
|
self.last_op_result = Some(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the result of the last operation.
|
/// Get the result of the last operation.
|
||||||
pub(crate) fn last_op_result(&self) -> &Output {
|
pub(crate) fn last_op_result(&self) -> Option<&Output> {
|
||||||
&self.last_op_result
|
self.last_op_result.as_ref()
|
||||||
}
|
}
|
||||||
|
|
||||||
// Is there an operation that has started, but hasn't yet finished?
|
// Is there an operation that has started, but hasn't yet finished?
|
||||||
|
|
|
@ -33,7 +33,7 @@ use vfs::{AbsPath, AbsPathBuf, ChangeKind};
|
||||||
use crate::{
|
use crate::{
|
||||||
config::{Config, FilesWatcher, LinkedProject},
|
config::{Config, FilesWatcher, LinkedProject},
|
||||||
flycheck::{FlycheckConfig, FlycheckHandle},
|
flycheck::{FlycheckConfig, FlycheckHandle},
|
||||||
global_state::{FetchWorkspaceRequest, GlobalState},
|
global_state::{FetchWorkspaceRequest, FetchWorkspaceResponse, GlobalState},
|
||||||
lsp_ext,
|
lsp_ext,
|
||||||
main_loop::{DiscoverProjectParam, Task},
|
main_loop::{DiscoverProjectParam, Task},
|
||||||
op_queue::Cause,
|
op_queue::Cause,
|
||||||
|
@ -448,15 +448,15 @@ impl GlobalState {
|
||||||
let _p = tracing::info_span!("GlobalState::switch_workspaces").entered();
|
let _p = tracing::info_span!("GlobalState::switch_workspaces").entered();
|
||||||
tracing::info!(%cause, "will switch workspaces");
|
tracing::info!(%cause, "will switch workspaces");
|
||||||
|
|
||||||
let Some((workspaces, force_reload_crate_graph)) =
|
let Some(FetchWorkspaceResponse { workspaces, force_crate_graph_reload }) =
|
||||||
self.fetch_workspaces_queue.last_op_result()
|
self.fetch_workspaces_queue.last_op_result()
|
||||||
else {
|
else {
|
||||||
return;
|
return;
|
||||||
};
|
};
|
||||||
|
|
||||||
info!(%cause, ?force_reload_crate_graph);
|
info!(%cause, ?force_crate_graph_reload);
|
||||||
if self.fetch_workspace_error().is_err() && !self.workspaces.is_empty() {
|
if self.fetch_workspace_error().is_err() && !self.workspaces.is_empty() {
|
||||||
if *force_reload_crate_graph {
|
if *force_crate_graph_reload {
|
||||||
self.recreate_crate_graph(cause);
|
self.recreate_crate_graph(cause);
|
||||||
}
|
}
|
||||||
// It only makes sense to switch to a partially broken workspace
|
// It only makes sense to switch to a partially broken workspace
|
||||||
|
@ -474,8 +474,12 @@ impl GlobalState {
|
||||||
.all(|(l, r)| l.eq_ignore_build_data(r));
|
.all(|(l, r)| l.eq_ignore_build_data(r));
|
||||||
|
|
||||||
if same_workspaces {
|
if same_workspaces {
|
||||||
let (workspaces, build_scripts) = self.fetch_build_data_queue.last_op_result();
|
let (workspaces, build_scripts) = match self.fetch_build_data_queue.last_op_result() {
|
||||||
if Arc::ptr_eq(workspaces, &self.workspaces) {
|
Some((workspaces, build_scripts)) => (workspaces.clone(), build_scripts.as_slice()),
|
||||||
|
None => (Default::default(), Default::default()),
|
||||||
|
};
|
||||||
|
|
||||||
|
if Arc::ptr_eq(&workspaces, &self.workspaces) {
|
||||||
info!("set build scripts to workspaces");
|
info!("set build scripts to workspaces");
|
||||||
|
|
||||||
let workspaces = workspaces
|
let workspaces = workspaces
|
||||||
|
@ -492,7 +496,7 @@ impl GlobalState {
|
||||||
self.workspaces = Arc::new(workspaces);
|
self.workspaces = Arc::new(workspaces);
|
||||||
} else {
|
} else {
|
||||||
info!("build scripts do not match the version of the active workspace");
|
info!("build scripts do not match the version of the active workspace");
|
||||||
if *force_reload_crate_graph {
|
if *force_crate_graph_reload {
|
||||||
self.recreate_crate_graph(cause);
|
self.recreate_crate_graph(cause);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -739,14 +743,16 @@ impl GlobalState {
|
||||||
pub(super) fn fetch_workspace_error(&self) -> Result<(), String> {
|
pub(super) fn fetch_workspace_error(&self) -> Result<(), String> {
|
||||||
let mut buf = String::new();
|
let mut buf = String::new();
|
||||||
|
|
||||||
let Some((last_op_result, _)) = self.fetch_workspaces_queue.last_op_result() else {
|
let Some(FetchWorkspaceResponse { workspaces, .. }) =
|
||||||
|
self.fetch_workspaces_queue.last_op_result()
|
||||||
|
else {
|
||||||
return Ok(());
|
return Ok(());
|
||||||
};
|
};
|
||||||
|
|
||||||
if last_op_result.is_empty() && self.config.discover_workspace_config().is_none() {
|
if workspaces.is_empty() && self.config.discover_workspace_config().is_none() {
|
||||||
stdx::format_to!(buf, "rust-analyzer failed to fetch workspace");
|
stdx::format_to!(buf, "rust-analyzer failed to fetch workspace");
|
||||||
} else {
|
} else {
|
||||||
for ws in last_op_result {
|
for ws in workspaces {
|
||||||
if let Err(err) = ws {
|
if let Err(err) = ws {
|
||||||
stdx::format_to!(buf, "rust-analyzer failed to load workspace: {:#}\n", err);
|
stdx::format_to!(buf, "rust-analyzer failed to load workspace: {:#}\n", err);
|
||||||
}
|
}
|
||||||
|
@ -763,7 +769,11 @@ impl GlobalState {
|
||||||
pub(super) fn fetch_build_data_error(&self) -> Result<(), String> {
|
pub(super) fn fetch_build_data_error(&self) -> Result<(), String> {
|
||||||
let mut buf = String::new();
|
let mut buf = String::new();
|
||||||
|
|
||||||
for ws in &self.fetch_build_data_queue.last_op_result().1 {
|
let Some((_, ws)) = &self.fetch_build_data_queue.last_op_result() else {
|
||||||
|
return Ok(());
|
||||||
|
};
|
||||||
|
|
||||||
|
for ws in ws {
|
||||||
match ws {
|
match ws {
|
||||||
Ok(data) => {
|
Ok(data) => {
|
||||||
if let Some(stderr) = data.error() {
|
if let Some(stderr) = data.error() {
|
||||||
|
|
Loading…
Reference in a new issue