#io #tty #process #readable #writable #terminal #write

terminal-trx

Provides a handle to the terminal of the current process

5 releases

0.2.3 Aug 22, 2024
0.2.2 Jul 31, 2024
0.2.1 Jun 7, 2024
0.2.0 Feb 2, 2024
0.1.0 Jan 20, 2024

#165 in Command-line interface

Download history 656/week @ 2024-07-25 1514/week @ 2024-08-01 785/week @ 2024-08-08 1592/week @ 2024-08-15 1692/week @ 2024-08-22 992/week @ 2024-08-29 1231/week @ 2024-09-05 813/week @ 2024-09-12 721/week @ 2024-09-19 727/week @ 2024-09-26 1144/week @ 2024-10-03 581/week @ 2024-10-10 622/week @ 2024-10-17 510/week @ 2024-10-24 680/week @ 2024-10-31 1263/week @ 2024-11-07

3,161 downloads per month
Used in 2 crates (via terminal-colorsaurus)

MIT/Apache

43KB
905 lines

terminal-trx

Docs Crate Version

Pronounced: Terminal T-Rex 🦖

Provides a handle to the terminal of the current process that is both readable and writable.

Example

use terminal_trx::terminal;
use std::io::{BufReader, BufRead as _, Write as _};

let mut terminal = terminal().unwrap();

write!(terminal, "hello world").unwrap();

let mut reader = BufReader::new(&mut terminal);
let mut line = String::new();
reader.read_line(&mut line).unwrap();

Docs

Wishlist

These are some features that I would like to include in this crate, but have not yet had the time to implement. Anyone is welcome to create a PR :)

  • Add integration tests.
  • Share the Terminal instance (like stdout, stderr, stdin in the standard library do). (Is this a good idea?)
  • Support enabling raw mode on MSYS/Cygwin.

Inspiration

This crate draws inspiration from many great resources, such as:

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions

Dependencies

~0–8MB
~64K SLoC