pub struct MutableFragmentPacket<'p> { /* private fields */ }
Expand description
A structure enabling manipulation of on the wire packets
Implementations§
Source§impl<'a> MutableFragmentPacket<'a>
impl<'a> MutableFragmentPacket<'a>
Sourcepub fn new<'p>(packet: &'p mut [u8]) -> Option<MutableFragmentPacket<'p>>
pub fn new<'p>(packet: &'p mut [u8]) -> Option<MutableFragmentPacket<'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<MutableFragmentPacket<'static>>
pub fn owned(packet: Vec<u8>) -> Option<MutableFragmentPacket<'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) -> FragmentPacket<'p>
pub fn to_immutable<'p>(&'p self) -> FragmentPacket<'p>
Maps from a #name to a #imm_name
Sourcepub fn consume_to_immutable(self) -> FragmentPacket<'a>
pub fn consume_to_immutable(self) -> FragmentPacket<'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: &Fragment) -> usize
pub fn packet_size(_packet: &Fragment) -> usize
The size (in bytes) of a #base_name instance when converted into a byte-array
Sourcepub fn populate(&mut self, packet: &Fragment)
pub fn populate(&mut self, packet: &Fragment)
Populates a {name}Packet using a {name} structure
Sourcepub fn get_next_header(&self) -> IpNextHeaderProtocol
pub fn get_next_header(&self) -> IpNextHeaderProtocol
Get the value of the {name} field
Sourcepub fn get_reserved(&self) -> u8
pub fn get_reserved(&self) -> u8
Get the reserved field. This field is always stored big-endian within the struct, but this accessor returns host order.
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.
Sourcepub fn get_id(&self) -> u32be
pub fn get_id(&self) -> u32be
Get the id field. This field is always stored big-endian within the struct, but this accessor returns host order.
Sourcepub fn get_payload(&self) -> Vec<u8> ⓘ
pub fn get_payload(&self) -> Vec<u8> ⓘ
Get the value of the {name} field (copies contents)
Sourcepub fn set_next_header(&mut self, val: IpNextHeaderProtocol)
pub fn set_next_header(&mut self, val: IpNextHeaderProtocol)
Set the value of the {name} field.
Sourcepub fn set_reserved(&mut self, val: u8)
pub fn set_reserved(&mut self, val: u8)
Set the reserved field. This field is always stored big-endian within the struct, but this mutator wants host order.
Sourcepub fn set_fragment_offset_with_flags(&mut self, val: u16be)
pub fn set_fragment_offset_with_flags(&mut self, val: u16be)
Set the fragment_offset_with_flags field. This field is always stored big-endian within the struct, but this mutator wants host order.
Sourcepub fn set_id(&mut self, val: u32be)
pub fn set_id(&mut self, val: u32be)
Set the id field. This field is always stored big-endian within the struct, but this mutator wants host order.
Sourcepub fn set_payload(&mut self, vals: &[u8])
pub fn set_payload(&mut self, vals: &[u8])
Set the value of the {name} field (copies contents)