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