mirror of
https://github.com/wez/wezterm.git
synced 2024-11-28 01:06:37 +03:00
47 lines
1.9 KiB
Markdown
47 lines
1.9 KiB
Markdown
# Terminal Wizardry
|
|
|
|
This is a rust crate that provides a number of support functions for
|
|
applications interested in either displaying data to a terminal or in building
|
|
a terminal emulator.
|
|
|
|
It is currently in active development and subject to fairly wild sweeping
|
|
changes.
|
|
|
|
Included functionality:
|
|
|
|
* `Surface` models a terminal display and its component `Cell`s
|
|
* Terminal attributes are aware of modern features such as
|
|
True Color, [Hyperlinks](https://gist.github.com/egmontkob/eb114294efbcd5adb1944c9f3cb5feda)
|
|
and will also support sixel and iterm style terminal graphics display.
|
|
* `Surface`s include a log of `Change`s and an API for consuming
|
|
and applying deltas. This is a powerful building block for
|
|
synchronizing screen instances.
|
|
* Escape sequence parser decodes inscrutable escape sequences
|
|
and gives them semantic meaning, making the code that uses
|
|
them clearer. The decoded escapes can be re-encoded, allowing
|
|
applications to start with the semantic meaning and emit
|
|
the appropriate escape sequence without embedding obscure
|
|
binary bytes.
|
|
* `Capabilities` allows probing for terminal capabilities
|
|
that may not be included in the system terminfo database,
|
|
and overriding them in an embedding application.
|
|
* `Terminal` trait provides an abstraction over unix style ttys
|
|
and Windows style console APIs. `Change`s from `Surface`
|
|
can be rendered to `Terminal`s. `Terminal`s allow decoding
|
|
mouse and keyboard inputs in both blocking or non-blocking
|
|
mode.
|
|
* `Widget` trait allows composition of UI elements at a higher level.
|
|
* `LineEditor` implements shell-like line editing functionality.
|
|
|
|
# Windows Support
|
|
|
|
Termwiz understands how to work with both the legacy console APIs and
|
|
the new PTY and virtual terminal features available in Windows 10,
|
|
allowing for true color terminal applications on Windows 10.
|
|
|
|
# Documentation
|
|
|
|
https://docs.rs/termwiz
|
|
|
|
|