Struct bytes::buf::ext::Chain [−][src]
pub struct Chain<T, U> { /* fields omitted */ }Expand description
A Chain sequences two buffers.
Chain is an adapter that links two underlying buffers and provides a
continuous view across both buffers. It is able to sequence either immutable
buffers (Buf values) or mutable buffers (BufMut values).
This struct is generally created by calling Buf::chain. Please see that
function’s documentation for more detail.
Examples
use bytes::{Bytes, Buf, buf::BufExt}; let mut buf = (&b"hello "[..]) .chain(&b"world"[..]); let full: Bytes = buf.to_bytes(); assert_eq!(full[..], b"hello world"[..]);
Implementations
impl<T, U> Chain<T, U>[src]
impl<T, U> Chain<T, U>[src]pub fn first_ref(&self) -> &T[src]
pub fn first_ref(&self) -> &T[src]Gets a reference to the first underlying Buf.
Examples
use bytes::buf::BufExt; let buf = (&b"hello"[..]) .chain(&b"world"[..]); assert_eq!(buf.first_ref()[..], b"hello"[..]);
pub fn first_mut(&mut self) -> &mut T[src]
pub fn first_mut(&mut self) -> &mut T[src]Gets a mutable reference to the first underlying Buf.
Examples
use bytes::{Buf, buf::BufExt}; let mut buf = (&b"hello"[..]) .chain(&b"world"[..]); buf.first_mut().advance(1); let full = buf.to_bytes(); assert_eq!(full, b"elloworld"[..]);
pub fn last_ref(&self) -> &U[src]
pub fn last_ref(&self) -> &U[src]Gets a reference to the last underlying Buf.
Examples
use bytes::buf::BufExt; let buf = (&b"hello"[..]) .chain(&b"world"[..]); assert_eq!(buf.last_ref()[..], b"world"[..]);
pub fn last_mut(&mut self) -> &mut U[src]
pub fn last_mut(&mut self) -> &mut U[src]Gets a mutable reference to the last underlying Buf.
Examples
use bytes::{Buf, buf::BufExt}; let mut buf = (&b"hello "[..]) .chain(&b"world"[..]); buf.last_mut().advance(1); let full = buf.to_bytes(); assert_eq!(full, b"hello orld"[..]);
pub fn into_inner(self) -> (T, U)[src]
pub fn into_inner(self) -> (T, U)[src]Consumes this Chain, returning the underlying values.
Examples
use bytes::buf::BufExt; let chain = (&b"hello"[..]) .chain(&b"world"[..]); let (first, last) = chain.into_inner(); assert_eq!(first[..], b"hello"[..]); assert_eq!(last[..], b"world"[..]);
Trait Implementations
impl<T, U> Buf for Chain<T, U> where
T: Buf,
U: Buf, [src]
impl<T, U> Buf for Chain<T, U> where
T: Buf,
U: Buf, [src]fn remaining(&self) -> usize[src]
fn remaining(&self) -> usize[src]Returns the number of bytes between the current position and the end of the buffer. Read more
fn bytes(&self) -> &[u8]ⓘ[src]
fn bytes(&self) -> &[u8]ⓘ[src]Returns a slice starting at the current position and of length between 0
and Buf::remaining(). Note that this can return shorter slice (this allows
non-continuous internal representation). Read more
fn bytes_vectored<'a>(&'a self, dst: &mut [IoSlice<'a>]) -> usize[src]
fn bytes_vectored<'a>(&'a self, dst: &mut [IoSlice<'a>]) -> usize[src]Fills dst with potentially multiple slices starting at self’s
current position. Read more
fn has_remaining(&self) -> bool[src]
fn has_remaining(&self) -> bool[src]Returns true if there are any more bytes to consume Read more
fn get_u16(&mut self) -> u16[src]
fn get_u16(&mut self) -> u16[src]Gets an unsigned 16 bit integer from self in big-endian byte order. Read more
fn get_u16_le(&mut self) -> u16[src]
fn get_u16_le(&mut self) -> u16[src]Gets an unsigned 16 bit integer from self in little-endian byte order. Read more
fn get_i16(&mut self) -> i16[src]
fn get_i16(&mut self) -> i16[src]Gets a signed 16 bit integer from self in big-endian byte order. Read more
fn get_i16_le(&mut self) -> i16[src]
fn get_i16_le(&mut self) -> i16[src]Gets a signed 16 bit integer from self in little-endian byte order. Read more
fn get_u32(&mut self) -> u32[src]
fn get_u32(&mut self) -> u32[src]Gets an unsigned 32 bit integer from self in the big-endian byte order. Read more
fn get_u32_le(&mut self) -> u32[src]
fn get_u32_le(&mut self) -> u32[src]Gets an unsigned 32 bit integer from self in the little-endian byte order. Read more
fn get_i32(&mut self) -> i32[src]
fn get_i32(&mut self) -> i32[src]Gets a signed 32 bit integer from self in big-endian byte order. Read more
fn get_i32_le(&mut self) -> i32[src]
fn get_i32_le(&mut self) -> i32[src]Gets a signed 32 bit integer from self in little-endian byte order. Read more
fn get_u64(&mut self) -> u64[src]
fn get_u64(&mut self) -> u64[src]Gets an unsigned 64 bit integer from self in big-endian byte order. Read more
fn get_u64_le(&mut self) -> u64[src]
fn get_u64_le(&mut self) -> u64[src]Gets an unsigned 64 bit integer from self in little-endian byte order. Read more
fn get_i64(&mut self) -> i64[src]
fn get_i64(&mut self) -> i64[src]Gets a signed 64 bit integer from self in big-endian byte order. Read more
fn get_i64_le(&mut self) -> i64[src]
fn get_i64_le(&mut self) -> i64[src]Gets a signed 64 bit integer from self in little-endian byte order. Read more
fn get_u128(&mut self) -> u128[src]
fn get_u128(&mut self) -> u128[src]Gets an unsigned 128 bit integer from self in big-endian byte order. Read more
fn get_u128_le(&mut self) -> u128[src]
fn get_u128_le(&mut self) -> u128[src]Gets an unsigned 128 bit integer from self in little-endian byte order. Read more
fn get_i128(&mut self) -> i128[src]
fn get_i128(&mut self) -> i128[src]Gets a signed 128 bit integer from self in big-endian byte order. Read more
fn get_i128_le(&mut self) -> i128[src]
fn get_i128_le(&mut self) -> i128[src]Gets a signed 128 bit integer from self in little-endian byte order. Read more
fn get_uint(&mut self, nbytes: usize) -> u64[src]
fn get_uint(&mut self, nbytes: usize) -> u64[src]Gets an unsigned n-byte integer from self in big-endian byte order. Read more
fn get_uint_le(&mut self, nbytes: usize) -> u64[src]
fn get_uint_le(&mut self, nbytes: usize) -> u64[src]Gets an unsigned n-byte integer from self in little-endian byte order. Read more
fn get_int(&mut self, nbytes: usize) -> i64[src]
fn get_int(&mut self, nbytes: usize) -> i64[src]Gets a signed n-byte integer from self in big-endian byte order. Read more
fn get_int_le(&mut self, nbytes: usize) -> i64[src]
fn get_int_le(&mut self, nbytes: usize) -> i64[src]Gets a signed n-byte integer from self in little-endian byte order. Read more
fn get_f32(&mut self) -> f32[src]
fn get_f32(&mut self) -> f32[src]Gets an IEEE754 single-precision (4 bytes) floating point number from
self in big-endian byte order. Read more
fn get_f32_le(&mut self) -> f32[src]
fn get_f32_le(&mut self) -> f32[src]Gets an IEEE754 single-precision (4 bytes) floating point number from
self in little-endian byte order. Read more
fn get_f64(&mut self) -> f64[src]
fn get_f64(&mut self) -> f64[src]Gets an IEEE754 double-precision (8 bytes) floating point number from
self in big-endian byte order. Read more
fn get_f64_le(&mut self) -> f64[src]
fn get_f64_le(&mut self) -> f64[src]Gets an IEEE754 double-precision (8 bytes) floating point number from
self in little-endian byte order. Read more
impl<T, U> BufMut for Chain<T, U> where
T: BufMut,
U: BufMut, [src]
impl<T, U> BufMut for Chain<T, U> where
T: BufMut,
U: BufMut, [src]fn remaining_mut(&self) -> usize[src]
fn remaining_mut(&self) -> usize[src]Returns the number of bytes that can be written from the current position until the end of the buffer is reached. Read more
fn bytes_mut(&mut self) -> &mut [MaybeUninit<u8>]ⓘ[src]
fn bytes_mut(&mut self) -> &mut [MaybeUninit<u8>]ⓘ[src]Returns a mutable slice starting at the current BufMut position and of
length between 0 and BufMut::remaining_mut(). Note that this can be shorter than the
whole remainder of the buffer (this allows non-continuous implementation). Read more
unsafe fn advance_mut(&mut self, cnt: usize)[src]
unsafe fn advance_mut(&mut self, cnt: usize)[src]Advance the internal cursor of the BufMut Read more
fn bytes_vectored_mut<'a>(&'a mut self, dst: &mut [IoSliceMut<'a>]) -> usize[src]
fn bytes_vectored_mut<'a>(&'a mut self, dst: &mut [IoSliceMut<'a>]) -> usize[src]Fills dst with potentially multiple mutable slices starting at self’s
current position. Read more
fn has_remaining_mut(&self) -> bool[src]
fn has_remaining_mut(&self) -> bool[src]Returns true if there is space in self for more bytes. Read more
fn put<T: Buf>(&mut self, src: T) where
Self: Sized, [src]
fn put<T: Buf>(&mut self, src: T) where
Self: Sized, [src]Transfer bytes into self from src and advance the cursor by the
number of bytes written. Read more
fn put_slice(&mut self, src: &[u8])[src]
fn put_slice(&mut self, src: &[u8])[src]Transfer bytes into self from src and advance the cursor by the
number of bytes written. Read more
fn put_u16(&mut self, n: u16)[src]
fn put_u16(&mut self, n: u16)[src]Writes an unsigned 16 bit integer to self in big-endian byte order. Read more
fn put_u16_le(&mut self, n: u16)[src]
fn put_u16_le(&mut self, n: u16)[src]Writes an unsigned 16 bit integer to self in little-endian byte order. Read more
fn put_i16(&mut self, n: i16)[src]
fn put_i16(&mut self, n: i16)[src]Writes a signed 16 bit integer to self in big-endian byte order. Read more
fn put_i16_le(&mut self, n: i16)[src]
fn put_i16_le(&mut self, n: i16)[src]Writes a signed 16 bit integer to self in little-endian byte order. Read more
fn put_u32(&mut self, n: u32)[src]
fn put_u32(&mut self, n: u32)[src]Writes an unsigned 32 bit integer to self in big-endian byte order. Read more
fn put_u32_le(&mut self, n: u32)[src]
fn put_u32_le(&mut self, n: u32)[src]Writes an unsigned 32 bit integer to self in little-endian byte order. Read more
fn put_i32(&mut self, n: i32)[src]
fn put_i32(&mut self, n: i32)[src]Writes a signed 32 bit integer to self in big-endian byte order. Read more
fn put_i32_le(&mut self, n: i32)[src]
fn put_i32_le(&mut self, n: i32)[src]Writes a signed 32 bit integer to self in little-endian byte order. Read more
fn put_u64(&mut self, n: u64)[src]
fn put_u64(&mut self, n: u64)[src]Writes an unsigned 64 bit integer to self in the big-endian byte order. Read more
fn put_u64_le(&mut self, n: u64)[src]
fn put_u64_le(&mut self, n: u64)[src]Writes an unsigned 64 bit integer to self in little-endian byte order. Read more
fn put_i64(&mut self, n: i64)[src]
fn put_i64(&mut self, n: i64)[src]Writes a signed 64 bit integer to self in the big-endian byte order. Read more
fn put_i64_le(&mut self, n: i64)[src]
fn put_i64_le(&mut self, n: i64)[src]Writes a signed 64 bit integer to self in little-endian byte order. Read more
fn put_u128(&mut self, n: u128)[src]
fn put_u128(&mut self, n: u128)[src]Writes an unsigned 128 bit integer to self in the big-endian byte order. Read more
fn put_u128_le(&mut self, n: u128)[src]
fn put_u128_le(&mut self, n: u128)[src]Writes an unsigned 128 bit integer to self in little-endian byte order. Read more
fn put_i128(&mut self, n: i128)[src]
fn put_i128(&mut self, n: i128)[src]Writes a signed 128 bit integer to self in the big-endian byte order. Read more
fn put_i128_le(&mut self, n: i128)[src]
fn put_i128_le(&mut self, n: i128)[src]Writes a signed 128 bit integer to self in little-endian byte order. Read more
fn put_uint(&mut self, n: u64, nbytes: usize)[src]
fn put_uint(&mut self, n: u64, nbytes: usize)[src]Writes an unsigned n-byte integer to self in big-endian byte order. Read more
fn put_uint_le(&mut self, n: u64, nbytes: usize)[src]
fn put_uint_le(&mut self, n: u64, nbytes: usize)[src]Writes an unsigned n-byte integer to self in the little-endian byte order. Read more
fn put_int(&mut self, n: i64, nbytes: usize)[src]
fn put_int(&mut self, n: i64, nbytes: usize)[src]Writes a signed n-byte integer to self in big-endian byte order. Read more
fn put_int_le(&mut self, n: i64, nbytes: usize)[src]
fn put_int_le(&mut self, n: i64, nbytes: usize)[src]Writes a signed n-byte integer to self in little-endian byte order. Read more
fn put_f32(&mut self, n: f32)[src]
fn put_f32(&mut self, n: f32)[src]Writes an IEEE754 single-precision (4 bytes) floating point number to
self in big-endian byte order. Read more
fn put_f32_le(&mut self, n: f32)[src]
fn put_f32_le(&mut self, n: f32)[src]Writes an IEEE754 single-precision (4 bytes) floating point number to
self in little-endian byte order. Read more
fn put_f64(&mut self, n: f64)[src]
fn put_f64(&mut self, n: f64)[src]Writes an IEEE754 double-precision (8 bytes) floating point number to
self in big-endian byte order. Read more
fn put_f64_le(&mut self, n: f64)[src]
fn put_f64_le(&mut self, n: f64)[src]Writes an IEEE754 double-precision (8 bytes) floating point number to
self in little-endian byte order. Read more
Auto Trait Implementations
impl<T, U> RefUnwindSafe for Chain<T, U> where
T: RefUnwindSafe,
U: RefUnwindSafe,
T: RefUnwindSafe,
U: RefUnwindSafe,
impl<T, U> Send for Chain<T, U> where
T: Send,
U: Send,
T: Send,
U: Send,
impl<T, U> Sync for Chain<T, U> where
T: Sync,
U: Sync,
T: Sync,
U: Sync,
impl<T, U> Unpin for Chain<T, U> where
T: Unpin,
U: Unpin,
T: Unpin,
U: Unpin,
impl<T, U> UnwindSafe for Chain<T, U> where
T: UnwindSafe,
U: UnwindSafe,
T: UnwindSafe,
U: UnwindSafe,
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<B> BufExt for B where
B: Buf + ?Sized, [src]
impl<B> BufExt for B where
B: Buf + ?Sized, [src]impl<B> BufMutExt for B where
B: BufMut + ?Sized, [src]
impl<B> BufMutExt for B where
B: BufMut + ?Sized, [src]