mirror of
https://github.com/wez/wezterm.git
synced 2024-12-19 03:11:31 +03:00
28 lines
967 B
Rust
28 lines
967 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.
|
|
|
|
use anyhow::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(())
|
|
}
|