pub struct TcpOptionPacket<'p> { /* private fields */ }
Expand description
A structure enabling manipulation of on the wire packets
Implementations§
Source§impl<'a> TcpOptionPacket<'a>
impl<'a> TcpOptionPacket<'a>
Sourcepub fn new<'p>(packet: &'p [u8]) -> Option<TcpOptionPacket<'p>>
pub fn new<'p>(packet: &'p [u8]) -> Option<TcpOptionPacket<'p>>
Constructs a new TcpOptionPacket. If the provided buffer is less than the minimum required packet size, this will return None.
Sourcepub fn owned(packet: Vec<u8>) -> Option<TcpOptionPacket<'static>>
pub fn owned(packet: Vec<u8>) -> Option<TcpOptionPacket<'static>>
Constructs a new TcpOptionPacket. If the provided buffer is less than the minimum required packet size, this will return None. With this constructor the TcpOptionPacket will own its own data and the underlying buffer will be dropped when the TcpOptionPacket is.
Sourcepub fn to_immutable<'p>(&'p self) -> TcpOptionPacket<'p>
pub fn to_immutable<'p>(&'p self) -> TcpOptionPacket<'p>
Maps from a TcpOptionPacket to a TcpOptionPacket
Sourcepub fn consume_to_immutable(self) -> TcpOptionPacket<'a>
pub fn consume_to_immutable(self) -> TcpOptionPacket<'a>
Maps from a TcpOptionPacket to a TcpOptionPacket while consuming the source
Sourcepub const fn minimum_packet_size() -> usize
pub const fn minimum_packet_size() -> usize
The minimum size (in bytes) a packet of this type can be. It’s based on the total size of the fixed-size fields.
Sourcepub fn packet_size(_packet: &TcpOption) -> usize
pub fn packet_size(_packet: &TcpOption) -> usize
The size (in bytes) of a TcpOption instance when converted into a byte-array
Sourcepub fn get_number(&self) -> TcpOptionNumber
pub fn get_number(&self) -> TcpOptionNumber
Get the value of the number field
Sourcepub fn get_length_raw(&self) -> &[u8] ⓘ
pub fn get_length_raw(&self) -> &[u8] ⓘ
Get the raw &u8 value of the length field, without copying
Sourcepub fn get_length(&self) -> Vec<u8> ⓘ
pub fn get_length(&self) -> Vec<u8> ⓘ
Get the value of the length field (copies contents)