minicrossterm/examples/event-stream-tokio.rs

73 lines
1.9 KiB
Rust
Raw Normal View History

//! Demonstrates how to read events asynchronously with tokio.
//!
2019-12-17 03:13:35 +11:00
//! cargo run --features="event-stream" --example event-stream-tokio
2019-12-05 03:40:11 +11:00
use std::{
io::{stdout, Write},
time::Duration,
};
2019-11-19 07:50:57 +11:00
use futures::{future::FutureExt, select, StreamExt};
use futures_timer::Delay;
use crossterm::{
cursor::position,
event::{DisableMouseCapture, EnableMouseCapture, Event, EventStream, KeyCode},
execute,
2019-12-05 03:40:11 +11:00
terminal::{disable_raw_mode, enable_raw_mode},
2019-11-19 07:50:57 +11:00
Result,
};
const HELP: &str = r#"EventStream based on futures::Stream with tokio
- Keyboard, mouse and terminal resize events enabled
- Prints "." every second if there's no event
- Hit "c" to print current cursor position
- Use Esc to quit
"#;
async fn print_events() {
let mut reader = EventStream::new();
loop {
let mut delay = Delay::new(Duration::from_millis(1_000)).fuse();
let mut event = reader.next().fuse();
select! {
_ = delay => { println!(".\r"); },
maybe_event = event => {
match maybe_event {
Some(Ok(event)) => {
println!("Event::{:?}\r", event);
if event == Event::Key(KeyCode::Char('c').into()) {
println!("Cursor position: {:?}\r", position());
}
if event == Event::Key(KeyCode::Esc.into()) {
break;
}
}
Some(Err(e)) => println!("Error: {:?}\r", e),
None => break,
}
}
};
}
}
#[tokio::main]
async fn main() -> Result<()> {
println!("{}", HELP);
2019-12-05 03:40:11 +11:00
enable_raw_mode()?;
2019-11-19 07:50:57 +11:00
let mut stdout = stdout();
execute!(stdout, EnableMouseCapture)?;
print_events().await;
execute!(stdout, DisableMouseCapture)?;
2019-12-05 03:40:11 +11:00
disable_raw_mode()
2019-11-19 07:50:57 +11:00
}