#raw #console #terminal #terminal-size #size #utilities

terminal-utils

A collection of utilities for working with the terminal

1 unstable release

0.1.0 Aug 28, 2023

#1078 in Command-line interface

MIT license

14KB
256 lines

terminal-utils

Crates.io Documentation License

This crate provides utilities for working with terminals.

Terminal size

let size = terminal_utils::size().unwrap();
println!("The terminal is {}x{} characters.", size.width, size.height);

Raw mode

let raw_mode_guard = terminal_utils::enable_raw_mode().unwrap();
println!("Raw mode is enabled.");

let is_raw_mode_enabled = terminal_utils::is_raw_mode_enabled().unwrap();
assert!(is_raw_mode_enabled);

// Previous terminal mode is restored when the guard is dropped.
drop(raw_mode_guard);
println!("Raw mode is disabled.");

Resize signal

This feature is only available with the tokio feature. It is enabled by default.

let mut resize_rx = terminal_utils::on_resize().unwrap();
tokio::spawn(async move {
    loop {
        resize_rx.changed().await.unwrap();

        let size = resize_rx.borrow();
        println!("terminal size changed: {:?}", size);
    }
});

Dependencies

~2–41MB
~615K SLoC