2018-07-21 02:00:46 +10:00
|
|
|
extern crate crossterm;
|
|
|
|
|
2018-08-12 01:58:15 +10:00
|
|
|
use self::crossterm::{Crossterm, Screen};
|
|
|
|
use self::crossterm::terminal::ClearType;
|
2018-07-21 02:00:46 +10:00
|
|
|
use self::crossterm::input::input;
|
|
|
|
|
2018-07-22 22:55:14 +10:00
|
|
|
use std::{thread, time};
|
|
|
|
use std::io::{stdout, Read, Write};
|
2018-07-21 21:11:31 +10:00
|
|
|
use std::time::Duration;
|
|
|
|
|
|
|
|
/// this will capture the input until the given key.
|
2018-07-22 22:55:14 +10:00
|
|
|
pub fn read_async_until() {
|
2018-08-12 22:51:08 +10:00
|
|
|
// create raw screen
|
2018-08-15 05:40:07 +10:00
|
|
|
let screen = Screen::default();
|
|
|
|
let crossterm = Crossterm::new(&screen);
|
2018-07-21 02:00:46 +10:00
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
// init some modules we use for this demo
|
2018-08-15 05:40:07 +10:00
|
|
|
let input = crossterm.input();
|
|
|
|
let terminal = crossterm.terminal();
|
|
|
|
let mut cursor = crossterm.cursor();
|
2018-07-21 02:00:46 +10:00
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
let mut stdin = input.read_until_async(b'\r').bytes();
|
2018-07-21 21:11:31 +10:00
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
for i in 0..100 {
|
|
|
|
terminal.clear(ClearType::All);
|
|
|
|
cursor.goto(1, 1);
|
|
|
|
let a = stdin.next();
|
2018-07-21 21:11:31 +10:00
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
println!("pressed key: {:?}", a);
|
2018-08-12 01:58:15 +10:00
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
if let Some(Ok(b'\r')) = a {
|
|
|
|
println!("The enter key is hit and program is not listening to input anymore.");
|
|
|
|
break;
|
|
|
|
}
|
2018-07-21 02:00:46 +10:00
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
if let Some(Ok(b'x')) = a {
|
|
|
|
println!("The key: x was pressed and program is terminated.");
|
|
|
|
break;
|
2018-08-12 01:58:15 +10:00
|
|
|
}
|
2018-08-12 22:51:08 +10:00
|
|
|
|
|
|
|
thread::sleep(time::Duration::from_millis(100));
|
2018-07-21 02:00:46 +10:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-08-14 05:04:07 +10:00
|
|
|
/// this will read pressed characters async until `x` is typed.
|
2018-07-22 22:55:14 +10:00
|
|
|
pub fn read_async() {
|
2018-08-15 05:40:07 +10:00
|
|
|
let screen = Screen::default();
|
|
|
|
let input = input(&screen);
|
2018-07-21 02:00:46 +10:00
|
|
|
|
|
|
|
let mut stdin = input.read_async().bytes();
|
|
|
|
|
2018-07-22 22:55:14 +10:00
|
|
|
for i in 0..100 {
|
2018-07-21 02:00:46 +10:00
|
|
|
let a = stdin.next();
|
|
|
|
|
2018-07-21 21:11:31 +10:00
|
|
|
println!("pressed key: {:?}", a);
|
2018-07-21 02:00:46 +10:00
|
|
|
|
|
|
|
if let Some(Ok(b'x')) = a {
|
2018-07-21 21:11:31 +10:00
|
|
|
println!("The key: `x` was pressed and program is terminated.");
|
2018-07-21 02:00:46 +10:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
thread::sleep(time::Duration::from_millis(50));
|
|
|
|
}
|
2018-07-21 21:11:31 +10:00
|
|
|
}
|
|
|
|
|
2018-07-22 22:55:14 +10:00
|
|
|
pub fn read_async_demo() {
|
2018-08-12 22:51:08 +10:00
|
|
|
let screen = Screen::new(true);
|
2018-08-15 05:40:07 +10:00
|
|
|
let crossterm = Crossterm::new(&screen);
|
2018-07-21 21:11:31 +10:00
|
|
|
|
2018-08-12 01:58:15 +10:00
|
|
|
// init some modules we use for this demo
|
2018-08-15 05:40:07 +10:00
|
|
|
let input = crossterm.input();
|
|
|
|
let terminal = crossterm.terminal();
|
|
|
|
let mut cursor = crossterm.cursor();
|
2018-07-21 21:11:31 +10:00
|
|
|
|
|
|
|
// this will setup the async reading.
|
|
|
|
let mut stdin = input.read_async().bytes();
|
|
|
|
|
|
|
|
// clear terminal and reset the cursor.
|
|
|
|
terminal.clear(ClearType::All);
|
|
|
|
cursor.goto(1, 1);
|
|
|
|
|
|
|
|
// loop until the enter key (\r) is pressed.
|
|
|
|
loop {
|
|
|
|
terminal.clear(ClearType::All);
|
|
|
|
cursor.goto(1, 1);
|
|
|
|
|
|
|
|
// get the next pressed key
|
|
|
|
let pressed_key = stdin.next();
|
2018-08-24 06:59:51 +10:00
|
|
|
terminal.write(format!("{:?} <- Character pressed", pressed_key));
|
2018-07-21 21:11:31 +10:00
|
|
|
|
|
|
|
// check if pressed key is enter (\r)
|
|
|
|
if let Some(Ok(b'\r')) = pressed_key {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
// wait 200 ms and reset cursor write
|
|
|
|
thread::sleep(Duration::from_millis(200));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-07-22 22:55:14 +10:00
|
|
|
pub fn async_reading_on_alternate_screen() {
|
2018-07-21 21:11:31 +10:00
|
|
|
use crossterm::screen::AlternateScreen;
|
|
|
|
|
2018-08-12 22:51:08 +10:00
|
|
|
let screen = Screen::new(false);
|
2018-08-15 05:40:07 +10:00
|
|
|
|
2018-07-21 21:11:31 +10:00
|
|
|
// switch to alternate screen
|
2018-08-12 22:51:08 +10:00
|
|
|
if let Ok(alternate) = screen.enable_alternate_modes(true)
|
2018-08-12 01:58:15 +10:00
|
|
|
{
|
2018-08-15 05:40:07 +10:00
|
|
|
let crossterm = Crossterm::new(&alternate.screen);
|
2018-08-12 22:51:08 +10:00
|
|
|
// init some modules we use for this demo
|
2018-08-15 05:40:07 +10:00
|
|
|
let input = crossterm.input();
|
|
|
|
let terminal = crossterm.terminal();
|
|
|
|
let mut cursor = crossterm.cursor();
|
2018-08-12 22:51:08 +10:00
|
|
|
|
|
|
|
// this will setup the async reading.
|
|
|
|
let mut stdin = input.read_async().bytes();
|
|
|
|
|
|
|
|
// loop until the enter key (\r) is pressed.
|
|
|
|
loop {
|
|
|
|
terminal.clear(ClearType::All);
|
|
|
|
cursor.goto(1, 1);
|
|
|
|
|
|
|
|
// get the next pressed key
|
|
|
|
let pressed_key = stdin.next();
|
|
|
|
|
2018-08-24 06:59:51 +10:00
|
|
|
terminal.write(format!("{:?} <- Character pressed", pressed_key));
|
2018-08-12 22:51:08 +10:00
|
|
|
|
|
|
|
// check if pressed key is enter (\r)
|
|
|
|
if let Some(Ok(b'\r')) = pressed_key {
|
|
|
|
break;
|
2018-08-12 01:58:15 +10:00
|
|
|
}
|
2018-08-12 22:51:08 +10:00
|
|
|
|
|
|
|
// wait 200 ms and reset cursor write
|
|
|
|
thread::sleep(Duration::from_millis(200));
|
2018-07-21 21:11:31 +10:00
|
|
|
}
|
|
|
|
}
|
2018-07-22 22:55:14 +10:00
|
|
|
}
|