aboutsummaryrefslogtreecommitdiff
path: root/src/lib.rs
diff options
context:
space:
mode:
authorLibravatar Silas Bartha <silas@exvacuum.dev>2024-12-20 08:02:55 -0500
committerLibravatar Silas Bartha <silas@exvacuum.dev>2024-12-20 08:02:55 -0500
commit652a17e0f90a045b99a80044be313e23b9529005 (patch)
tree0fec702d8a143cc67c1845eb4214aba5ee0d1d7d /src/lib.rs
parent87172fd904a9d461b10438be7dc55660e7ced680 (diff)
parent39e8be3872232d929c4ccaa1b595bf61d656b2fe (diff)
Merge branch 'wip'
Diffstat (limited to 'src/lib.rs')
-rw-r--r--src/lib.rs17
1 files changed, 10 insertions, 7 deletions
diff --git a/src/lib.rs b/src/lib.rs
index 09134f9..e17f271 100644
--- a/src/lib.rs
+++ b/src/lib.rs
@@ -3,7 +3,7 @@
//! Bevy plugin which allows a camera to render to a terminal window.
use std::{
- fs::OpenOptions, io::stdout, path::PathBuf, sync::{Arc, Mutex}
+ fs::OpenOptions, io::{stdout, Write}, path::PathBuf, sync::{Arc, Mutex}
};
use bevy::{
@@ -79,6 +79,7 @@ impl Plugin for TerminalDisplayPlugin {
std::panic::set_hook(Box::new(move |info| {
let _ = restore_terminal();
+ error!("{info}");
panic(info);
}));
@@ -94,19 +95,21 @@ impl Plugin for TerminalDisplayPlugin {
display::systems::resize_handling,
display::systems::print_to_terminal,
widgets::systems::widget_input_handling,
+ widgets::systems::update_widgets,
),
)
.insert_resource(display::resources::Terminal::default())
.insert_resource(input::resources::EventQueue::default())
- .insert_resource(input::resources::TerminalInput::default())
.add_event::<input::events::TerminalInputEvent>();
}
}
-fn restore_terminal() {
+fn restore_terminal() -> Result<(), Box<dyn std::error::Error>>{
+ disable_raw_mode()?;
let mut stdout = stdout();
- let _ = stdout.execute(PopKeyboardEnhancementFlags);
- let _ = stdout.execute(DisableMouseCapture);
- let _ = stdout.execute(LeaveAlternateScreen);
- let _ = disable_raw_mode();
+ stdout.execute(PopKeyboardEnhancementFlags)?
+ .execute(DisableMouseCapture)?
+ .execute(LeaveAlternateScreen)?
+ .flush()?;
+ Ok(())
}