From b8d4255bac279f0cae5d9ab5d3efeef1e091956b Mon Sep 17 00:00:00 2001 From: Timon Date: Wed, 17 Apr 2019 16:24:58 +0200 Subject: [PATCH] Fixed some Bugs. (#118) - Terminal size Linux was not 0-based. - Windows mouse input event position was 0-based and should be 1-based - Result, ErrorKind are made re-exported - Fixed some special key combination detections for UNIX systems - Made FreeBSD compile. --- Cargo.toml | 6 ++--- crossterm_cursor/src/sys/unix.rs | 1 + crossterm_input/CHANGELOG.md | 7 ++++++ crossterm_input/Cargo.toml | 2 +- crossterm_input/src/input/unix_input.rs | 7 ++++-- crossterm_input/src/input/windows_input.rs | 26 ++++++++++------------ crossterm_terminal/CHANGELOG.md | 4 ++++ crossterm_terminal/Cargo.toml | 2 +- crossterm_terminal/src/sys/unix.rs | 4 ++-- crossterm_winapi/src/console.rs | 5 ++++- docs/CHANGELOG.md | 12 +++++++++- src/lib.rs | 1 + 12 files changed, 52 insertions(+), 25 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 0672a41..5a7dbf4 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "crossterm" -version = "0.9.1" +version = "0.9.2" authors = ["T. Post"] description = "An crossplatform terminal library for manipulating terminals." repository = "https://github.com/TimonPost/crossterm" @@ -34,9 +34,9 @@ members = [ [dependencies] crossterm_screen = { optional = true, version = "0.2.1" } crossterm_cursor = { optional = true, version = "0.2.1" } -crossterm_terminal = { optional = true, version = "0.2.1" } +crossterm_terminal = { optional = true, path = "./crossterm_terminal" } crossterm_style = { optional = true, version = "0.3.1" } -crossterm_input = { optional = true, version = "0.3.1" } +crossterm_input = { optional = true, path = "./crossterm_input" } crossterm_utils = { optional = false, version = "0.2.1" } [lib] diff --git a/crossterm_cursor/src/sys/unix.rs b/crossterm_cursor/src/sys/unix.rs index d465a84..ef8f049 100644 --- a/crossterm_cursor/src/sys/unix.rs +++ b/crossterm_cursor/src/sys/unix.rs @@ -70,6 +70,7 @@ pub fn pos() -> io::Result<(u16, u16)> { // Expect `R` let res = if c == 'R' { + // subtract one to get 0-based coords Ok(((cols - 1) as u16, (rows - 1) as u16)) } else { return Err(Error::new(ErrorKind::Other, "test")); diff --git a/crossterm_input/CHANGELOG.md b/crossterm_input/CHANGELOG.md index a087714..4a7b684 100644 --- a/crossterm_input/CHANGELOG.md +++ b/crossterm_input/CHANGELOG.md @@ -1,3 +1,10 @@ +# Changes crossterm_input 0.3.2 +- Fixed some special key combination detections for UNIX systems +- Windows mouse input event position was 0-based and should be 1-based + +# Changes crossterm_input 0.3.1 +- Updated crossterm_utils + # Changes crossterm_input 0.3 - Removed `TerminalInput::from_output()` diff --git a/crossterm_input/Cargo.toml b/crossterm_input/Cargo.toml index 62df05b..26b2da8 100644 --- a/crossterm_input/Cargo.toml +++ b/crossterm_input/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "crossterm_input" -version = "0.3.1" +version = "0.3.2" authors = ["T. Post"] description = "A cross-platform library for reading userinput." repository = "https://github.com/TimonPost/crossterm" diff --git a/crossterm_input/src/input/unix_input.rs b/crossterm_input/src/input/unix_input.rs index c40f220..6f8fa2b 100644 --- a/crossterm_input/src/input/unix_input.rs +++ b/crossterm_input/src/input/unix_input.rs @@ -113,11 +113,13 @@ impl Iterator for SyncReader { // an escape sequence, we will read multiple bytes (the first byte being ESC) but if this // is a single ESC keypress, we will only read a single byte. let mut buf = [0u8; 2]; + let res = match source.read(&mut buf) { Ok(0) => return None, Ok(1) => match buf[0] { b'\x1B' => return Some(InputEvent::Keyboard(KeyEvent::Esc)), c => { + println!("size 1: {:?}", buf); if let Ok(e) = parse_event(c, &mut source.bytes().flatten()) { return Some(e); } else { @@ -126,9 +128,10 @@ impl Iterator for SyncReader { } }, Ok(2) => { + println!("size 2: {:?}", buf); let option_iter = &mut Some(buf[1]).into_iter(); - let iter = option_iter.map(|c| Ok(c)).chain(source.bytes()); - if let Ok(e) = parse_event(buf[0], &mut source.bytes().flatten()) { + let mut iter = option_iter.map(|c| Ok(c)).chain(source.bytes()); + if let Ok(e) = parse_event(buf[0], &mut iter.flatten()) { self.leftover = option_iter.next(); Some(e) } else { diff --git a/crossterm_input/src/input/windows_input.rs b/crossterm_input/src/input/windows_input.rs index 69aa505..61c0708 100644 --- a/crossterm_input/src/input/windows_input.rs +++ b/crossterm_input/src/input/windows_input.rs @@ -291,20 +291,18 @@ fn handle_mouse_event(event: &MouseEvent, seq: &mut Vec) { // mimicks the behavior; additionally, in xterm, mouse move is only handled when a // mouse button is held down (ie. mouse drag) - let cxbs: Vec = event - .mouse_position - .x - .to_string() - .chars() - .map(|d| d as u8) - .collect(); - let cybs: Vec = event - .mouse_position - .y - .to_string() - .chars() - .map(|d| d as u8) - .collect(); + let cxbs: Vec = + (event.mouse_position.x + 1) /* windows positions are 0 based and ansi codes 1. */ + .to_string() + .chars() + .map(|d| d as u8) + .collect(); + let cybs: Vec = + (event.mouse_position.y + 1) /* windows positions are 0 based and ansi codes 1. */ + .to_string() + .chars() + .map(|d| d as u8) + .collect(); // TODO (@imdaveho): check if linux only provides coords for visible terminal window vs the total buffer diff --git a/crossterm_terminal/CHANGELOG.md b/crossterm_terminal/CHANGELOG.md index 0db4e14..7870ab5 100644 --- a/crossterm_terminal/CHANGELOG.md +++ b/crossterm_terminal/CHANGELOG.md @@ -1,3 +1,7 @@ +# Changes crossterm_style 0.2.2 +- Terminal size Linux was not 0-based. +- Made FreeBSD compile + # Changes crossterm_style 0.2 - Removed `Terminal:from_output()` diff --git a/crossterm_terminal/Cargo.toml b/crossterm_terminal/Cargo.toml index 37c4464..87d6918 100644 --- a/crossterm_terminal/Cargo.toml +++ b/crossterm_terminal/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "crossterm_terminal" -version = "0.2.1" +version = "0.2.2" authors = ["T. Post"] description = "A cross-platform library for doing terminal related actions." repository = "https://github.com/TimonPost/crossterm" diff --git a/crossterm_terminal/src/sys/unix.rs b/crossterm_terminal/src/sys/unix.rs index cf96735..044bf92 100644 --- a/crossterm_terminal/src/sys/unix.rs +++ b/crossterm_terminal/src/sys/unix.rs @@ -26,11 +26,11 @@ pub fn get_terminal_size() -> (u16, u16) { ws_ypixel: 0, }; - let r = unsafe { ioctl(STDOUT_FILENO, TIOCGWINSZ, &us) }; + let r = unsafe { ioctl(STDOUT_FILENO, TIOCGWINSZ.into(), &us) }; if r == 0 { // because crossterm works starts counting at 0 and unix terminal starts at cell 1 you have subtract one to get 0-based results. - (us.cols, us.rows) + (us.cols - 1, us.rows - 1) } else { (0, 0) } diff --git a/crossterm_winapi/src/console.rs b/crossterm_winapi/src/console.rs index 92ddac6..43e6395 100644 --- a/crossterm_winapi/src/console.rs +++ b/crossterm_winapi/src/console.rs @@ -165,7 +165,10 @@ impl Console { } pub fn read_console_input(&self) -> Result<(u32, Vec)> { - let mut buf: [INPUT_RECORD; 0x1000] = unsafe { zeroed() }; + // Large buffers can overflow max heap size (?) and lead to errno 8 + // "Not enough storage is available to process this command." + // It can be reproduced at Windows 7 i686 with `0x1000` buffer size. + let mut buf: [INPUT_RECORD; 0x800] = unsafe { zeroed() }; let mut size = 0; if !is_true(unsafe { diff --git a/docs/CHANGELOG.md b/docs/CHANGELOG.md index d27934b..12fca74 100644 --- a/docs/CHANGELOG.md +++ b/docs/CHANGELOG.md @@ -1,4 +1,14 @@ -## Changes crossterm 0.9.0 +## Changes crossterm 0.9.2 +- Terminal size linux was not 0-based +- Windows mouse input event position was 0-based ans should be 1-based +- Result, ErrorKind are made re-exported +- Fixed some special key combination detections for UNIX systems +- Made FreeBSD compile + +## Changes crossterm 0.9.1 +- Fixed libc compile error + +## Changes crossterm 0.9.0 (yanked) This release is all about moving to a stabilized API for 1.0. - Major refactor and cleanup. diff --git a/src/lib.rs b/src/lib.rs index 20d01b8..b17ed31 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -30,3 +30,4 @@ pub use self::crossterm_style::{ pub use self::crossterm_terminal::{terminal, ClearType, Terminal}; pub use self::crossterm::Crossterm; +pub use self::crossterm_utils::{ErrorKind, Result};