#io #tty #process #writable #readable #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

#139 in Command-line interface

Download history 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 9104/week @ 2025-02-05 9216/week @ 2025-02-12 9301/week @ 2025-02-19 10071/week @ 2025-02-26 11571/week @ 2025-03-05

41,578 downloads per month
Used in 15 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–8MB
~53K SLoC