summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authora5ob7r <12132068+a5ob7r@users.noreply.github.com>2022-01-07 18:03:15 +0900
committerChristian Duerr <contact@christianduerr.com>2022-01-08 21:52:58 +0100
commitd86e79f1ac47291672632c7c4edcded7a24293bb (patch)
treec652e8a88f0abb616d703a04fb3a99b8cdb4b64b
parent7e0636810ed9a1b003cb62f4a0b8a3e632610d96 (diff)
downloadalacritty-d86e79f1ac47291672632c7c4edcded7a24293bb.tar.gz
alacritty-d86e79f1ac47291672632c7c4edcded7a24293bb.zip
Fix last column block selection
This fixes a regression introduced in 8e584099, where block selections containing the last cell would have the trailing newline stripped and be joined into one long line on copy.
-rw-r--r--alacritty_terminal/src/term/mod.rs105
1 files changed, 83 insertions, 22 deletions
diff --git a/alacritty_terminal/src/term/mod.rs b/alacritty_terminal/src/term/mod.rs
index ef71f6f1..ce939401 100644
--- a/alacritty_terminal/src/term/mod.rs
+++ b/alacritty_terminal/src/term/mod.rs
@@ -358,12 +358,9 @@ impl<T> Term<T> {
res += self
.line_to_string(line, start.column..end.column, start.column.0 != 0)
.trim_end();
-
- // If the last column is included, newline is appended automatically.
- if end.column != self.columns() - 1 {
- res += "\n";
- }
+ res += "\n";
}
+
res += self.line_to_string(end.line, start.column..end.column, true).trim_end();
},
Some(Selection { ty: SelectionType::Lines, .. }) => {
@@ -2019,6 +2016,52 @@ mod tests {
}
#[test]
+ fn simple_selection_works() {
+ let size = SizeInfo::new(5., 5., 1.0, 1.0, 0.0, 0.0, false);
+ let mut term = Term::new(&Config::default(), size, ());
+ let grid = term.grid_mut();
+ for i in 0..4 {
+ if i == 1 {
+ continue;
+ }
+
+ grid[Line(i)][Column(0)].c = '"';
+
+ for j in 1..4 {
+ grid[Line(i)][Column(j)].c = 'a';
+ }
+
+ grid[Line(i)][Column(4)].c = '"';
+ }
+ grid[Line(2)][Column(0)].c = ' ';
+ grid[Line(2)][Column(4)].c = ' ';
+ grid[Line(2)][Column(4)].flags.insert(Flags::WRAPLINE);
+ grid[Line(3)][Column(0)].c = ' ';
+
+ // Multiple lines contain an empty line.
+ term.selection = Some(Selection::new(
+ SelectionType::Simple,
+ Point { line: Line(0), column: Column(0) },
+ Side::Left,
+ ));
+ if let Some(s) = term.selection.as_mut() {
+ s.update(Point { line: Line(2), column: Column(4) }, Side::Right);
+ }
+ assert_eq!(term.selection_to_string(), Some(String::from("\"aaa\"\n\n aaa ")));
+
+ // A wrapline.
+ term.selection = Some(Selection::new(
+ SelectionType::Simple,
+ Point { line: Line(2), column: Column(0) },
+ Side::Left,
+ ));
+ if let Some(s) = term.selection.as_mut() {
+ s.update(Point { line: Line(3), column: Column(4) }, Side::Right);
+ }
+ assert_eq!(term.selection_to_string(), Some(String::from(" aaa aaa\"")));
+ }
+
+ #[test]
fn semantic_selection_works() {
let size = SizeInfo::new(5., 3., 1.0, 1.0, 0.0, 0.0, false);
let mut term = Term::new(&Config::default(), size, ());
@@ -2088,28 +2131,46 @@ mod tests {
}
#[test]
- fn selecting_empty_line() {
- let size = SizeInfo::new(3.0, 3.0, 1.0, 1.0, 0.0, 0.0, false);
+ fn block_selection_works() {
+ let size = SizeInfo::new(5., 5., 1.0, 1.0, 0.0, 0.0, false);
let mut term = Term::new(&Config::default(), size, ());
- let mut grid: Grid<Cell> = Grid::new(3, 3, 0);
- for l in 0..3 {
- if l != 1 {
- for c in 0..3 {
- grid[Line(l)][Column(c)].c = 'a';
- }
+ let grid = term.grid_mut();
+ for i in 1..4 {
+ grid[Line(i)][Column(0)].c = '"';
+
+ for j in 1..4 {
+ grid[Line(i)][Column(j)].c = 'a';
}
- }
- mem::swap(&mut term.grid, &mut grid);
+ grid[Line(i)][Column(4)].c = '"';
+ }
+ grid[Line(2)][Column(2)].c = ' ';
+ grid[Line(2)][Column(4)].flags.insert(Flags::WRAPLINE);
+ grid[Line(3)][Column(4)].c = ' ';
- let mut selection = Selection::new(
- SelectionType::Simple,
- Point { line: Line(0), column: Column(0) },
+ term.selection = Some(Selection::new(
+ SelectionType::Block,
+ Point { line: Line(0), column: Column(3) },
Side::Left,
- );
- selection.update(Point { line: Line(2), column: Column(2) }, Side::Right);
- term.selection = Some(selection);
- assert_eq!(term.selection_to_string(), Some("aaa\n\naaa".into()));
+ ));
+
+ // The same column.
+ if let Some(s) = term.selection.as_mut() {
+ s.update(Point { line: Line(3), column: Column(3) }, Side::Right);
+ }
+ assert_eq!(term.selection_to_string(), Some(String::from("\na\na\na")));
+
+ // The first column.
+ if let Some(s) = term.selection.as_mut() {
+ s.update(Point { line: Line(3), column: Column(0) }, Side::Left);
+ }
+ assert_eq!(term.selection_to_string(), Some(String::from("\n\"aa\n\"a\n\"aa")));
+
+ // The last column.
+ if let Some(s) = term.selection.as_mut() {
+ s.update(Point { line: Line(3), column: Column(4) }, Side::Right);
+ }
+ assert_eq!(term.selection_to_string(), Some(String::from("\na\"\na\"\na")));
}
/// Check that the grid can be serialized back and forth losslessly.