3 releases

0.1.2 Nov 3, 2023
0.1.1 Oct 10, 2023
0.1.0 Sep 22, 2023

#1731 in Encoding

Download history 19/week @ 2024-07-18 22/week @ 2024-07-25 24/week @ 2024-08-01 18/week @ 2024-08-08 14/week @ 2024-08-15 15/week @ 2024-08-22 29/week @ 2024-08-29 70/week @ 2024-09-05 52/week @ 2024-09-12 69/week @ 2024-09-19 46/week @ 2024-09-26 42/week @ 2024-10-03 27/week @ 2024-10-10 14/week @ 2024-10-17 8/week @ 2024-10-24 1/week @ 2024-10-31

57 downloads per month
Used in 2 crates (via libshpool)

MIT license

140KB
3K SLoC

shpool_vt100

A fork of the vt100 crate with some tweaks for implementing shpool. See the main vt100 crate for more details.


lib.rs:

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 = shpool_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(),
    shpool_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