parent
c249c3a7bc
commit
12824e638c
@ -1,18 +1,25 @@
|
|||||||
pub mod reader;
|
pub mod reader;
|
||||||
|
|
||||||
|
use std::sync::{Arc, Mutex};
|
||||||
|
|
||||||
use reader::ReaderState;
|
use reader::ReaderState;
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
let mut state = ReaderState::new("uwu> ");
|
let state = Arc::new(Mutex::new(ReaderState::new("uwu> ")));
|
||||||
assert!(ReaderState::init_tty().is_ok());
|
let state_r = state.clone();
|
||||||
|
assert!(state.lock().unwrap().init_tty().is_ok());
|
||||||
|
std::panic::set_hook(Box::new(move |_| {
|
||||||
|
let _ = state_r.lock().unwrap().restore_tty();
|
||||||
|
}));
|
||||||
loop {
|
loop {
|
||||||
let line = state.read_line();
|
let line = state.lock().unwrap().read_line();
|
||||||
match line {
|
match line {
|
||||||
Ok(s) => println!("{}", s),
|
Ok(s) => println!("{}", s),
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
eprintln!("Error: {:?}", e);
|
eprintln!("\nError: {:?}", e);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
let _ = state.lock().unwrap().restore_tty();
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in new issue