mirror of
https://github.com/FliegendeWurst/cursive.git
synced 2024-11-13 20:53:07 +00:00
7fb1108ff8
The example spelled "Hello world", but the image said "Hello Dialog".
2.0 KiB
2.0 KiB
Cursive
Cursive is a ncurses-based TUI (Text User Interface) library for rust. It is based on jeaye's ncurses-rs.
It is designed to be safe and easy to use:
[dependencies.cursive]
git = "https://github.com/Gyscos/cursive"
extern crate cursive;
use cursive::Cursive;
use cursive::view::{Dialog,TextView};
fn main() {
let mut siv = Cursive::new();
// Create a popup window with a "Ok" button that quits the application
siv.add_layer(Dialog::new(TextView::new("Hello Dialog!"))
.title("Cursive")
.button("Quit", |s| s.quit()));
// Starts the event loop.
siv.run();
}
(Colors may depend on your terminal configuration.)
The goal is to be flexible enough, so that recreating these kind of tools would be - relatively - easy (at least on the layout front):
A few notes :
- The main focus point is not performance. This is a simple layout library, guys, not compiz piped into libcaca. Unless you are running it on your microwave's microcontroller, it's not going to be slow.
- The library is single-threaded. Thus, callback methods are blocking - careful what you're doing in there! Feel free to use threads on your side, though.
- This goal is not to have an equivalent to every ncurses function. You can access the underlying ncurses window when creating your own custom views, so you can do what you want with that, but the main library will probably only use a subset of the ncurses features.