Merge pull request #233 from zed-industries/fix-split-selection-into-lines

Place the cursor at end of first line when splitting selections into lines
This commit is contained in:
Max Brunsfeld 2021-11-22 16:25:19 -08:00 committed by GitHub
commit 66e27b7420
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -2003,16 +2003,7 @@ impl Editor {
let mut to_unfold = Vec::new(); let mut to_unfold = Vec::new();
let mut new_selections = Vec::new(); let mut new_selections = Vec::new();
for selection in selections.iter() { for selection in selections.iter() {
if selection.start.row != selection.end.row { for row in selection.start.row..selection.end.row {
new_selections.push(Selection {
id: post_inc(&mut self.next_selection_id),
start: selection.start,
end: selection.start,
reversed: false,
goal: SelectionGoal::None,
});
}
for row in selection.start.row + 1..selection.end.row {
let cursor = Point::new(row, buffer.line_len(row)); let cursor = Point::new(row, buffer.line_len(row));
new_selections.push(Selection { new_selections.push(Selection {
id: post_inc(&mut self.next_selection_id), id: post_inc(&mut self.next_selection_id),
@ -4460,7 +4451,7 @@ mod tests {
assert_eq!( assert_eq!(
view.selection_ranges(cx), view.selection_ranges(cx),
[ [
DisplayPoint::new(0, 1)..DisplayPoint::new(0, 1), DisplayPoint::new(0, 5)..DisplayPoint::new(0, 5),
DisplayPoint::new(1, 5)..DisplayPoint::new(1, 5), DisplayPoint::new(1, 5)..DisplayPoint::new(1, 5),
DisplayPoint::new(2, 5)..DisplayPoint::new(2, 5), DisplayPoint::new(2, 5)..DisplayPoint::new(2, 5),
DisplayPoint::new(3, 5)..DisplayPoint::new(3, 5), DisplayPoint::new(3, 5)..DisplayPoint::new(3, 5),