Crossterm is a pure-rust, terminal manipulation library that makes it possible to write cross-platform text-based interfaces (see features). It supports all UNIX and Windows terminals down to Windows 7 (not all terminals are tested, see Tested Terminals for more info).
This crate supports all UNIX terminals and Windows terminals down to Windows 7; however, not all of the terminals have been tested. If you have used this library for a terminal other than the above list without issues, then feel free to add it to the above list - I really would appreciate it!
see the examples directory and documentation for more advanced examples.
[dependencies] crossterm = "0.17"
use std::io::{stdout, Write}; use crossterm::{ execute, style::{Color, Print, ResetColor, SetBackgroundColor, SetForegroundColor}, ExecutableCommand, Result, event, }; fn main() -> Result<()> { // using the macro execute!( stdout(), SetForegroundColor(Color::Blue), SetBackgroundColor(Color::Red), Print("Styled text here."), ResetColor )?; // or using functions stdout() .execute(SetForegroundColor(Color::Blue))? .execute(SetBackgroundColor(Color::Red))? .execute(Print("Styled text here."))? .execute(ResetColor)?; Ok(()) }
Checkout this list with all possible commands.
To optional feature flags.
[dependencies.crossterm] version = "0.17" features = ["event-stream"]
| Feature | Description |
|---|---|
event-stream | futures::Stream producing Result<Event>. |
| Dependency | Used for | Included |
|---|---|---|
bitflags | KeyModifiers, those are differ based on input. | always |
lazy_static | original console color, original terminal mode, saved cursor position, supports ANSI on windows, single event reader per application. | always |
parking_lot | used for an RW LOCK. | always |
libc | UNIX terminal_size/raw modes/set_title and several other lowlevel functionality. | UNIX only |
Mio | event readiness polling, waking up poller | UNIX only |
signal-hook | signalhook is used to handle terminal resize SIGNAL with Mio. | UNIX only |
winapi | Used for low-level windows system calls which ANSI codes can't replace | windows only |
futures | Can be used to for async stream of events | only with a feature flag |
serde | Se/dese/realizing of events | only with a feature flag |
We highly appreciate when anyone contributes to this crate. Before you do, please, read the Contributing guidelines.
This project, crossterm and all its sub-crates: crossterm_screen, crossterm_cursor, crossterm_style, crossterm_input, crossterm_terminal, crossterm_winapi, crossterm_utils are licensed under the MIT License - see the LICENSE file for details.