25 releases

new 0.9.0 May 8, 2024
0.8.0 Mar 24, 2023
0.7.5 Jan 15, 2023
0.7.3 May 21, 2020
0.1.2 Dec 26, 2016

#60 in Command-line interface

Download history 42447/week @ 2024-01-23 36730/week @ 2024-01-30 36206/week @ 2024-02-06 32939/week @ 2024-02-13 28931/week @ 2024-02-20 30709/week @ 2024-02-27 33168/week @ 2024-03-05 35168/week @ 2024-03-12 37866/week @ 2024-03-19 34074/week @ 2024-03-26 32292/week @ 2024-04-02 31574/week @ 2024-04-09 29940/week @ 2024-04-16 27253/week @ 2024-04-23 28032/week @ 2024-04-30 20714/week @ 2024-05-07

111,746 downloads per month
Used in 161 crates (10 directly)

WTFPL license

120KB
3K SLoC

terminfo

Crates.io Crates.io WTFPL Build Status

Terminal capabilities with type-safe getters.

Documentation

Example

use std::io;
use terminfo::{capability as cap, Database};

fn main() {
	let info = Database::from_env().unwrap();

	if let Some(cap::MaxColors(n)) = info.get::<cap::MaxColors>() {
		println!("The terminal supports {} colors.", n);
	} else {
		println!("The terminal does not support colors, what year is this?");
	}

	if let Some(flash) = info.get::<cap::FlashScreen>() {
		flash.expand().to(io::stdout()).unwrap();
	} else {
		println!("FLASH GORDON!");
	}

	info.get::<cap::SetAForeground>().unwrap().expand().color(2).to(io::stdout()).unwrap();
	info.get::<cap::SetABackground>().unwrap().expand().color(4).to(io::stdout()).unwrap();
	println!("SUP");
	info.get::<cap::ExitAttributeMode>().unwrap().expand().to(io::stdout()).unwrap();
}

Packaging and Distributing

For all terminals but windows consoles, this library depends on a non-hashed (for now) terminfo database being present. For example, on Debian derivitives, you should depend on ncurses-term; on Arch Linux, you depend on ncurses; and on MinGW, you should depend on mingw32-terminfo.

Unfortunately, if you're using a non-windows console on Windows (e.g. MinGW, Cygwin, Git Bash), you'll need to set the TERMINFO environment variable to point to the directory containing the terminfo database.

Dependencies

~1MB
~23K SLoC