Skip to content

Commit 7099438

Browse files
committed
internal: prepare to store OpQueue results in the queue itself
1 parent fab1c06 commit 7099438

File tree

3 files changed

+24
-13
lines changed

3 files changed

+24
-13
lines changed

crates/rust-analyzer/src/global_state.rs

Lines changed: 5 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -81,10 +81,13 @@ pub(crate) struct GlobalState {
8181
pub(crate) status: Status,
8282
pub(crate) source_root_config: SourceRootConfig,
8383
pub(crate) proc_macro_client: Option<ProcMacroClient>,
84+
8485
pub(crate) workspaces: Arc<Vec<ProjectWorkspace>>,
85-
pub(crate) fetch_workspaces_queue: OpQueue<()>,
86+
pub(crate) fetch_workspaces_queue: OpQueue<(), ()>,
87+
8688
pub(crate) workspace_build_data: Option<BuildDataResult>,
87-
pub(crate) fetch_build_data_queue: OpQueue<BuildDataCollector>,
89+
pub(crate) fetch_build_data_queue: OpQueue<BuildDataCollector, ()>,
90+
8891
latest_requests: Arc<RwLock<LatestRequests>>,
8992
}
9093

crates/rust-analyzer/src/op_queue.rs

Lines changed: 17 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1,29 +1,37 @@
1-
//! Bookkeeping to make sure only one long-running operation is executed.
1+
//! Bookkeeping to make sure only one long-running operation is being executed
2+
//! at a time.
23
3-
pub(crate) struct OpQueue<D> {
4-
op_scheduled: Option<D>,
4+
pub(crate) struct OpQueue<Args, Output> {
5+
op_scheduled: Option<Args>,
56
op_in_progress: bool,
7+
last_op_result: Output,
68
}
79

8-
impl<D> Default for OpQueue<D> {
10+
impl<Args, Output: Default> Default for OpQueue<Args, Output> {
911
fn default() -> Self {
10-
Self { op_scheduled: None, op_in_progress: false }
12+
Self { op_scheduled: None, op_in_progress: false, last_op_result: Default::default() }
1113
}
1214
}
1315

14-
impl<D> OpQueue<D> {
15-
pub(crate) fn request_op(&mut self, data: D) {
16+
impl<Args, Output> OpQueue<Args, Output> {
17+
pub(crate) fn request_op(&mut self, data: Args) {
1618
self.op_scheduled = Some(data);
1719
}
18-
pub(crate) fn should_start_op(&mut self) -> Option<D> {
20+
pub(crate) fn should_start_op(&mut self) -> Option<Args> {
1921
if self.op_in_progress {
2022
return None;
2123
}
2224
self.op_in_progress = self.op_scheduled.is_some();
2325
self.op_scheduled.take()
2426
}
25-
pub(crate) fn op_completed(&mut self) {
27+
pub(crate) fn op_completed(&mut self, result: Output) {
2628
assert!(self.op_in_progress);
2729
self.op_in_progress = false;
30+
self.last_op_result = result;
31+
}
32+
33+
#[allow(unused)]
34+
pub(crate) fn last_op_result(&self) -> &Output {
35+
&self.last_op_result
2836
}
2937
}

crates/rust-analyzer/src/reload.rs

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -140,7 +140,7 @@ impl GlobalState {
140140
});
141141
}
142142
pub(crate) fn fetch_build_data_completed(&mut self) {
143-
self.fetch_build_data_queue.op_completed()
143+
self.fetch_build_data_queue.op_completed(())
144144
}
145145

146146
pub(crate) fn fetch_workspaces_request(&mut self) {
@@ -195,7 +195,7 @@ impl GlobalState {
195195
});
196196
}
197197
pub(crate) fn fetch_workspaces_completed(&mut self) {
198-
self.fetch_workspaces_queue.op_completed()
198+
self.fetch_workspaces_queue.op_completed(())
199199
}
200200

201201
pub(crate) fn switch_workspaces(

0 commit comments

Comments
 (0)