pub struct ExtensionPacket<'p> { /* private fields */ }
Expand description
A structure enabling manipulation of on the wire packets
Implementations§
Source§impl<'a> ExtensionPacket<'a>
impl<'a> ExtensionPacket<'a>
Sourcepub fn new<'p>(packet: &'p [u8]) -> Option<ExtensionPacket<'p>>
pub fn new<'p>(packet: &'p [u8]) -> Option<ExtensionPacket<'p>>
Constructs a new ExtensionPacket. If the provided buffer is less than the minimum required packet size, this will return None.
Sourcepub fn owned(packet: Vec<u8>) -> Option<ExtensionPacket<'static>>
pub fn owned(packet: Vec<u8>) -> Option<ExtensionPacket<'static>>
Constructs a new ExtensionPacket. If the provided buffer is less than the minimum required packet size, this will return None. With this constructor the ExtensionPacket will own its own data and the underlying buffer will be dropped when the ExtensionPacket is.
Sourcepub fn to_immutable<'p>(&'p self) -> ExtensionPacket<'p>
pub fn to_immutable<'p>(&'p self) -> ExtensionPacket<'p>
Maps from a ExtensionPacket to a ExtensionPacket
Sourcepub fn consume_to_immutable(self) -> ExtensionPacket<'a>
pub fn consume_to_immutable(self) -> ExtensionPacket<'a>
Maps from a ExtensionPacket to a ExtensionPacket 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: &Extension) -> usize
pub fn packet_size(_packet: &Extension) -> usize
The size (in bytes) of a Extension instance when converted into a byte-array
Sourcepub fn get_next_header(&self) -> IpNextHeaderProtocol
pub fn get_next_header(&self) -> IpNextHeaderProtocol
Get the value of the next_header field
Sourcepub fn get_hdr_ext_len(&self) -> u8
pub fn get_hdr_ext_len(&self) -> u8
Get the hdr_ext_len field.