Prune dead workspaces from WorkspaceStore on read

Also, remove unnecessary window handle from Workspace.
This commit is contained in:
Max Brunsfeld 2023-12-20 16:08:58 -08:00
parent 5e7c74c7b6
commit 42bdc11112

View File

@ -430,7 +430,6 @@ pub enum Event {
}
pub struct Workspace {
window_self: WindowHandle<Self>,
weak_self: WeakView<Self>,
workspace_actions: Vec<Box<dyn Fn(Div, &mut ViewContext<Self>) -> Div>>,
zoomed: Option<AnyWeakView>,
@ -642,9 +641,10 @@ impl Workspace {
this.serialize_workspace(cx);
cx.notify();
}),
cx.on_release(|this, _, cx| {
cx.on_release(|this, window, cx| {
this.app_state.workspace_store.update(cx, |store, _| {
store.workspaces.remove(&this.window_self);
let window = window.downcast::<Self>().unwrap();
debug_assert!(store.workspaces.remove(&window));
})
}),
];
@ -665,7 +665,6 @@ impl Workspace {
// });
});
Workspace {
window_self: window_handle,
weak_self: weak_handle.clone(),
zoomed: None,
zoomed_position: None,
@ -3708,7 +3707,7 @@ impl WorkspaceStore {
let active_project = ActiveCall::global(cx).read(cx).location().cloned();
let mut response = proto::FollowResponse::default();
for workspace in &this.workspaces {
this.workspaces.retain(|workspace| {
workspace
.update(cx, |workspace, cx| {
let handler_response = workspace.handle_follow(follower.project_id, cx);
@ -3726,8 +3725,8 @@ impl WorkspaceStore {
}
}
})
.ok();
}
.is_ok()
});
if let Err(ix) = this.followers.binary_search(&follower) {
this.followers.insert(ix, follower);
@ -3765,15 +3764,17 @@ impl WorkspaceStore {
let update = envelope.payload;
this.update(&mut cx, |this, cx| {
for workspace in &this.workspaces {
workspace.update(cx, |workspace, cx| {
let project_id = workspace.project.read(cx).remote_id();
if update.project_id != project_id && update.project_id.is_some() {
return;
}
workspace.handle_update_followers(leader_id, update.clone(), cx);
})?;
}
this.workspaces.retain(|workspace| {
workspace
.update(cx, |workspace, cx| {
let project_id = workspace.project.read(cx).remote_id();
if update.project_id != project_id && update.project_id.is_some() {
return;
}
workspace.handle_update_followers(leader_id, update.clone(), cx);
})
.is_ok()
});
Ok(())
})?
}