pub struct Terminal<I: TermIn, O: TermOut> { /* private fields */ }
Expand description
§Terminal
Stores the current termios stuff and derives a new termios object. It also reverts changes on drop. All fields should be treated as private, mutating any of them (pointer magic included) will break the system.
If I
implements BufRead
, then Terminal
will implement BufRead
.
Implementations§
Source§impl<I: TermIn, O: TermOut> Terminal<I, O>
impl<I: TermIn, O: TermOut> Terminal<I, O>
Sourcepub fn new(input: I, output: O) -> Result<Self>
pub fn new(input: I, output: O) -> Result<Self>
constructs a new Terminal
object and puts it in control.
If you’re using stdin/stdout, it’s recommended to lock them first
since it gives you StdinLock
/StdoutLock
, which gives you the
BufRead
trait.
Examples found in repository?
examples/naive.rs (line 8)
7fn main() -> io::Result<()> {
8 let mut terminal = TJ::Terminal::new(stdin().lock(), stdout().lock())?;
9 for i in 0 .. 16 {
10 let ri = 15 - i;
11 terminal.foreground(TJ::Colour::Term(i as u8))?;
12 terminal.background(TJ::Colour::Term(ri as u8))?;
13 terminal.write(format!("The colour of term col {i:>02}:{ri:>02}")
14 .as_bytes())?;
15 terminal.style_clear()?;
16 terminal.write(b"\n")?;
17 terminal.flush()?;
18 }
19 Ok(())
20}
Sourcepub fn change<'a>(&'a mut self) -> Transform<'a, I, O>
pub fn change<'a>(&'a mut self) -> Transform<'a, I, O>
prep a transform object for changing the current termios object.
Sourcepub fn foreground(&mut self, col: Colour) -> Result<()>
pub fn foreground(&mut self, col: Colour) -> Result<()>
§foreground
sets the foreground colour
Examples found in repository?
examples/naive.rs (line 11)
7fn main() -> io::Result<()> {
8 let mut terminal = TJ::Terminal::new(stdin().lock(), stdout().lock())?;
9 for i in 0 .. 16 {
10 let ri = 15 - i;
11 terminal.foreground(TJ::Colour::Term(i as u8))?;
12 terminal.background(TJ::Colour::Term(ri as u8))?;
13 terminal.write(format!("The colour of term col {i:>02}:{ri:>02}")
14 .as_bytes())?;
15 terminal.style_clear()?;
16 terminal.write(b"\n")?;
17 terminal.flush()?;
18 }
19 Ok(())
20}
Sourcepub fn background(&mut self, col: Colour) -> Result<()>
pub fn background(&mut self, col: Colour) -> Result<()>
§background
sets the background colour
Examples found in repository?
examples/naive.rs (line 12)
7fn main() -> io::Result<()> {
8 let mut terminal = TJ::Terminal::new(stdin().lock(), stdout().lock())?;
9 for i in 0 .. 16 {
10 let ri = 15 - i;
11 terminal.foreground(TJ::Colour::Term(i as u8))?;
12 terminal.background(TJ::Colour::Term(ri as u8))?;
13 terminal.write(format!("The colour of term col {i:>02}:{ri:>02}")
14 .as_bytes())?;
15 terminal.style_clear()?;
16 terminal.write(b"\n")?;
17 terminal.flush()?;
18 }
19 Ok(())
20}
Sourcepub fn style_clear(&mut self) -> Result<()>
pub fn style_clear(&mut self) -> Result<()>
Examples found in repository?
examples/naive.rs (line 15)
7fn main() -> io::Result<()> {
8 let mut terminal = TJ::Terminal::new(stdin().lock(), stdout().lock())?;
9 for i in 0 .. 16 {
10 let ri = 15 - i;
11 terminal.foreground(TJ::Colour::Term(i as u8))?;
12 terminal.background(TJ::Colour::Term(ri as u8))?;
13 terminal.write(format!("The colour of term col {i:>02}:{ri:>02}")
14 .as_bytes())?;
15 terminal.style_clear()?;
16 terminal.write(b"\n")?;
17 terminal.flush()?;
18 }
19 Ok(())
20}
pub fn pull_utf8(&mut self) -> Result<Option<char>>
Trait Implementations§
Source§impl<I: TermIn + BufRead, O: TermOut> BufRead for Terminal<I, O>
impl<I: TermIn + BufRead, O: TermOut> BufRead for Terminal<I, O>
Source§fn consume(&mut self, amt: usize)
fn consume(&mut self, amt: usize)
Marks the given
amount
of additional bytes from the internal buffer as having been read.
Subsequent calls to read
only return bytes that have not been marked as read. Read moreSource§fn fill_buf(&mut self) -> Result<&[u8]>
fn fill_buf(&mut self) -> Result<&[u8]>
Returns the contents of the internal buffer, filling it with more data, via
Read
methods, if empty. Read moreSource§fn has_data_left(&mut self) -> Result<bool, Error>
fn has_data_left(&mut self) -> Result<bool, Error>
🔬This is a nightly-only experimental API. (
buf_read_has_data_left
)Checks if there is any data left to be
read
. Read more1.83.0 · Source§fn skip_until(&mut self, byte: u8) -> Result<usize, Error>
fn skip_until(&mut self, byte: u8) -> Result<usize, Error>
Skips all bytes until the delimiter
byte
or EOF is reached. Read more1.0.0 · Source§fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>
Reads all bytes until a newline (the
0xA
byte) is reached, and append
them to the provided String
buffer. Read moreSource§impl<I: TermIn, O: TermOut> Read for Terminal<I, O>
impl<I: TermIn, O: TermOut> Read for Terminal<I, O>
Source§fn read(&mut self, buf: &mut [u8]) -> Result<usize>
fn read(&mut self, buf: &mut [u8]) -> Result<usize>
Pull some bytes from this source into the specified buffer, returning
how many bytes were read. Read more
1.36.0 · Source§fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
fn read_vectored(&mut self, bufs: &mut [IoSliceMut<'_>]) -> Result<usize, Error>
Like
read
, except that it reads into a slice of buffers. Read moreSource§fn is_read_vectored(&self) -> bool
fn is_read_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector
)1.0.0 · Source§fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
fn read_to_end(&mut self, buf: &mut Vec<u8>) -> Result<usize, Error>
Reads all bytes until EOF in this source, placing them into
buf
. Read more1.0.0 · Source§fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>
Reads all bytes until EOF in this source, appending them to
buf
. Read more1.6.0 · Source§fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>
Reads the exact number of bytes required to fill
buf
. Read moreSource§fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf(&mut self, buf: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf
)Pull some bytes from this source into the specified buffer. Read more
Source§fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
fn read_buf_exact(&mut self, cursor: BorrowedCursor<'_>) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
read_buf
)Reads the exact number of bytes required to fill
cursor
. Read more1.0.0 · Source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
Creates a “by reference” adaptor for this instance of
Read
. Read moreSource§impl<I: TermIn, O: TermOut> Write for Terminal<I, O>
impl<I: TermIn, O: TermOut> Write for Terminal<I, O>
Source§fn write(&mut self, buf: &[u8]) -> Result<usize>
fn write(&mut self, buf: &[u8]) -> Result<usize>
Writes a buffer into this writer, returning how many bytes were written. Read more
Source§fn flush(&mut self) -> Result<()>
fn flush(&mut self) -> Result<()>
Flushes this output stream, ensuring that all intermediately buffered
contents reach their destination. Read more
Source§fn is_write_vectored(&self) -> bool
fn is_write_vectored(&self) -> bool
🔬This is a nightly-only experimental API. (
can_vector
)1.0.0 · Source§fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
fn write_all(&mut self, buf: &[u8]) -> Result<(), Error>
Attempts to write an entire buffer into this writer. Read more
Source§fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
fn write_all_vectored(&mut self, bufs: &mut [IoSlice<'_>]) -> Result<(), Error>
🔬This is a nightly-only experimental API. (
write_all_vectored
)Attempts to write multiple buffers into this writer. Read more
Auto Trait Implementations§
impl<I, O> Freeze for Terminal<I, O>
impl<I, O> RefUnwindSafe for Terminal<I, O>where
I: RefUnwindSafe,
O: RefUnwindSafe,
impl<I, O> Send for Terminal<I, O>
impl<I, O> Sync for Terminal<I, O>
impl<I, O> Unpin for Terminal<I, O>
impl<I, O> UnwindSafe for Terminal<I, O>where
I: UnwindSafe,
O: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more