| Crates.io | ibox-crossterm |
| lib.rs | ibox-crossterm |
| version | 0.23.2 |
| created_at | 2022-04-12 02:56:19.843439+00 |
| updated_at | 2022-04-12 02:56:19.843439+00 |
| description | A fork of crossterm made for ibox to get the stderr position of the cursor. NOT FOR GENERAL USE. |
| homepage | |
| repository | https://github.com/Vonr/crossterm |
| max_upload_size | |
| id | 566216 |
| size | 365,789 |

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.23"
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.
[dependencies.crossterm]
version = "0.23"
features = ["event-stream"]
| Feature | Description |
|---|---|
event-stream |
futures::Stream producing Result<Event>. |
serde |
Se/dese/rializing of events. |
| Dependency | Used for | Included |
|---|---|---|
bitflags |
KeyModifiers, those are differ based on input. |
always |
parking_lot |
locking RwLocks with a timeout, const mutexes. |
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-core |
For async stream of events | only with event-stream feature flag |
serde |
Se/dese/rializing of events | only with serde 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.