mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-12 05:15:00 +00:00
Revert "Wait for previous UpdateFollowers
message ack before sending new ones"
This reverts commit fe93263ad4
.
This commit is contained in:
parent
8621c88a3c
commit
e7e45be6e1
4 changed files with 57 additions and 106 deletions
|
@ -4672,7 +4672,7 @@ async fn test_following(
|
||||||
cx_a: &mut TestAppContext,
|
cx_a: &mut TestAppContext,
|
||||||
cx_b: &mut TestAppContext,
|
cx_b: &mut TestAppContext,
|
||||||
) {
|
) {
|
||||||
deterministic.forbid_parking();
|
cx_a.foreground().forbid_parking();
|
||||||
cx_a.update(editor::init);
|
cx_a.update(editor::init);
|
||||||
cx_b.update(editor::init);
|
cx_b.update(editor::init);
|
||||||
|
|
||||||
|
@ -4791,14 +4791,11 @@ async fn test_following(
|
||||||
workspace_a.update(cx_a, |workspace, cx| {
|
workspace_a.update(cx_a, |workspace, cx| {
|
||||||
workspace.activate_item(&editor_a1, cx)
|
workspace.activate_item(&editor_a1, cx)
|
||||||
});
|
});
|
||||||
deterministic.run_until_parked();
|
workspace_b
|
||||||
assert_eq!(
|
.condition(cx_b, |workspace, cx| {
|
||||||
workspace_b.read_with(cx_b, |workspace, cx| workspace
|
workspace.active_item(cx).unwrap().id() == editor_b1.id()
|
||||||
.active_item(cx)
|
})
|
||||||
.unwrap()
|
.await;
|
||||||
.id()),
|
|
||||||
editor_b1.id()
|
|
||||||
);
|
|
||||||
|
|
||||||
// When client A navigates back and forth, client B does so as well.
|
// When client A navigates back and forth, client B does so as well.
|
||||||
workspace_a
|
workspace_a
|
||||||
|
@ -4806,74 +4803,49 @@ async fn test_following(
|
||||||
workspace::Pane::go_back(workspace, None, cx)
|
workspace::Pane::go_back(workspace, None, cx)
|
||||||
})
|
})
|
||||||
.await;
|
.await;
|
||||||
deterministic.run_until_parked();
|
workspace_b
|
||||||
assert_eq!(
|
.condition(cx_b, |workspace, cx| {
|
||||||
workspace_b.read_with(cx_b, |workspace, cx| workspace
|
workspace.active_item(cx).unwrap().id() == editor_b2.id()
|
||||||
.active_item(cx)
|
})
|
||||||
.unwrap()
|
.await;
|
||||||
.id()),
|
|
||||||
editor_b2.id()
|
|
||||||
);
|
|
||||||
|
|
||||||
workspace_a
|
workspace_a
|
||||||
.update(cx_a, |workspace, cx| {
|
.update(cx_a, |workspace, cx| {
|
||||||
workspace::Pane::go_forward(workspace, None, cx)
|
workspace::Pane::go_forward(workspace, None, cx)
|
||||||
})
|
})
|
||||||
.await;
|
.await;
|
||||||
workspace_a
|
workspace_b
|
||||||
.update(cx_a, |workspace, cx| {
|
.condition(cx_b, |workspace, cx| {
|
||||||
workspace::Pane::go_back(workspace, None, cx)
|
workspace.active_item(cx).unwrap().id() == editor_b1.id()
|
||||||
})
|
})
|
||||||
.await;
|
.await;
|
||||||
workspace_a
|
|
||||||
.update(cx_a, |workspace, cx| {
|
|
||||||
workspace::Pane::go_forward(workspace, None, cx)
|
|
||||||
})
|
|
||||||
.await;
|
|
||||||
deterministic.run_until_parked();
|
|
||||||
assert_eq!(
|
|
||||||
workspace_b.read_with(cx_b, |workspace, cx| workspace
|
|
||||||
.active_item(cx)
|
|
||||||
.unwrap()
|
|
||||||
.id()),
|
|
||||||
editor_b1.id()
|
|
||||||
);
|
|
||||||
|
|
||||||
// Changes to client A's editor are reflected on client B.
|
// Changes to client A's editor are reflected on client B.
|
||||||
editor_a1.update(cx_a, |editor, cx| {
|
editor_a1.update(cx_a, |editor, cx| {
|
||||||
editor.change_selections(None, cx, |s| s.select_ranges([1..1, 2..2]));
|
editor.change_selections(None, cx, |s| s.select_ranges([1..1, 2..2]));
|
||||||
});
|
});
|
||||||
deterministic.run_until_parked();
|
editor_b1
|
||||||
assert_eq!(
|
.condition(cx_b, |editor, cx| {
|
||||||
editor_b1.read_with(cx_b, |editor, cx| editor.selections.ranges(cx)),
|
editor.selections.ranges(cx) == vec![1..1, 2..2]
|
||||||
vec![1..1, 2..2]
|
})
|
||||||
);
|
.await;
|
||||||
|
|
||||||
editor_a1.update(cx_a, |editor, cx| editor.set_text("TWO", cx));
|
editor_a1.update(cx_a, |editor, cx| editor.set_text("TWO", cx));
|
||||||
deterministic.run_until_parked();
|
editor_b1
|
||||||
assert_eq!(
|
.condition(cx_b, |editor, cx| editor.text(cx) == "TWO")
|
||||||
editor_b1.read_with(cx_b, |editor, cx| editor.text(cx)),
|
.await;
|
||||||
"TWO"
|
|
||||||
);
|
|
||||||
|
|
||||||
editor_a1.update(cx_a, |editor, cx| {
|
editor_a1.update(cx_a, |editor, cx| {
|
||||||
editor.change_selections(None, cx, |s| s.select_ranges([3..3]));
|
editor.change_selections(None, cx, |s| s.select_ranges([3..3]));
|
||||||
editor.set_scroll_position(vec2f(0., 100.), cx);
|
editor.set_scroll_position(vec2f(0., 100.), cx);
|
||||||
});
|
});
|
||||||
deterministic.run_until_parked();
|
editor_b1
|
||||||
assert_eq!(
|
.condition(cx_b, |editor, cx| {
|
||||||
editor_b1.read_with(cx_b, |editor, cx| editor.selections.ranges(cx)),
|
editor.selections.ranges(cx) == vec![3..3]
|
||||||
vec![3..3]
|
})
|
||||||
);
|
.await;
|
||||||
|
|
||||||
// After unfollowing, client B stops receiving updates from client A.
|
// After unfollowing, client B stops receiving updates from client A.
|
||||||
assert_eq!(
|
|
||||||
workspace_b.read_with(cx_b, |workspace, cx| workspace
|
|
||||||
.active_item(cx)
|
|
||||||
.unwrap()
|
|
||||||
.id()),
|
|
||||||
editor_b1.id()
|
|
||||||
);
|
|
||||||
workspace_b.update(cx_b, |workspace, cx| {
|
workspace_b.update(cx_b, |workspace, cx| {
|
||||||
workspace.unfollow(&workspace.active_pane().clone(), cx)
|
workspace.unfollow(&workspace.active_pane().clone(), cx)
|
||||||
});
|
});
|
||||||
|
|
|
@ -192,7 +192,7 @@ impl Server {
|
||||||
.add_request_handler(Server::respond_to_contact_request)
|
.add_request_handler(Server::respond_to_contact_request)
|
||||||
.add_request_handler(Server::follow)
|
.add_request_handler(Server::follow)
|
||||||
.add_message_handler(Server::unfollow)
|
.add_message_handler(Server::unfollow)
|
||||||
.add_request_handler(Server::update_followers)
|
.add_message_handler(Server::update_followers)
|
||||||
.add_message_handler(Server::update_diff_base)
|
.add_message_handler(Server::update_diff_base)
|
||||||
.add_request_handler(Server::get_private_user_info);
|
.add_request_handler(Server::get_private_user_info);
|
||||||
|
|
||||||
|
@ -1437,7 +1437,6 @@ impl Server {
|
||||||
async fn update_followers(
|
async fn update_followers(
|
||||||
self: Arc<Self>,
|
self: Arc<Self>,
|
||||||
request: Message<proto::UpdateFollowers>,
|
request: Message<proto::UpdateFollowers>,
|
||||||
response: Response<proto::UpdateFollowers>,
|
|
||||||
) -> Result<()> {
|
) -> Result<()> {
|
||||||
let project_id = ProjectId::from_proto(request.payload.project_id);
|
let project_id = ProjectId::from_proto(request.payload.project_id);
|
||||||
let project_connection_ids = self
|
let project_connection_ids = self
|
||||||
|
@ -1465,7 +1464,6 @@ impl Server {
|
||||||
)?;
|
)?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
response.send(proto::Ack {})?;
|
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -229,7 +229,6 @@ request_messages!(
|
||||||
(Test, Test),
|
(Test, Test),
|
||||||
(UpdateBuffer, Ack),
|
(UpdateBuffer, Ack),
|
||||||
(UpdateDiagnosticSummary, Ack),
|
(UpdateDiagnosticSummary, Ack),
|
||||||
(UpdateFollowers, Ack),
|
|
||||||
(UpdateParticipantLocation, Ack),
|
(UpdateParticipantLocation, Ack),
|
||||||
(UpdateProject, Ack),
|
(UpdateProject, Ack),
|
||||||
(UpdateWorktree, Ack),
|
(UpdateWorktree, Ack),
|
||||||
|
|
|
@ -18,10 +18,7 @@ use collections::{hash_map, HashMap, HashSet};
|
||||||
use dock::{DefaultItemFactory, Dock, ToggleDockButton};
|
use dock::{DefaultItemFactory, Dock, ToggleDockButton};
|
||||||
use drag_and_drop::DragAndDrop;
|
use drag_and_drop::DragAndDrop;
|
||||||
use fs::{self, Fs};
|
use fs::{self, Fs};
|
||||||
use futures::{
|
use futures::{channel::oneshot, FutureExt, StreamExt};
|
||||||
channel::{mpsc, oneshot},
|
|
||||||
FutureExt, StreamExt,
|
|
||||||
};
|
|
||||||
use gpui::{
|
use gpui::{
|
||||||
actions,
|
actions,
|
||||||
elements::*,
|
elements::*,
|
||||||
|
@ -714,13 +711,14 @@ impl<T: Item> ItemHandle for ViewHandle<T> {
|
||||||
|
|
||||||
if let Some(followed_item) = self.to_followable_item_handle(cx) {
|
if let Some(followed_item) = self.to_followable_item_handle(cx) {
|
||||||
if let Some(message) = followed_item.to_state_proto(cx) {
|
if let Some(message) = followed_item.to_state_proto(cx) {
|
||||||
workspace.update_followers(proto::update_followers::Variant::CreateView(
|
workspace.update_followers(
|
||||||
proto::View {
|
proto::update_followers::Variant::CreateView(proto::View {
|
||||||
id: followed_item.id() as u64,
|
id: followed_item.id() as u64,
|
||||||
variant: Some(message),
|
variant: Some(message),
|
||||||
leader_id: workspace.leader_for_pane(&pane).map(|id| id.0),
|
leader_id: workspace.leader_for_pane(&pane).map(|id| id.0),
|
||||||
},
|
}),
|
||||||
));
|
cx,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -764,7 +762,7 @@ impl<T: Item> ItemHandle for ViewHandle<T> {
|
||||||
cx.after_window_update({
|
cx.after_window_update({
|
||||||
let pending_update = pending_update.clone();
|
let pending_update = pending_update.clone();
|
||||||
let pending_update_scheduled = pending_update_scheduled.clone();
|
let pending_update_scheduled = pending_update_scheduled.clone();
|
||||||
move |this, _| {
|
move |this, cx| {
|
||||||
pending_update_scheduled.store(false, SeqCst);
|
pending_update_scheduled.store(false, SeqCst);
|
||||||
this.update_followers(
|
this.update_followers(
|
||||||
proto::update_followers::Variant::UpdateView(
|
proto::update_followers::Variant::UpdateView(
|
||||||
|
@ -774,6 +772,7 @@ impl<T: Item> ItemHandle for ViewHandle<T> {
|
||||||
leader_id: leader_id.map(|id| id.0),
|
leader_id: leader_id.map(|id| id.0),
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
cx,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -1082,11 +1081,9 @@ pub struct Workspace {
|
||||||
leader_state: LeaderState,
|
leader_state: LeaderState,
|
||||||
follower_states_by_leader: FollowerStatesByLeader,
|
follower_states_by_leader: FollowerStatesByLeader,
|
||||||
last_leaders_by_pane: HashMap<WeakViewHandle<Pane>, PeerId>,
|
last_leaders_by_pane: HashMap<WeakViewHandle<Pane>, PeerId>,
|
||||||
follower_updates: mpsc::UnboundedSender<proto::update_followers::Variant>,
|
|
||||||
window_edited: bool,
|
window_edited: bool,
|
||||||
active_call: Option<(ModelHandle<ActiveCall>, Vec<gpui::Subscription>)>,
|
active_call: Option<(ModelHandle<ActiveCall>, Vec<gpui::Subscription>)>,
|
||||||
_observe_current_user: Task<()>,
|
_observe_current_user: Task<()>,
|
||||||
_update_followers: Task<Option<()>>,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default)]
|
#[derive(Default)]
|
||||||
|
@ -1169,34 +1166,6 @@ impl Workspace {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
let (follower_updates_tx, mut follower_updates_rx) = mpsc::unbounded();
|
|
||||||
let _update_followers = cx.spawn_weak(|this, cx| async move {
|
|
||||||
while let Some(update) = follower_updates_rx.next().await {
|
|
||||||
let this = this.upgrade(&cx)?;
|
|
||||||
let update_followers = this.read_with(&cx, |this, cx| {
|
|
||||||
if let Some(project_id) = this.project.read(cx).remote_id() {
|
|
||||||
if this.leader_state.followers.is_empty() {
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
Some(this.client.request(proto::UpdateFollowers {
|
|
||||||
project_id,
|
|
||||||
follower_ids:
|
|
||||||
this.leader_state.followers.iter().map(|f| f.0).collect(),
|
|
||||||
variant: Some(update),
|
|
||||||
}))
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
None
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
if let Some(update_followers) = update_followers {
|
|
||||||
update_followers.await.log_err();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
None
|
|
||||||
});
|
|
||||||
|
|
||||||
let handle = cx.handle();
|
let handle = cx.handle();
|
||||||
let weak_handle = cx.weak_handle();
|
let weak_handle = cx.weak_handle();
|
||||||
|
|
||||||
|
@ -1255,12 +1224,10 @@ impl Workspace {
|
||||||
project,
|
project,
|
||||||
leader_state: Default::default(),
|
leader_state: Default::default(),
|
||||||
follower_states_by_leader: Default::default(),
|
follower_states_by_leader: Default::default(),
|
||||||
follower_updates: follower_updates_tx,
|
|
||||||
last_leaders_by_pane: Default::default(),
|
last_leaders_by_pane: Default::default(),
|
||||||
window_edited: false,
|
window_edited: false,
|
||||||
active_call,
|
active_call,
|
||||||
_observe_current_user,
|
_observe_current_user,
|
||||||
_update_followers,
|
|
||||||
};
|
};
|
||||||
this.project_remote_id_changed(this.project.read(cx).remote_id(), cx);
|
this.project_remote_id_changed(this.project.read(cx).remote_id(), cx);
|
||||||
cx.defer(|this, cx| this.update_window_title(cx));
|
cx.defer(|this, cx| this.update_window_title(cx));
|
||||||
|
@ -2000,12 +1967,13 @@ impl Workspace {
|
||||||
cx.notify();
|
cx.notify();
|
||||||
}
|
}
|
||||||
|
|
||||||
self.update_followers(proto::update_followers::Variant::UpdateActiveView(
|
self.update_followers(
|
||||||
proto::UpdateActiveView {
|
proto::update_followers::Variant::UpdateActiveView(proto::UpdateActiveView {
|
||||||
id: self.active_item(cx).map(|item| item.id() as u64),
|
id: self.active_item(cx).map(|item| item.id() as u64),
|
||||||
leader_id: self.leader_for_pane(&pane).map(|id| id.0),
|
leader_id: self.leader_for_pane(&pane).map(|id| id.0),
|
||||||
},
|
}),
|
||||||
));
|
cx,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn handle_pane_event(
|
fn handle_pane_event(
|
||||||
|
@ -2626,8 +2594,22 @@ impl Workspace {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update_followers(&self, update: proto::update_followers::Variant) {
|
fn update_followers(
|
||||||
let _ = self.follower_updates.unbounded_send(update);
|
&self,
|
||||||
|
update: proto::update_followers::Variant,
|
||||||
|
cx: &AppContext,
|
||||||
|
) -> Option<()> {
|
||||||
|
let project_id = self.project.read(cx).remote_id()?;
|
||||||
|
if !self.leader_state.followers.is_empty() {
|
||||||
|
self.client
|
||||||
|
.send(proto::UpdateFollowers {
|
||||||
|
project_id,
|
||||||
|
follower_ids: self.leader_state.followers.iter().map(|f| f.0).collect(),
|
||||||
|
variant: Some(update),
|
||||||
|
})
|
||||||
|
.log_err();
|
||||||
|
}
|
||||||
|
None
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn leader_for_pane(&self, pane: &ViewHandle<Pane>) -> Option<PeerId> {
|
pub fn leader_for_pane(&self, pane: &ViewHandle<Pane>) -> Option<PeerId> {
|
||||||
|
|
Loading…
Reference in a new issue