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 #name. 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 #name. If the provided buffer is less than the minimum required packet size, this will return None. With this constructor the #name will own its own data and the underlying buffer will be dropped when the #name is.
Sourcepub fn to_immutable<'p>(&'p self) -> ExtensionPacket<'p>
pub fn to_immutable<'p>(&'p self) -> ExtensionPacket<'p>
Maps from a #name to a #imm_name
Sourcepub fn consume_to_immutable(self) -> ExtensionPacket<'a>
pub fn consume_to_immutable(self) -> ExtensionPacket<'a>
Maps from a #name to a #imm_name 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 #base_name 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 {name} field
Sourcepub fn get_hdr_ext_len(&self) -> u8
pub fn get_hdr_ext_len(&self) -> u8
Get the hdr_ext_len field. This field is always stored big-endian within the struct, but this accessor returns host order.
Sourcepub fn get_options(&self) -> Vec<u8> ⓘ
pub fn get_options(&self) -> Vec<u8> ⓘ
Get the value of the {name} field (copies contents)