diff options
Diffstat (limited to 'src/term/mod.rs')
-rw-r--r-- | src/term/mod.rs | 111 |
1 files changed, 57 insertions, 54 deletions
diff --git a/src/term/mod.rs b/src/term/mod.rs index 72c259f7..5d4260fb 100644 --- a/src/term/mod.rs +++ b/src/term/mod.rs @@ -36,7 +36,7 @@ pub mod color; pub use self::cell::Cell; use self::cell::LineLength; -impl<'a> selection::SemanticSearch for &'a Term { +impl selection::SemanticSearch for Term { fn semantic_search_left(&self, mut point: Point) -> Point { let mut iter = self.grid.iter_from(point); let last_col = self.grid.num_cols() - Column(1); @@ -76,7 +76,7 @@ impl<'a> selection::SemanticSearch for &'a Term { } } -impl<'a> selection::Dimensions for &'a Term { +impl selection::Dimensions for Term { fn dimensions(&self) -> Point { Point { col: self.grid.num_cols(), @@ -119,7 +119,6 @@ impl<'a> RenderableCellsIter<'a> { config: &'b Config, selection: Option<RangeInclusive<index::Linear>>, cursor_style: CursorStyle, - window_focused: bool, ) -> RenderableCellsIter<'b> { let cursor_index = Linear(cursor.line.0 * grid.num_cols().0 + cursor.col.0); @@ -134,7 +133,7 @@ impl<'a> RenderableCellsIter<'a> { config: config, colors: colors, cursor_cells: ArrayDeque::new(), - }.initialize(cursor_style, window_focused) + }.initialize(cursor_style) } fn push_cursor_cells( @@ -214,6 +213,10 @@ impl<'a> RenderableCellsIter<'a> { self.populate_char_cursor(font::BEAM_CURSOR_CHAR, ' '); } + fn populate_box_cursor(&mut self) { + self.populate_char_cursor(font::BOX_CURSOR_CHAR, ' '); + } + #[inline] fn is_wide_cursor(&self, cell: &Cell) -> bool { cell.flags.contains(cell::Flags::WIDE_CHAR) && (self.cursor.col + 1) < self.grid.num_cols() @@ -237,22 +240,20 @@ impl<'a> RenderableCellsIter<'a> { }); } - fn initialize(mut self, cursor_style: CursorStyle, window_focused: bool) -> Self { + fn initialize(mut self, cursor_style: CursorStyle) -> Self { if self.cursor_is_visible() { - if !window_focused { - // Render the box cursor if the window is not focused - self.populate_char_cursor(font::BOX_CURSOR_CHAR, ' '); - } else { - match cursor_style { - CursorStyle::Block => { - self.populate_block_cursor(); - }, - CursorStyle::Beam => { - self.populate_beam_cursor(); - }, - CursorStyle::Underline => { - self.populate_underline_cursor(); - } + match cursor_style { + CursorStyle::HollowBlock => { + self.populate_box_cursor(); + }, + CursorStyle::Block => { + self.populate_block_cursor(); + }, + CursorStyle::Beam => { + self.populate_beam_cursor(); + }, + CursorStyle::Underline => { + self.populate_underline_cursor(); } } } else { @@ -417,20 +418,20 @@ impl<'a> Iterator for RenderableCellsIter<'a> { pub mod mode { bitflags! { pub struct TermMode: u16 { - const SHOW_CURSOR = 0b0000000000001; - const APP_CURSOR = 0b0000000000010; - const APP_KEYPAD = 0b0000000000100; - const MOUSE_REPORT_CLICK = 0b0000000001000; - const BRACKETED_PASTE = 0b0000000010000; - const SGR_MOUSE = 0b0000000100000; - const MOUSE_MOTION = 0b0000001000000; - const LINE_WRAP = 0b0000010000000; - const LINE_FEED_NEW_LINE = 0b0000100000000; - const ORIGIN = 0b0001000000000; - const INSERT = 0b0010000000000; - const FOCUS_IN_OUT = 0b0100000000000; - const ALT_SCREEN = 0b1000000000000; - const ANY = 0b1111111111111; + const SHOW_CURSOR = 0b0_0000_0000_0001; + const APP_CURSOR = 0b0_0000_0000_0010; + const APP_KEYPAD = 0b0_0000_0000_0100; + const MOUSE_REPORT_CLICK = 0b0_0000_0000_1000; + const BRACKETED_PASTE = 0b0_0000_0001_0000; + const SGR_MOUSE = 0b0_0000_0010_0000; + const MOUSE_MOTION = 0b0_0000_0100_0000; + const LINE_WRAP = 0b0_0000_1000_0000; + const LINE_FEED_NEW_LINE = 0b0_0001_0000_0000; + const ORIGIN = 0b0_0010_0000_0000; + const INSERT = 0b0_0100_0000_0000; + const FOCUS_IN_OUT = 0b0_1000_0000_0000; + const ALT_SCREEN = 0b1_0000_0000_0000; + const ANY = 0b1_1111_1111_1111; const NONE = 0; } } @@ -603,9 +604,9 @@ impl VisualBell { let elapsed = instant.duration_since(earlier); let elapsed_f = elapsed.as_secs() as f64 + - elapsed.subsec_nanos() as f64 / 1e9f64; + f64::from(elapsed.subsec_nanos()) / 1e9f64; let duration_f = self.duration.as_secs() as f64 + - self.duration.subsec_nanos() as f64 / 1e9f64; + f64::from(self.duration.subsec_nanos()) / 1e9f64; // Otherwise, we compute a value `time` from 0.0 to 1.0 // inclusive that represents the ratio of `elapsed` time to the @@ -616,8 +617,9 @@ impl VisualBell { // VisualBell. When `time` is 0.0, `inverse_intensity` is 0.0, // and when `time` is 1.0, `inverse_intensity` is 1.0. let inverse_intensity = match self.animation { - VisualBellAnimation::Ease => cubic_bezier(0.25, 0.1, 0.25, 1.0, time), - VisualBellAnimation::EaseOut => cubic_bezier(0.25, 0.1, 0.25, 1.0, time), + VisualBellAnimation::Ease | VisualBellAnimation::EaseOut => { + cubic_bezier(0.25, 0.1, 0.25, 1.0, time) + }, VisualBellAnimation::EaseOutSine => cubic_bezier(0.39, 0.575, 0.565, 1.0, time), VisualBellAnimation::EaseOutQuad => cubic_bezier(0.25, 0.46, 0.45, 0.94, time), VisualBellAnimation::EaseOutCubic => cubic_bezier(0.215, 0.61, 0.355, 1.0, time), @@ -840,7 +842,7 @@ impl Term { pub fn change_font_size(&mut self, delta: i8) { // Saturating addition with minimum font size 1 - let new_size = self.font_size + Size::new(delta as f32); + let new_size = self.font_size + Size::new(f32::from(delta)); self.font_size = max(new_size, Size::new(1.)); self.dirty = true; } @@ -993,6 +995,11 @@ impl Term { ) -> RenderableCellsIter { let selection = selection.and_then(|s| s.to_span(self)) .map(|span| span.to_range()); + let cursor = if window_focused { + self.cursor_style.unwrap_or(self.default_cursor_style) + } else { + CursorStyle::HollowBlock + }; RenderableCellsIter::new( &self.grid, @@ -1001,8 +1008,7 @@ impl Term { self.mode, config, selection, - self.cursor_style.unwrap_or(self.default_cursor_style), - window_focused, + cursor, ) } @@ -1046,13 +1052,13 @@ impl Term { // Scroll up to keep cursor in terminal if self.cursor.point.line >= num_lines { let lines = self.cursor.point.line - num_lines + 1; - self.grid.scroll_up(Line(0)..old_lines, lines); + self.grid.scroll_up(&(Line(0)..old_lines), lines); } // Scroll up alt grid as well if self.cursor_save_alt.point.line >= num_lines { let lines = self.cursor_save_alt.point.line - num_lines + 1; - self.alt_grid.scroll_up(Line(0)..old_lines, lines); + self.alt_grid.scroll_up(&(Line(0)..old_lines), lines); } debug!("num_cols, num_lines = {}, {}", num_cols, num_lines); @@ -1131,7 +1137,7 @@ impl Term { } // Scroll between origin and bottom - self.grid.scroll_down(origin..self.scroll_region.end, lines); + self.grid.scroll_down(&(origin..self.scroll_region.end), lines); } /// Scroll screen up @@ -1153,7 +1159,7 @@ impl Term { } // Scroll from origin to bottom less number of lines - self.grid.scroll_up(origin..self.scroll_region.end, lines); + self.grid.scroll_up(&(origin..self.scroll_region.end), lines); } fn deccolm(&mut self) { @@ -1262,13 +1268,11 @@ impl ansi::Handler for Term { } // Set spacer cell for wide chars. - if width == 2 { - if self.cursor.point.col + 1 < num_cols { - self.cursor.point.col += 1; - let spacer = &mut self.grid[&self.cursor.point]; - *spacer = self.cursor.template; - spacer.flags.insert(cell::Flags::WIDE_CHAR_SPACER); - } + if width == 2 && self.cursor.point.col + 1 < num_cols { + self.cursor.point.col += 1; + let spacer = &mut self.grid[&self.cursor.point]; + *spacer = self.cursor.template; + spacer.flags.insert(cell::Flags::WIDE_CHAR_SPACER); } } } @@ -1987,9 +1991,8 @@ mod tests { mem::swap(&mut term.grid, &mut grid); 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\n"), - _ => () + if let Some(span) = selection.to_span(&term) { + assert_eq!(term.string_from_selection(&span), "\"aa\"a\n"); } } |