cool_rust_input

Struct CoolInput

Source
pub struct CoolInput<H: CustomInputHandler> {
    pub text_data: TextInputData,
    pub scroll_x: usize,
    pub scroll_y: usize,
    pub listening: bool,
    pub custom_input: H,
}
Expand description

The main input type. Uses a custom input handler (a struct which implements [CustomInput])

Fields§

§text_data: TextInputData§scroll_x: usize§scroll_y: usize§listening: bool§custom_input: H

Implementations§

Source§

impl<H: CustomInputHandler> CoolInput<H>

Source

pub fn new(handler: H, tab_width: usize) -> Self

Examples found in repository?
examples/simple-custom-input.rs (line 25)
24
25
26
27
28
fn main() -> Result<(), std::io::Error> {
    let mut my_input = CoolInput::new(MyHandler, 0);
    my_input.listen()?;
    Ok(())
}
More examples
Hide additional examples
examples/basic.rs (line 4)
3
4
5
6
7
fn main() -> Result<(), std::io::Error> {
    let mut my_input = CoolInput::new(DefaultInputHandler, 0);
    my_input.listen()?;
    Ok(())
}
examples/full-custom-input.rs (line 56)
55
56
57
58
59
fn main() -> Result<(), std::io::Error> {
    let mut cool_input = CoolInput::new(CoolCustomInput, 0);
    cool_input.listen()?;
    Ok(())
}
examples/single-line-input.rs (line 40)
39
40
41
42
43
44
fn main() -> Result<(), std::io::Error> {
    let mut my_input = CoolInput::new(MyHandler, 0);
    my_input.listen()?;
    println!("your input was: '{}'", my_input.text_data.text);
    Ok(())
}
Source

pub fn get_terminal_size(&mut self) -> Result<(u16, u16), Error>

Get the size of the terminal running the program

Source

pub fn render(&mut self) -> Result<(), Error>

Render all text and update cursor

Source

pub fn handle_key_press(&mut self, key: Event) -> Result<(), Error>

Handle a key event

Source

pub fn listen_quiet(&mut self) -> Result<(), Error>

Start listening for key presses without preparing the terminal

Source

pub fn pre_listen(&mut self) -> Result<(), Error>

Prepare the terminal for input

Source

pub fn post_listen(&mut self) -> Result<(), Error>

Restore the terminal after input is finished.

Source

pub fn listen(&mut self) -> Result<(), Error>

Prepare terminal and start to listen for key presses until finished.

Examples found in repository?
examples/simple-custom-input.rs (line 26)
24
25
26
27
28
fn main() -> Result<(), std::io::Error> {
    let mut my_input = CoolInput::new(MyHandler, 0);
    my_input.listen()?;
    Ok(())
}
More examples
Hide additional examples
examples/basic.rs (line 5)
3
4
5
6
7
fn main() -> Result<(), std::io::Error> {
    let mut my_input = CoolInput::new(DefaultInputHandler, 0);
    my_input.listen()?;
    Ok(())
}
examples/full-custom-input.rs (line 57)
55
56
57
58
59
fn main() -> Result<(), std::io::Error> {
    let mut cool_input = CoolInput::new(CoolCustomInput, 0);
    cool_input.listen()?;
    Ok(())
}
examples/single-line-input.rs (line 41)
39
40
41
42
43
44
fn main() -> Result<(), std::io::Error> {
    let mut my_input = CoolInput::new(MyHandler, 0);
    my_input.listen()?;
    println!("your input was: '{}'", my_input.text_data.text);
    Ok(())
}

Auto Trait Implementations§

§

impl<H> Freeze for CoolInput<H>
where H: Freeze,

§

impl<H> RefUnwindSafe for CoolInput<H>
where H: RefUnwindSafe,

§

impl<H> Send for CoolInput<H>
where H: Send,

§

impl<H> Sync for CoolInput<H>
where H: Sync,

§

impl<H> Unpin for CoolInput<H>
where H: Unpin,

§

impl<H> UnwindSafe for CoolInput<H>
where H: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.