Always render local selections on top of remote ones

This commit is contained in:
Antonio Scandurra 2022-03-22 10:31:28 +01:00
parent 7d566ce455
commit 34e5a1f6bb

View file

@ -909,7 +909,7 @@ impl Element for EditorElement {
.anchor_before(DisplayPoint::new(end_row, 0).to_offset(&snapshot, Bias::Right)) .anchor_before(DisplayPoint::new(end_row, 0).to_offset(&snapshot, Bias::Right))
}; };
let mut selections = HashMap::default(); let mut selections = Vec::new();
let mut active_rows = BTreeMap::new(); let mut active_rows = BTreeMap::new();
let mut highlighted_rows = None; let mut highlighted_rows = None;
let mut highlighted_ranges = Vec::new(); let mut highlighted_ranges = Vec::new();
@ -922,11 +922,32 @@ impl Element for EditorElement {
&display_map, &display_map,
); );
let mut remote_selections = HashMap::default();
for (replica_id, selection) in display_map
.buffer_snapshot
.remote_selections_in_range(&(start_anchor.clone()..end_anchor.clone()))
{
// The local selections match the leader's selections.
if Some(replica_id) == view.leader_replica_id {
continue;
}
remote_selections
.entry(replica_id)
.or_insert(Vec::new())
.push(crate::Selection {
id: selection.id,
goal: selection.goal,
reversed: selection.reversed,
start: selection.start.to_display_point(&display_map),
end: selection.end.to_display_point(&display_map),
});
}
selections.extend(remote_selections);
if view.show_local_selections { if view.show_local_selections {
let local_selections = view.local_selections_in_range( let local_selections =
start_anchor.clone()..end_anchor.clone(), view.local_selections_in_range(start_anchor..end_anchor, &display_map);
&display_map,
);
for selection in &local_selections { for selection in &local_selections {
let is_empty = selection.start == selection.end; let is_empty = selection.start == selection.end;
let selection_start = snapshot.prev_line_boundary(selection.start).1; let selection_start = snapshot.prev_line_boundary(selection.start).1;
@ -943,7 +964,7 @@ impl Element for EditorElement {
// Render the local selections in the leader's color when following. // Render the local selections in the leader's color when following.
let local_replica_id = view.leader_replica_id.unwrap_or(view.replica_id(cx)); let local_replica_id = view.leader_replica_id.unwrap_or(view.replica_id(cx));
selections.insert( selections.push((
local_replica_id, local_replica_id,
local_selections local_selections
.into_iter() .into_iter()
@ -955,28 +976,7 @@ impl Element for EditorElement {
end: selection.end.to_display_point(&display_map), end: selection.end.to_display_point(&display_map),
}) })
.collect(), .collect(),
); ));
}
for (replica_id, selection) in display_map
.buffer_snapshot
.remote_selections_in_range(&(start_anchor..end_anchor))
{
// The local selections match the leader's selections.
if Some(replica_id) == view.leader_replica_id {
continue;
}
selections
.entry(replica_id)
.or_insert(Vec::new())
.push(crate::Selection {
id: selection.id,
goal: selection.goal,
reversed: selection.reversed,
start: selection.start.to_display_point(&display_map),
end: selection.end.to_display_point(&display_map),
});
} }
}); });
@ -1222,7 +1222,7 @@ pub struct LayoutState {
em_width: f32, em_width: f32,
em_advance: f32, em_advance: f32,
highlighted_ranges: Vec<(Range<DisplayPoint>, Color)>, highlighted_ranges: Vec<(Range<DisplayPoint>, Color)>,
selections: HashMap<ReplicaId, Vec<text::Selection<DisplayPoint>>>, selections: Vec<(ReplicaId, Vec<text::Selection<DisplayPoint>>)>,
context_menu: Option<(DisplayPoint, ElementBox)>, context_menu: Option<(DisplayPoint, ElementBox)>,
code_actions_indicator: Option<(u32, ElementBox)>, code_actions_indicator: Option<(u32, ElementBox)>,
} }