diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/input.rs | 17 | ||||
-rw-r--r-- | src/selection.rs | 55 | ||||
-rw-r--r-- | src/term/mod.rs | 20 |
3 files changed, 53 insertions, 39 deletions
diff --git a/src/input.rs b/src/input.rs index 920e55f5..468e9ef3 100644 --- a/src/input.rs +++ b/src/input.rs @@ -496,6 +496,7 @@ mod tests { use event::{Mouse, ClickState}; use config::{self, Config, ClickHandler}; use index::{Point, Side}; + use selection::Selection; use super::{Action, Binding, Processor}; @@ -510,7 +511,7 @@ mod tests { struct ActionContext<'a> { pub terminal: &'a mut Term, - pub selection: Option<&'a mut Selection>, + pub selection: &'a mut Option<Selection>, pub size_info: &'a SizeInfo, pub mouse: &'a mut Mouse, pub last_action: MultiClick, @@ -533,11 +534,9 @@ mod tests { // STUBBED } - fn clear_selection(&mut self) { } - - fn update_selection(&mut self, point: Point, side: Side) { - self.selection.update(point, side); - } + fn clear_selection(&mut self) {} + fn update_selection(&mut self, _point: Point, _side: Side) {} + fn simple_selection(&mut self, _point: Point, _side: Side) {} fn semantic_selection(&mut self, _point: Point) { // set something that we can check for here @@ -578,16 +577,16 @@ mod tests { padding_y: 0.0, }; - use ::ansi::TermInfo; - let mut terminal = Term::new(&config, size); let mut mouse = Mouse::default(); mouse.click_state = $initial_state; + let mut selection = None; + let context = ActionContext { terminal: &mut terminal, - selection: None, + selection: &mut selection, mouse: &mut mouse, size_info: &size, last_action: MultiClick::None, diff --git a/src/selection.rs b/src/selection.rs index a81a9fe6..714c84c4 100644 --- a/src/selection.rs +++ b/src/selection.rs @@ -408,6 +408,27 @@ mod test { use index::{Line, Column, Side, Point}; use super::{Selection, Span, SpanType}; + struct Dimensions(Point); + impl<'a> super::Dimensions for &'a Dimensions { + fn dimensions(&self) -> Point { + self.0 + } + } + + impl Dimensions { + pub fn new(line: usize, col: usize) -> Self { + Dimensions(Point { + line: Line(line), + col: Column(col) + }) + } + } + + impl<'a> super::SemanticSearch for &'a Dimensions { + fn semantic_search_left(&self, _: Point) -> Point { unimplemented!(); } + fn semantic_search_right(&self, _: Point) -> Point { unimplemented!(); } + } + /// Test case of single cell selection /// /// 1. [ ] @@ -416,11 +437,11 @@ mod test { #[test] fn single_cell_left_to_right() { let location = Point { line: Line(0), col: Column(0) }; - let mut selection = Selection::new(Line(1), Column(1)); - selection.update(location, Side::Left); + let mut selection = Selection::simple(location, Side::Left); selection.update(location, Side::Right); - assert_eq!(selection.span().unwrap(), Span { + assert_eq!(selection.to_span(&Dimensions::new(1, 1)).unwrap(), Span { + cols: Column(1), ty: SpanType::Inclusive, front: location, tail: location @@ -435,11 +456,11 @@ mod test { #[test] fn single_cell_right_to_left() { let location = Point { line: Line(0), col: Column(0) }; - let mut selection = Selection::new(Line(1), Column(1)); - selection.update(location, Side::Right); + let mut selection = Selection::simple(location, Side::Right); selection.update(location, Side::Left); - assert_eq!(selection.span().unwrap(), Span { + assert_eq!(selection.to_span(&Dimensions::new(1, 1)).unwrap(), Span { + cols: Column(1), ty: SpanType::Inclusive, front: location, tail: location @@ -453,11 +474,10 @@ mod test { /// 3. [ B][E ] #[test] fn between_adjacent_cells_left_to_right() { - let mut selection = Selection::new(Line(1), Column(2)); - selection.update(Point::new(Line(0), Column(0)), Side::Right); + let mut selection = Selection::simple(Point::new(Line(0), Column(0)), Side::Right); selection.update(Point::new(Line(0), Column(1)), Side::Left); - assert_eq!(selection.span(), None); + assert_eq!(selection.to_span(&Dimensions::new(1, 2)), None); } /// Test adjacent cell selection from right to left @@ -467,11 +487,10 @@ mod test { /// 3. [ E][B ] #[test] fn between_adjacent_cells_right_to_left() { - let mut selection = Selection::new(Line(1), Column(2)); - selection.update(Point::new(Line(0), Column(1)), Side::Left); + let mut selection = Selection::simple(Point::new(Line(0), Column(1)), Side::Left); selection.update(Point::new(Line(0), Column(0)), Side::Right); - assert_eq!(selection.span(), None); + assert_eq!(selection.to_span(&Dimensions::new(1, 2)), None); } /// Test selection across adjacent lines @@ -485,11 +504,11 @@ mod test { /// [XX][XB][ ][ ][ ] #[test] fn across_adjacent_lines_upward_final_cell_exclusive() { - let mut selection = Selection::new(Line(2), Column(5)); - selection.update(Point::new(Line(1), Column(1)), Side::Right); + let mut selection = Selection::simple(Point::new(Line(1), Column(1)), Side::Right); selection.update(Point::new(Line(0), Column(1)), Side::Right); - assert_eq!(selection.span().unwrap(), Span { + assert_eq!(selection.to_span(&Dimensions::new(2, 5)).unwrap(), Span { + cols: Column(5), front: Point::new(Line(0), Column(1)), tail: Point::new(Line(1), Column(1)), ty: SpanType::ExcludeFront @@ -509,12 +528,12 @@ mod test { /// [XE][ ][ ][ ][ ] #[test] fn selection_bigger_then_smaller() { - let mut selection = Selection::new(Line(2), Column(5)); - selection.update(Point::new(Line(0), Column(1)), Side::Right); + let mut selection = Selection::simple(Point::new(Line(0), Column(1)), Side::Right); selection.update(Point::new(Line(1), Column(1)), Side::Right); selection.update(Point::new(Line(1), Column(0)), Side::Right); - assert_eq!(selection.span().unwrap(), Span { + assert_eq!(selection.to_span(&Dimensions::new(2, 5)).unwrap(), Span { + cols: Column(5), front: Point::new(Line(0), Column(1)), tail: Point::new(Line(1), Column(0)), ty: SpanType::ExcludeFront diff --git a/src/term/mod.rs b/src/term/mod.rs index cd7ffadd..8563be54 100644 --- a/src/term/mod.rs +++ b/src/term/mod.rs @@ -1841,21 +1841,18 @@ mod tests { mem::swap(&mut term.semantic_escape_chars, &mut escape_chars); { - let mut selection = Selection::new(grid.num_lines(), grid.num_cols()); - term.semantic_selection(&mut selection, Point { line: Line(0), col: Column(1) }); - assert_eq!(term.string_from_selection(&selection.span().unwrap()), "aa"); + let selection = Selection::semantic(Point { line: Line(0), col: Column(1) }, &term); + assert_eq!(term.string_from_selection(&selection.to_span(&term).unwrap()), "aa"); } { - let mut selection = Selection::new(grid.num_lines(), grid.num_cols()); - term.semantic_selection(&mut selection, Point { line: Line(0), col: Column(4) }); - assert_eq!(term.string_from_selection(&selection.span().unwrap()), "aaa"); + let selection = Selection::semantic(Point { line: Line(0), col: Column(4) }, &term); + assert_eq!(term.string_from_selection(&selection.to_span(&term).unwrap()), "aaa"); } { - let mut selection = Selection::new(grid.num_lines(), grid.num_cols()); - term.semantic_selection(&mut selection, Point { line: Line(1), col: Column(1) }); - assert_eq!(term.string_from_selection(&selection.span().unwrap()), "aaa"); + let selection = Selection::semantic(Point { line: Line(1), col: Column(1) }, &term); + assert_eq!(term.string_from_selection(&selection.to_span(&term).unwrap()), "aaa"); } } @@ -1880,9 +1877,8 @@ mod tests { mem::swap(&mut term.grid, &mut grid); - let mut selection = Selection::new(grid.num_lines(), grid.num_cols()); - term.line_selection(&mut selection, Point { line: Line(0), col: Column(3) }); - match selection.span() { + let selection = Selection::lines(Point { line: Line(0), col: Column(3) }); + match selection.to_span(&term) { Some(span) => assert_eq!(term.string_from_selection(&span), "\"aa\"a"), _ => () } |