From c32dcfc16bc5a5013c04d9c28793939b19aa88f5 Mon Sep 17 00:00:00 2001 From: Mroik Date: Thu, 27 Nov 2025 04:42:48 +0100 Subject: Refactor events generations Move all events generation in the same code section --- src/event.rs | 36 ++++++++++++++---------------------- 1 file changed, 14 insertions(+), 22 deletions(-) (limited to 'src/event.rs') diff --git a/src/event.rs b/src/event.rs index 7e0db3e..22d538b 100644 --- a/src/event.rs +++ b/src/event.rs @@ -1,10 +1,8 @@ -use std::{error::Error, time::Duration}; +use std::error::Error; -use crossterm::event::{KeyCode, KeyModifiers, poll, read}; +use crossterm::event::{KeyCode, KeyModifiers, read}; use tokio::sync::mpsc::Sender; -use crate::app::TICK_RATE; - #[derive(PartialEq)] pub enum Event { Terminate, @@ -17,25 +15,19 @@ pub enum Event { // TODO // - [ ] Pause on focus lost // - [ ] Invalidate on paste -pub async fn handle_input(sender: &Sender) -> Result<(), Box> { - if poll(Duration::from_millis(TICK_RATE))? { - match read()? { - //crossterm::event::Event::FocusGained => todo!(), - //crossterm::event::Event::FocusLost => todo!(), - //crossterm::event::Event::Paste(_) => todo!(), - crossterm::event::Event::Resize(_, _) => sender.send(Event::ForceRender).await?, - crossterm::event::Event::Key(key_event) => { - match (key_event.code, key_event.modifiers) { - (KeyCode::Char('c'), KeyModifiers::CONTROL) => { - sender.send(Event::Terminate).await? - } - (KeyCode::Backspace, _) => sender.send(Event::Backspace).await?, - (KeyCode::Char(c), _) => sender.send(Event::KeyPress(c)).await?, - _ => (), - } - } +pub async fn handle_input(sender: Sender) -> Result<(), Box> { + match read()? { + //crossterm::event::Event::FocusGained => todo!(), + //crossterm::event::Event::FocusLost => todo!(), + //crossterm::event::Event::Paste(_) => todo!(), + crossterm::event::Event::Resize(_, _) => sender.send(Event::ForceRender).await?, + crossterm::event::Event::Key(key_event) => match (key_event.code, key_event.modifiers) { + (KeyCode::Char('c'), KeyModifiers::CONTROL) => sender.send(Event::Terminate).await?, + (KeyCode::Backspace, _) => sender.send(Event::Backspace).await?, + (KeyCode::Char(c), _) => sender.send(Event::KeyPress(c)).await?, _ => (), - } + }, + _ => (), } return Ok(()); } -- cgit v1.3