Struct snarkvm_utilities::io::StdinLock 1.0.0[−][src]
pub struct StdinLock<'a> { /* fields omitted */ }Expand description
A locked reference to the Stdin handle.
This handle implements both the Read and BufRead traits, and
is constructed via the Stdin::lock method.
Note: Windows Portability Consideration
When operating in a console, the Windows implementation of this stream does not support non-UTF-8 byte sequences. Attempting to read bytes that are not valid UTF-8 will return an error.
Examples
use std::io::{self, Read}; fn main() -> io::Result<()> { let mut buffer = String::new(); let stdin = io::stdin(); // We get `Stdin` here. { let mut handle = stdin.lock(); // We get `StdinLock` here. handle.read_to_string(&mut buffer)?; } // `StdinLock` is dropped here. Ok(()) }
Trait Implementations
impl<'_> BufRead for StdinLock<'_>[src]
impl<'_> BufRead for StdinLock<'_>[src]pub fn fill_buf(&mut self) -> Result<&[u8], Error>[src]
pub fn fill_buf(&mut self) -> Result<&[u8], Error>[src]Returns the contents of the internal buffer, filling it with more data from the inner reader if it is empty. Read more
pub fn consume(&mut self, n: usize)[src]
pub fn consume(&mut self, n: usize)[src]Tells this buffer that amt bytes have been consumed from the buffer,
so they should no longer be returned in calls to read. Read more
pub fn read_until(
&mut self,
byte: u8,
buf: &mut Vec<u8, Global>
) -> Result<usize, Error>[src]
pub fn read_until(
&mut self,
byte: u8,
buf: &mut Vec<u8, Global>
) -> Result<usize, Error>[src]Read all bytes into buf until the delimiter byte or EOF is reached. Read more
pub fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>[src]
pub fn read_line(&mut self, buf: &mut String) -> Result<usize, Error>[src]Read all bytes until a newline (the 0xA byte) is reached, and append
them to the provided buffer. Read more
impl<'_> Read for StdinLock<'_>[src]
impl<'_> Read for StdinLock<'_>[src]pub fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error>[src]
pub fn read(&mut self, buf: &mut [u8]) -> Result<usize, Error>[src]Pull some bytes from this source into the specified buffer, returning how many bytes were read. Read more
pub fn read_vectored(
&mut self,
bufs: &mut [IoSliceMut<'_>]
) -> Result<usize, Error>[src]
pub fn read_vectored(
&mut self,
bufs: &mut [IoSliceMut<'_>]
) -> Result<usize, Error>[src]Like read, except that it reads into a slice of buffers. Read more
pub fn is_read_vectored(&self) -> bool[src]
pub fn is_read_vectored(&self) -> bool[src]can_vector)Determines if this Reader has an efficient read_vectored
implementation. Read more
pub unsafe fn initializer(&self) -> Initializer[src]
pub unsafe fn initializer(&self) -> Initializer[src]read_initializer)Determines if this Reader can work with buffers of uninitialized
memory. Read more
pub fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>[src]
pub fn read_to_end(&mut self, buf: &mut Vec<u8, Global>) -> Result<usize, Error>[src]Read all bytes until EOF in this source, placing them into buf. Read more
pub fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>[src]
pub fn read_to_string(&mut self, buf: &mut String) -> Result<usize, Error>[src]Read all bytes until EOF in this source, appending them to buf. Read more
pub fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>[src]
pub fn read_exact(&mut self, buf: &mut [u8]) -> Result<(), Error>[src]Read the exact number of bytes required to fill buf. Read more
fn by_ref(&mut self) -> &mut Self[src]
fn by_ref(&mut self) -> &mut Self[src]Creates a “by reference” adaptor for this instance of Read. Read more
Auto Trait Implementations
impl<'a> RefUnwindSafe for StdinLock<'a>
impl<'a> !Send for StdinLock<'a>
impl<'a> Sync for StdinLock<'a>
impl<'a> Unpin for StdinLock<'a>
impl<'a> UnwindSafe for StdinLock<'a>
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized, [src]
impl<T> BorrowMut<T> for T where
T: ?Sized, [src]pub fn borrow_mut(&mut self) -> &mut T[src]
pub fn borrow_mut(&mut self) -> &mut T[src]Mutably borrows from an owned value. Read more
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,