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

terminal-trx

Provides a handle to the terminal of the current process

6 releases

0.2.4 Jan 24, 2025
0.2.3 Aug 22, 2024
0.2.2 Jul 31, 2024
0.2.1 Jun 7, 2024
0.1.0 Jan 20, 2024

#125 in Command-line interface

Download history 588/week @ 2024-10-23 703/week @ 2024-10-30 1085/week @ 2024-11-06 1524/week @ 2024-11-13 1383/week @ 2024-11-20 1340/week @ 2024-11-27 991/week @ 2024-12-04 980/week @ 2024-12-11 644/week @ 2024-12-18 816/week @ 2024-12-25 2751/week @ 2025-01-01 9803/week @ 2025-01-08 7997/week @ 2025-01-15 7471/week @ 2025-01-22 7880/week @ 2025-01-29 7751/week @ 2025-02-05

32,543 downloads per month
Used in 10 crates (via terminal-colorsaurus)

MIT/Apache

44KB
910 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–7.5MB
~53K SLoC