wip: mouse capture errors

This commit is contained in:
Jack Wills
2023-02-27 19:52:03 +00:00
parent 72279e26ae
commit 846e0641d0
3 changed files with 67 additions and 44 deletions
Generated
+2 -2
View File
@@ -370,9 +370,9 @@ dependencies = [
[[package]] [[package]]
name = "h2" name = "h2"
version = "0.3.15" version = "0.3.16"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5f9f29bc9dda355256b2916cf526ab02ce0aeaaaf2bad60d65ef3f12f11dd0f4" checksum = "5be7b54589b581f624f566bf5d8eb2bab1db736c51528720b6bd36b96b55924d"
dependencies = [ dependencies = [
"bytes", "bytes",
"fnv", "fnv",
+22 -18
View File
@@ -1,20 +1,20 @@
#![forbid(unsafe_code)] #![forbid(unsafe_code)]
#![warn( // #![warn(
clippy::nursery, // clippy::nursery,
clippy::pedantic, // clippy::pedantic,
clippy::expect_used, // clippy::expect_used,
clippy::todo, // clippy::todo,
clippy::unused_async, // clippy::unused_async,
clippy::unwrap_used // clippy::unwrap_used
)] // )]
// Warning - These are indeed pedantic // // Warning - These are indeed pedantic
#![allow( // #![allow(
clippy::module_name_repetitions, // clippy::module_name_repetitions,
clippy::doc_markdown, // clippy::doc_markdown,
clippy::similar_names // clippy::similar_names
)] // )]
// Only allow when debugging // Only allow when debugging
// #![allow(unused)] #![allow(unused)]
use app_data::AppData; use app_data::AppData;
use app_error::AppError; use app_error::AppError;
@@ -23,7 +23,10 @@ use docker_data::DockerData;
use input_handler::InputMessages; use input_handler::InputMessages;
use parking_lot::Mutex; use parking_lot::Mutex;
use parse_args::CliArgs; use parse_args::CliArgs;
use std::{sync::{atomic::AtomicBool, Arc}, io::Write}; use std::{
io::Write,
sync::{atomic::AtomicBool, Arc},
};
use tokio::sync::mpsc::{Receiver, Sender}; use tokio::sync::mpsc::{Receiver, Sender};
use tracing::{info, Level}; use tracing::{info, Level};
@@ -146,6 +149,7 @@ async fn main() {
.await; .await;
} }
} }
// Clear screen // Clear screen
std::io::stdout().flush().unwrap_or(()); // std::io::stdout().lock().flush().unwrap_or(());
// std::io::stdout().lock().write(b"").unwrap_or_default();
} }
+43 -24
View File
@@ -6,7 +6,7 @@ use crossterm::{
}; };
use parking_lot::Mutex; use parking_lot::Mutex;
use std::{ use std::{
io, io::{self, Write},
sync::{atomic::Ordering, Arc}, sync::{atomic::Ordering, Arc},
}; };
use std::{sync::atomic::AtomicBool, time::Instant}; use std::{sync::atomic::AtomicBool, time::Instant};
@@ -38,11 +38,12 @@ pub async fn create_ui(
) -> Result<()> { ) -> Result<()> {
enable_raw_mode()?; enable_raw_mode()?;
let mut stdout = io::stdout(); let mut stdout = io::stdout();
execute!(stdout, EnterAlternateScreen, EnableMouseCapture)?; // EnableMouseCapture
execute!(stdout, EnableMouseCapture, EnterAlternateScreen)?;
let backend = CrosstermBackend::new(stdout); let backend = CrosstermBackend::new(stdout);
let mut terminal = Terminal::new(backend)?; let mut terminal = Terminal::new(backend)?;
let res = run_app( run_app(
app_data, app_data,
docker_sx, docker_sx,
gui_state, gui_state,
@@ -50,7 +51,8 @@ pub async fn create_ui(
sender, sender,
&mut terminal, &mut terminal,
) )
.await; .await
.unwrap_or(());
disable_raw_mode()?; disable_raw_mode()?;
execute!( execute!(
terminal.backend_mut(), terminal.backend_mut(),
@@ -59,8 +61,39 @@ pub async fn create_ui(
)?; )?;
terminal.show_cursor()?; terminal.show_cursor()?;
if let Err(err) = res { // if let Err(err) = res {
println!("error: {err}"); // println!("error: {err}");
// }
std::io::stdout().flush().unwrap_or(());
Ok(())
}
/// Display error message for 5 seconds, with countdown
fn err_loop<B: Backend + Send>(
now: &mut Instant,
terminal: &mut Terminal<B>,
) -> Result<(), AppError> {
let mut seconds = 5;
loop {
if seconds < 1 {
// terminal.clear().unwrap_or(());
break;
}
if now.elapsed() >= std::time::Duration::from_secs(1) {
seconds -= 1;
*now = Instant::now();
}
terminal
.draw(|f| draw_blocks::error(f, AppError::DockerConnect, Some(seconds)))
.unwrap();
// {
// return Err(AppError::Terminal);
// }
// terminal
// .draw(|f| draw_blocks::error(f, AppError::DockerConnect, Some(seconds)))
// .unwrap();
} }
Ok(()) Ok(())
} }
@@ -79,23 +112,9 @@ async fn run_app<B: Backend + Send>(
let input_poll_rate = std::time::Duration::from_millis(75); let input_poll_rate = std::time::Duration::from_millis(75);
let status_dockerconnect = gui_state.lock().status_contains(&[Status::DockerConnect]); let status_dockerconnect = gui_state.lock().status_contains(&[Status::DockerConnect]);
let mut now = Instant::now(); let mut now = Instant::now();
if status_dockerconnect {
let mut seconds = 5; if !status_dockerconnect {
loop { err_loop(&mut now, terminal).unwrap_or(());
if seconds < 1 {
break;
}
if now.elapsed() >= std::time::Duration::from_secs(1) {
seconds -= 1;
now = Instant::now();
}
if terminal
.draw(|f| draw_blocks::error(f, AppError::DockerConnect, Some(seconds)))
.is_err()
{
return Err(AppError::Terminal);
}
}
} else { } else {
while is_running.load(Ordering::SeqCst) { while is_running.load(Ordering::SeqCst) {
if crossterm::event::poll(input_poll_rate).unwrap_or(false) { if crossterm::event::poll(input_poll_rate).unwrap_or(false) {
@@ -126,7 +145,7 @@ async fn run_app<B: Backend + Send>(
} }
} }
} }
terminal.clear().unwrap_or(());
Ok(()) Ok(())
} }