mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-02 19:31:39 +03:00
Implement Copy for multibuffer anchors
This commit is contained in:
parent
f71145bb32
commit
718f802157
@ -1162,7 +1162,7 @@ impl Editor {
|
|||||||
});
|
});
|
||||||
clone.selections.set_state(&self.selections);
|
clone.selections.set_state(&self.selections);
|
||||||
clone.scroll_position = self.scroll_position;
|
clone.scroll_position = self.scroll_position;
|
||||||
clone.scroll_top_anchor = self.scroll_top_anchor.clone();
|
clone.scroll_top_anchor = self.scroll_top_anchor;
|
||||||
clone.searchable = self.searchable;
|
clone.searchable = self.searchable;
|
||||||
clone
|
clone
|
||||||
}
|
}
|
||||||
@ -1305,7 +1305,7 @@ impl Editor {
|
|||||||
display_snapshot: self.display_map.update(cx, |map, cx| map.snapshot(cx)),
|
display_snapshot: self.display_map.update(cx, |map, cx| map.snapshot(cx)),
|
||||||
ongoing_scroll: self.ongoing_scroll,
|
ongoing_scroll: self.ongoing_scroll,
|
||||||
scroll_position: self.scroll_position,
|
scroll_position: self.scroll_position,
|
||||||
scroll_top_anchor: self.scroll_top_anchor.clone(),
|
scroll_top_anchor: self.scroll_top_anchor,
|
||||||
placeholder_text: self.placeholder_text.clone(),
|
placeholder_text: self.placeholder_text.clone(),
|
||||||
is_focused: self
|
is_focused: self
|
||||||
.handle
|
.handle
|
||||||
@ -1791,17 +1791,15 @@ impl Editor {
|
|||||||
.pending_anchor()
|
.pending_anchor()
|
||||||
.expect("extend_selection not called with pending selection");
|
.expect("extend_selection not called with pending selection");
|
||||||
if position >= tail {
|
if position >= tail {
|
||||||
pending_selection.start = tail_anchor.clone();
|
pending_selection.start = tail_anchor;
|
||||||
} else {
|
} else {
|
||||||
pending_selection.end = tail_anchor.clone();
|
pending_selection.end = tail_anchor;
|
||||||
pending_selection.reversed = true;
|
pending_selection.reversed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut pending_mode = self.selections.pending_mode().unwrap();
|
let mut pending_mode = self.selections.pending_mode().unwrap();
|
||||||
match &mut pending_mode {
|
match &mut pending_mode {
|
||||||
SelectMode::Word(range) | SelectMode::Line(range) => {
|
SelectMode::Word(range) | SelectMode::Line(range) => *range = tail_anchor..tail_anchor,
|
||||||
*range = tail_anchor.clone()..tail_anchor
|
|
||||||
}
|
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2145,10 +2143,9 @@ impl Editor {
|
|||||||
));
|
));
|
||||||
if following_text_allows_autoclose && preceding_text_matches_prefix {
|
if following_text_allows_autoclose && preceding_text_matches_prefix {
|
||||||
let anchor = snapshot.anchor_before(selection.end);
|
let anchor = snapshot.anchor_before(selection.end);
|
||||||
new_selections
|
new_selections.push((selection.map(|_| anchor), text.len()));
|
||||||
.push((selection.map(|_| anchor.clone()), text.len()));
|
|
||||||
new_autoclose_regions.push((
|
new_autoclose_regions.push((
|
||||||
anchor.clone(),
|
anchor,
|
||||||
text.len(),
|
text.len(),
|
||||||
selection.id,
|
selection.id,
|
||||||
bracket_pair.clone(),
|
bracket_pair.clone(),
|
||||||
@ -2169,10 +2166,8 @@ impl Editor {
|
|||||||
&& text.as_ref() == region.pair.end.as_str();
|
&& text.as_ref() == region.pair.end.as_str();
|
||||||
if should_skip {
|
if should_skip {
|
||||||
let anchor = snapshot.anchor_after(selection.end);
|
let anchor = snapshot.anchor_after(selection.end);
|
||||||
new_selections.push((
|
new_selections
|
||||||
selection.map(|_| anchor.clone()),
|
.push((selection.map(|_| anchor), region.pair.end.len()));
|
||||||
region.pair.end.len(),
|
|
||||||
));
|
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2204,7 +2199,7 @@ impl Editor {
|
|||||||
// text with the given input and move the selection to the end of the
|
// text with the given input and move the selection to the end of the
|
||||||
// newly inserted text.
|
// newly inserted text.
|
||||||
let anchor = snapshot.anchor_after(selection.end);
|
let anchor = snapshot.anchor_after(selection.end);
|
||||||
new_selections.push((selection.map(|_| anchor.clone()), 0));
|
new_selections.push((selection.map(|_| anchor), 0));
|
||||||
edits.push((selection.start..selection.end, text.clone()));
|
edits.push((selection.start..selection.end, text.clone()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2306,7 +2301,7 @@ impl Editor {
|
|||||||
}
|
}
|
||||||
|
|
||||||
let anchor = buffer.anchor_after(end);
|
let anchor = buffer.anchor_after(end);
|
||||||
let new_selection = selection.map(|_| anchor.clone());
|
let new_selection = selection.map(|_| anchor);
|
||||||
(
|
(
|
||||||
(start..end, new_text),
|
(start..end, new_text),
|
||||||
(insert_extra_newline, new_selection),
|
(insert_extra_newline, new_selection),
|
||||||
@ -2386,7 +2381,7 @@ impl Editor {
|
|||||||
.iter()
|
.iter()
|
||||||
.map(|s| {
|
.map(|s| {
|
||||||
let anchor = snapshot.anchor_after(s.end);
|
let anchor = snapshot.anchor_after(s.end);
|
||||||
s.map(|_| anchor.clone())
|
s.map(|_| anchor)
|
||||||
})
|
})
|
||||||
.collect::<Vec<_>>()
|
.collect::<Vec<_>>()
|
||||||
};
|
};
|
||||||
@ -3650,7 +3645,7 @@ impl Editor {
|
|||||||
String::new(),
|
String::new(),
|
||||||
));
|
));
|
||||||
let insertion_anchor = buffer.anchor_after(insertion_point);
|
let insertion_anchor = buffer.anchor_after(insertion_point);
|
||||||
edits.push((insertion_anchor.clone()..insertion_anchor, text));
|
edits.push((insertion_anchor..insertion_anchor, text));
|
||||||
|
|
||||||
let row_delta = range_to_move.start.row - insertion_point.row + 1;
|
let row_delta = range_to_move.start.row - insertion_point.row + 1;
|
||||||
|
|
||||||
@ -3755,7 +3750,7 @@ impl Editor {
|
|||||||
String::new(),
|
String::new(),
|
||||||
));
|
));
|
||||||
let insertion_anchor = buffer.anchor_after(insertion_point);
|
let insertion_anchor = buffer.anchor_after(insertion_point);
|
||||||
edits.push((insertion_anchor.clone()..insertion_anchor, text));
|
edits.push((insertion_anchor..insertion_anchor, text));
|
||||||
|
|
||||||
let row_delta = insertion_point.row - range_to_move.end.row + 1;
|
let row_delta = insertion_point.row - range_to_move.end.row + 1;
|
||||||
|
|
||||||
@ -4625,7 +4620,7 @@ impl Editor {
|
|||||||
cursor_anchor: position,
|
cursor_anchor: position,
|
||||||
cursor_position: point,
|
cursor_position: point,
|
||||||
scroll_position: self.scroll_position,
|
scroll_position: self.scroll_position,
|
||||||
scroll_top_anchor: self.scroll_top_anchor.clone(),
|
scroll_top_anchor: self.scroll_top_anchor,
|
||||||
scroll_top_row,
|
scroll_top_row,
|
||||||
}),
|
}),
|
||||||
cx,
|
cx,
|
||||||
|
@ -542,7 +542,7 @@ fn test_navigation_history(cx: &mut gpui::MutableAppContext) {
|
|||||||
// Set scroll position to check later
|
// Set scroll position to check later
|
||||||
editor.set_scroll_position(Vector2F::new(5.5, 5.5), cx);
|
editor.set_scroll_position(Vector2F::new(5.5, 5.5), cx);
|
||||||
let original_scroll_position = editor.scroll_position;
|
let original_scroll_position = editor.scroll_position;
|
||||||
let original_scroll_top_anchor = editor.scroll_top_anchor.clone();
|
let original_scroll_top_anchor = editor.scroll_top_anchor;
|
||||||
|
|
||||||
// Jump to the end of the document and adjust scroll
|
// Jump to the end of the document and adjust scroll
|
||||||
editor.move_to_end(&MoveToEnd, cx);
|
editor.move_to_end(&MoveToEnd, cx);
|
||||||
@ -556,12 +556,12 @@ fn test_navigation_history(cx: &mut gpui::MutableAppContext) {
|
|||||||
assert_eq!(editor.scroll_top_anchor, original_scroll_top_anchor);
|
assert_eq!(editor.scroll_top_anchor, original_scroll_top_anchor);
|
||||||
|
|
||||||
// Ensure we don't panic when navigation data contains invalid anchors *and* points.
|
// Ensure we don't panic when navigation data contains invalid anchors *and* points.
|
||||||
let mut invalid_anchor = editor.scroll_top_anchor.clone();
|
let mut invalid_anchor = editor.scroll_top_anchor;
|
||||||
invalid_anchor.text_anchor.buffer_id = Some(999);
|
invalid_anchor.text_anchor.buffer_id = Some(999);
|
||||||
let invalid_point = Point::new(9999, 0);
|
let invalid_point = Point::new(9999, 0);
|
||||||
editor.navigate(
|
editor.navigate(
|
||||||
Box::new(NavigationData {
|
Box::new(NavigationData {
|
||||||
cursor_anchor: invalid_anchor.clone(),
|
cursor_anchor: invalid_anchor,
|
||||||
cursor_position: invalid_point,
|
cursor_position: invalid_point,
|
||||||
scroll_top_anchor: invalid_anchor,
|
scroll_top_anchor: invalid_anchor,
|
||||||
scroll_top_row: invalid_point.row,
|
scroll_top_row: invalid_point.row,
|
||||||
|
@ -1607,16 +1607,13 @@ impl Element for EditorElement {
|
|||||||
|
|
||||||
highlighted_rows = view.highlighted_rows();
|
highlighted_rows = view.highlighted_rows();
|
||||||
let theme = cx.global::<Settings>().theme.as_ref();
|
let theme = cx.global::<Settings>().theme.as_ref();
|
||||||
highlighted_ranges = view.background_highlights_in_range(
|
highlighted_ranges =
|
||||||
start_anchor.clone()..end_anchor.clone(),
|
view.background_highlights_in_range(start_anchor..end_anchor, &display_map, theme);
|
||||||
&display_map,
|
|
||||||
theme,
|
|
||||||
);
|
|
||||||
|
|
||||||
let mut remote_selections = HashMap::default();
|
let mut remote_selections = HashMap::default();
|
||||||
for (replica_id, line_mode, cursor_shape, selection) in display_map
|
for (replica_id, line_mode, cursor_shape, selection) in display_map
|
||||||
.buffer_snapshot
|
.buffer_snapshot
|
||||||
.remote_selections_in_range(&(start_anchor.clone()..end_anchor.clone()))
|
.remote_selections_in_range(&(start_anchor..end_anchor))
|
||||||
{
|
{
|
||||||
// The local selections match the leader's selections.
|
// The local selections match the leader's selections.
|
||||||
if Some(replica_id) == view.leader_replica_id {
|
if Some(replica_id) == view.leader_replica_id {
|
||||||
|
@ -221,7 +221,7 @@ fn show_hover(
|
|||||||
|
|
||||||
start..end
|
start..end
|
||||||
} else {
|
} else {
|
||||||
anchor.clone()..anchor.clone()
|
anchor..anchor
|
||||||
};
|
};
|
||||||
|
|
||||||
Some(InfoPopover {
|
Some(InfoPopover {
|
||||||
|
@ -2305,7 +2305,7 @@ impl MultiBufferSnapshot {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
let (anchor_ix, anchor) = anchors.next().unwrap();
|
let (anchor_ix, anchor) = anchors.next().unwrap();
|
||||||
let mut anchor = anchor.clone();
|
let mut anchor = *anchor;
|
||||||
|
|
||||||
// Leave min and max anchors unchanged if invalid or
|
// Leave min and max anchors unchanged if invalid or
|
||||||
// if the old excerpt still exists at this location
|
// if the old excerpt still exists at this location
|
||||||
|
@ -6,7 +6,7 @@ use std::{
|
|||||||
};
|
};
|
||||||
use sum_tree::Bias;
|
use sum_tree::Bias;
|
||||||
|
|
||||||
#[derive(Clone, Eq, PartialEq, Debug, Hash)]
|
#[derive(Clone, Copy, Eq, PartialEq, Debug, Hash)]
|
||||||
pub struct Anchor {
|
pub struct Anchor {
|
||||||
pub(crate) buffer_id: Option<usize>,
|
pub(crate) buffer_id: Option<usize>,
|
||||||
pub(crate) excerpt_id: ExcerptId,
|
pub(crate) excerpt_id: ExcerptId,
|
||||||
|
@ -114,12 +114,12 @@ pub fn change(_: &mut Workspace, _: &VisualChange, cx: &mut ViewContext<Workspac
|
|||||||
};
|
};
|
||||||
|
|
||||||
edits.push((expanded_range, "\n"));
|
edits.push((expanded_range, "\n"));
|
||||||
new_selections.push(selection.map(|_| anchor.clone()));
|
new_selections.push(selection.map(|_| anchor));
|
||||||
} else {
|
} else {
|
||||||
let range = selection.map(|p| p.to_point(map)).range();
|
let range = selection.map(|p| p.to_point(map)).range();
|
||||||
let anchor = map.buffer_snapshot.anchor_after(range.end);
|
let anchor = map.buffer_snapshot.anchor_after(range.end);
|
||||||
edits.push((range, ""));
|
edits.push((range, ""));
|
||||||
new_selections.push(selection.map(|_| anchor.clone()));
|
new_selections.push(selection.map(|_| anchor));
|
||||||
}
|
}
|
||||||
selection.goal = SelectionGoal::None;
|
selection.goal = SelectionGoal::None;
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user