diff options
author | Christian Duerr <chrisduerr@users.noreply.github.com> | 2017-12-03 21:38:42 +0000 |
---|---|---|
committer | Joe Wilm <jwilm@users.noreply.github.com> | 2017-12-03 13:38:42 -0800 |
commit | 9bdac6b50aa911cd8f94624a1084a1ba35be6ed4 (patch) | |
tree | 0809e0e65413978c8f906528bee192559a05fa78 /src | |
parent | d552d28418ef192724b2b4353863708f31f325d4 (diff) | |
download | alacritty-9bdac6b50aa911cd8f94624a1084a1ba35be6ed4.tar.gz alacritty-9bdac6b50aa911cd8f94624a1084a1ba35be6ed4.zip |
Add cursor style option (#928)
The default cursor can now be configured through the cursor_style field
of the config. Valid options include Block, Underline, and Beam.
The default can be restored by sending \e[0q as in VTE terminals.
Live config reloading is supported for this parameter.
Diffstat (limited to 'src')
-rw-r--r-- | src/ansi.rs | 17 | ||||
-rw-r--r-- | src/config.rs | 12 | ||||
-rw-r--r-- | src/term/mod.rs | 16 |
3 files changed, 35 insertions, 10 deletions
diff --git a/src/ansi.rs b/src/ansi.rs index 2b196145..ec139294 100644 --- a/src/ansi.rs +++ b/src/ansi.rs @@ -179,7 +179,7 @@ pub trait Handler { fn set_title(&mut self, &str) {} /// Set the cursor style - fn set_cursor_style(&mut self, _: CursorStyle) {} + fn set_cursor_style(&mut self, _: Option<CursorStyle>) {} /// A character to be displayed fn input(&mut self, _c: char) {} @@ -344,7 +344,7 @@ pub trait Handler { } /// Describes shape of cursor -#[derive(Debug, Eq, PartialEq, Copy, Clone)] +#[derive(Debug, Eq, PartialEq, Copy, Clone, Deserialize)] pub enum CursorStyle { /// Cursor is a block like `▒` Block, @@ -356,6 +356,12 @@ pub enum CursorStyle { Beam, } +impl Default for CursorStyle { + fn default() -> CursorStyle { + CursorStyle::Block + } +} + /// Terminal modes #[derive(Debug, Eq, PartialEq)] pub enum Mode { @@ -1070,9 +1076,10 @@ impl<'a, H, W> vte::Perform for Performer<'a, H, W> 'u' => handler.restore_cursor_position(), 'q' => { let style = match arg_or_default!(idx: 0, default: 0) { - 0 ... 2 => CursorStyle::Block, - 3 | 4 => CursorStyle::Underline, - 5 | 6 => CursorStyle::Beam, + 0 => None, + 1 | 2 => Some(CursorStyle::Block), + 3 | 4 => Some(CursorStyle::Underline), + 5 | 6 => Some(CursorStyle::Beam), _ => unhandled!() }; diff --git a/src/config.rs b/src/config.rs index 36ac3319..48fcda7a 100644 --- a/src/config.rs +++ b/src/config.rs @@ -25,6 +25,7 @@ use glutin::ModifiersState; use input::{Action, Binding, MouseBinding, KeyBinding}; use index::{Line, Column}; +use ansi::CursorStyle; use util::fmt::Yellow; @@ -275,6 +276,10 @@ pub struct Config { #[serde(default)] hide_cursor_when_typing: bool, + /// Style of the cursor + #[serde(default)] + cursor_style: CursorStyle, + /// Live config reload #[serde(default="true_bool")] live_config_reload: bool, @@ -329,6 +334,7 @@ impl Default for Config { visual_bell: Default::default(), env: Default::default(), hide_cursor_when_typing: Default::default(), + cursor_style: Default::default(), live_config_reload: true, padding: default_padding(), } @@ -1179,6 +1185,12 @@ impl Config { self.hide_cursor_when_typing } + /// Style of the cursor + #[inline] + pub fn cursor_style(&self) -> CursorStyle { + self.cursor_style + } + /// Live config reload #[inline] pub fn live_config_reload(&self) -> bool { diff --git a/src/term/mod.rs b/src/term/mod.rs index 51620762..6bce8451 100644 --- a/src/term/mod.rs +++ b/src/term/mod.rs @@ -708,7 +708,11 @@ pub struct Term { /// Original colors from config original_colors: color::List, - cursor_style: CursorStyle, + /// Current style of the cursor + cursor_style: Option<CursorStyle>, + + /// Default style for resetting the cursor + default_cursor_style: CursorStyle, } /// Terminal size info @@ -773,7 +777,7 @@ impl Term { self.next_title.take() } - pub fn new(config : &Config, size: SizeInfo) -> Term { + pub fn new(config: &Config, size: SizeInfo) -> Term { let template = Cell::default(); let num_cols = size.cols(); @@ -810,7 +814,8 @@ impl Term { color_modified: [false; color::COUNT], original_colors: color::List::from(config.colors()), semantic_escape_chars: config.selection().semantic_escape_chars.clone(), - cursor_style: CursorStyle::Block, + cursor_style: None, + default_cursor_style: config.cursor_style(), } } @@ -835,6 +840,7 @@ impl Term { } } self.visual_bell.update_config(config); + self.default_cursor_style = config.cursor_style(); } #[inline] @@ -1003,7 +1009,7 @@ impl Term { self.mode, config, selection, - self.cursor_style, + self.cursor_style.unwrap_or(self.default_cursor_style), ) } @@ -1869,7 +1875,7 @@ impl ansi::Handler for Term { } #[inline] - fn set_cursor_style(&mut self, style: CursorStyle) { + fn set_cursor_style(&mut self, style: Option<CursorStyle>) { trace!("set_cursor_style {:?}", style); self.cursor_style = style; } |