29 unstable releases

0.15.2 Feb 5, 2023
0.15.1 Dec 21, 2021
0.14.0 Dec 6, 2021
0.13.0 Nov 18, 2021
0.1.2 Jun 4, 2016

#629 in Parser implementations

Download history 5490/week @ 2024-11-16 4466/week @ 2024-11-23 6833/week @ 2024-11-30 9247/week @ 2024-12-07 9784/week @ 2024-12-14 4656/week @ 2024-12-21 4481/week @ 2024-12-28 7164/week @ 2025-01-04 8617/week @ 2025-01-11 8746/week @ 2025-01-18 8513/week @ 2025-01-25 8569/week @ 2025-02-01 9785/week @ 2025-02-08 8148/week @ 2025-02-15 11575/week @ 2025-02-22 11514/week @ 2025-03-01

42,891 downloads per month
Used in 85 crates (16 directly)

MIT license

135KB
3K SLoC

vt100

This crate parses a terminal byte stream and provides an in-memory representation of the rendered contents.

Overview

This is essentially the terminal parser component of a graphical terminal emulator pulled out into a separate crate. Although you can use this crate to build a graphical terminal emulator, it also contains functionality necessary for implementing terminal applications that want to run other terminal applications - programs like screen or tmux for example.

Synopsis

let mut parser = vt100::Parser::new(24, 80, 0);

let screen = parser.screen().clone();
parser.process(b"this text is \x1b[31mRED\x1b[m");
assert_eq!(
    parser.screen().cell(0, 13).unwrap().fgcolor(),
    vt100::Color::Idx(1),
);

let screen = parser.screen().clone();
parser.process(b"\x1b[3D\x1b[32mGREEN");
assert_eq!(
    parser.screen().contents_formatted(),
    &b"\x1b[?25h\x1b[m\x1b[H\x1b[Jthis text is \x1b[32mGREEN"[..],
);
assert_eq!(
    parser.screen().contents_diff(&screen),
    &b"\x1b[1;14H\x1b[32mGREEN"[..],
);

Dependencies

~1.5MB
~25K SLoC