1
1
mirror of https://github.com/wez/wezterm.git synced 2025-01-01 10:18:20 +03:00
wezterm/examples/terminal_direct.rs
2018-07-22 08:03:11 -07:00

30 lines
1012 B
Rust

//! This example shows how to render `Change`s directly to
//! an instance of `Terminal`. When used in this way, the
//! library performas no optimization on the change stream.
//! Consider using the `Surface` struct to enable optimization;
//! the `buffered_terminal.rs` example demonstrates a simple
//! way to enable optimizations.
extern crate failure;
extern crate termwiz;
use failure::Error;
use termwiz::caps::Capabilities;
use termwiz::cell::AttributeChange;
use termwiz::color::AnsiColor;
use termwiz::surface::Change;
use termwiz::terminal::{new_terminal, Terminal};
fn main() -> Result<(), Error> {
let caps = Capabilities::new_from_env()?;
let mut terminal = new_terminal(caps)?;
terminal.render(&[
Change::Attribute(AttributeChange::Foreground(AnsiColor::Maroon.into())),
Change::Text("Hello world\r\n".into()),
Change::Attribute(AttributeChange::Foreground(AnsiColor::Red.into())),
Change::Text("and in red here\r\n".into()),
])?;
Ok(())
}