mod tui_engine; pub use self::tui_engine::*; mod tui_content; pub use self::tui_content::*; pub use ::tengri_input as input; pub(crate) use ::tengri_input::*; pub use ::tengri_output as output; pub(crate) use ::tengri_output::*; #[cfg(feature = "dsl")] pub use ::tengri_dsl; #[cfg(feature = "dsl")] pub(crate) use ::tengri_dsl::*; pub(crate) use atomic_float::AtomicF64; pub use ::better_panic; pub(crate) use ::better_panic::{Settings, Verbosity}; pub use ::palette; pub(crate) use ::palette::{*, convert::*, okhsl::*}; pub use ::crossterm; pub(crate) use ::crossterm::{ ExecutableCommand, terminal::{EnterAlternateScreen, LeaveAlternateScreen, enable_raw_mode, disable_raw_mode}, event::{Event, KeyEvent, KeyCode, KeyModifiers, KeyEventKind, KeyEventState}, }; pub use ::ratatui; pub(crate) use ratatui::{ prelude::{Color, Style, Buffer}, style::Modifier, backend::{Backend, CrosstermBackend, ClearType}, layout::{Size, Rect}, buffer::Cell }; pub(crate) use std::sync::{Arc, RwLock, atomic::{AtomicBool, Ordering::*}}; pub(crate) use std::io::{stdout, Stdout}; pub(crate) use std::path::PathBuf; pub(crate) use std::ffi::OsString; #[macro_export] macro_rules! from { ($(<$($lt:lifetime),+>)?|$state:ident:$Source:ty|$Target:ty=$cb:expr) => { impl $(<$($lt),+>)? From<$Source> for $Target { fn from ($state:$Source) -> Self { $cb } } }; } #[cfg(test)] #[test] fn test_tui_engine () -> Usually<()> { use crate::*; use std::sync::{Arc, RwLock}; struct TestComponent(String); impl Content for TestComponent { fn content (&self) -> impl Render { Some(self.0.as_str()) } } impl Handle for TestComponent { fn handle (&mut self, from: &TuiIn) -> Perhaps { Ok(None) } } let engine = Tui::new()?; engine.read().unwrap().exited.store(true, std::sync::atomic::Ordering::Relaxed); let state = TestComponent("hello world".into()); let state = std::sync::Arc::new(std::sync::RwLock::new(state)); //engine.run(&state)?; Ok(()) }