summaryrefslogtreecommitdiff
path: root/helix-tui
diff options
context:
space:
mode:
authorIvan Tham2021-06-15 05:27:53 +0000
committerIvan Tham2021-06-15 15:46:21 +0000
commit33a35b7589dbc35f43f8823b79591ca857bceeac (patch)
tree564ed18b66a0e038fd5d74c434c42e1f8475b03b /helix-tui
parent124514aa7024b0cf40bf01def54d280fcc86897c (diff)
Add other cursor shape
Diffstat (limited to 'helix-tui')
-rw-r--r--helix-tui/src/backend/crossterm.rs13
-rw-r--r--helix-tui/src/backend/mod.rs3
-rw-r--r--helix-tui/src/backend/test.rs3
-rw-r--r--helix-tui/src/terminal.rs12
4 files changed, 20 insertions, 11 deletions
diff --git a/helix-tui/src/backend/crossterm.rs b/helix-tui/src/backend/crossterm.rs
index f6703e14..189f9dce 100644
--- a/helix-tui/src/backend/crossterm.rs
+++ b/helix-tui/src/backend/crossterm.rs
@@ -3,9 +3,10 @@ use crate::{
buffer::Cell,
layout::Rect,
style::{Color, Modifier},
+ terminal::CursorKind,
};
use crossterm::{
- cursor::{Hide, MoveTo, Show},
+ cursor::{CursorShape, Hide, MoveTo, SetCursorShape, Show},
execute, queue,
style::{
Attribute as CAttribute, Color as CColor, Print, SetAttribute, SetBackgroundColor,
@@ -93,8 +94,14 @@ where
map_error(execute!(self.buffer, Hide))
}
- fn show_cursor(&mut self) -> io::Result<()> {
- map_error(execute!(self.buffer, Show))
+ fn show_cursor(&mut self, kind: CursorKind) -> io::Result<()> {
+ let shape = match kind {
+ CursorKind::Block => CursorShape::Block,
+ CursorKind::Bar => CursorShape::Line,
+ CursorKind::Underline => CursorShape::UnderScore,
+ CursorKind::Hidden => unreachable!(),
+ };
+ map_error(execute!(self.buffer, Show, SetCursorShape(shape)))
}
fn get_cursor(&mut self) -> io::Result<(u16, u16)> {
diff --git a/helix-tui/src/backend/mod.rs b/helix-tui/src/backend/mod.rs
index ed125200..5cf21768 100644
--- a/helix-tui/src/backend/mod.rs
+++ b/helix-tui/src/backend/mod.rs
@@ -2,6 +2,7 @@ use std::io;
use crate::buffer::Cell;
use crate::layout::Rect;
+use crate::terminal::CursorKind;
#[cfg(feature = "crossterm")]
mod crossterm;
@@ -16,7 +17,7 @@ pub trait Backend {
where
I: Iterator<Item = (u16, u16, &'a Cell)>;
fn hide_cursor(&mut self) -> Result<(), io::Error>;
- fn show_cursor(&mut self) -> Result<(), io::Error>;
+ fn show_cursor(&mut self, kind: CursorKind) -> Result<(), io::Error>;
fn get_cursor(&mut self) -> Result<(u16, u16), io::Error>;
fn set_cursor(&mut self, x: u16, y: u16) -> Result<(), io::Error>;
fn clear(&mut self) -> Result<(), io::Error>;
diff --git a/helix-tui/src/backend/test.rs b/helix-tui/src/backend/test.rs
index 46b37261..4681831d 100644
--- a/helix-tui/src/backend/test.rs
+++ b/helix-tui/src/backend/test.rs
@@ -2,6 +2,7 @@ use crate::{
backend::Backend,
buffer::{Buffer, Cell},
layout::Rect,
+ terminal::CursorKind,
};
use std::{fmt::Write, io};
use unicode_width::UnicodeWidthStr;
@@ -122,7 +123,7 @@ impl Backend for TestBackend {
Ok(())
}
- fn show_cursor(&mut self) -> Result<(), io::Error> {
+ fn show_cursor(&mut self, _kind: CursorKind) -> Result<(), io::Error> {
self.cursor = true;
Ok(())
}
diff --git a/helix-tui/src/terminal.rs b/helix-tui/src/terminal.rs
index e8f8f359..b9b2437a 100644
--- a/helix-tui/src/terminal.rs
+++ b/helix-tui/src/terminal.rs
@@ -14,9 +14,9 @@ pub enum CursorKind {
/// █
Block,
/// |
- // Bar,
+ Bar,
/// _
- // Underline,
+ Underline,
/// Hidden cursor, can set cursor position with this to let IME have correct cursor position.
Hidden,
}
@@ -70,7 +70,7 @@ where
fn drop(&mut self) {
// Attempt to restore the cursor state
if self.hidden_cursor {
- if let Err(err) = self.show_cursor() {
+ if let Err(err) = self.show_cursor(CursorKind::Block) {
eprintln!("Failed to show the cursor: {}", err);
}
}
@@ -184,8 +184,8 @@ where
}
match cursor_kind {
- CursorKind::Block => self.show_cursor()?,
CursorKind::Hidden => self.hide_cursor()?,
+ kind => self.show_cursor(kind)?,
}
// Swap buffers
@@ -203,8 +203,8 @@ where
Ok(())
}
- pub fn show_cursor(&mut self) -> io::Result<()> {
- self.backend.show_cursor()?;
+ pub fn show_cursor(&mut self, kind: CursorKind) -> io::Result<()> {
+ self.backend.show_cursor(kind)?;
self.hidden_cursor = false;
Ok(())
}