Struct netsim_embed::quic::VersionNegotiationPacket
source · pub struct VersionNegotiationPacket<'p> { /* private fields */ }Expand description
A structure enabling manipulation of on the wire packets
Implementations§
source§impl<'a> VersionNegotiationPacket<'a>
impl<'a> VersionNegotiationPacket<'a>
sourcepub fn new<'p>(packet: &'p [u8]) -> Option<VersionNegotiationPacket<'p>>
pub fn new<'p>(packet: &'p [u8]) -> Option<VersionNegotiationPacket<'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, Global>
) -> Option<VersionNegotiationPacket<'static>>
pub fn owned(
packet: Vec<u8, Global>
) -> Option<VersionNegotiationPacket<'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) -> VersionNegotiationPacket<'p>
pub fn to_immutable<'p>(&'p self) -> VersionNegotiationPacket<'p>
Maps from a #name to a #imm_name
sourcepub fn consume_to_immutable(self) -> VersionNegotiationPacket<'a>
pub fn consume_to_immutable(self) -> VersionNegotiationPacket<'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: &VersionNegotiation) -> usize
pub fn packet_size(_packet: &VersionNegotiation) -> usize
The size (in bytes) of a #base_name instance when converted into a byte-array
sourcepub fn get_header_form(&self) -> HeaderForm
pub fn get_header_form(&self) -> HeaderForm
Get the value of the {name} field
sourcepub fn get_unused(&self) -> u8
pub fn get_unused(&self) -> u8
Get the unused field. This field is always stored big-endian within the struct, but this accessor returns host order.
sourcepub fn get_version(&self) -> u32
pub fn get_version(&self) -> u32
Get the version field. This field is always stored big-endian within the struct, but this accessor returns host order.
sourcepub fn get_dest_id_len(&self) -> u8
pub fn get_dest_id_len(&self) -> u8
Get the dest_id_len field. This field is always stored big-endian within the struct, but this accessor returns host order.
sourcepub fn get_dest_id_raw(&self) -> &[u8] ⓘ
pub fn get_dest_id_raw(&self) -> &[u8] ⓘ
Get the raw &u8 value of the {name} field, without copying
sourcepub fn get_dest_id(&self) -> Vec<u8, Global>
pub fn get_dest_id(&self) -> Vec<u8, Global>
Get the value of the {name} field (copies contents)
sourcepub fn get_src_id_len(&self) -> u8
pub fn get_src_id_len(&self) -> u8
Get the src_id_len field. This field is always stored big-endian within the struct, but this accessor returns host order.
sourcepub fn get_src_id_raw(&self) -> &[u8] ⓘ
pub fn get_src_id_raw(&self) -> &[u8] ⓘ
Get the raw &u8 value of the {name} field, without copying
sourcepub fn get_src_id(&self) -> Vec<u8, Global>
pub fn get_src_id(&self) -> Vec<u8, Global>
Get the value of the {name} field (copies contents)
sourcepub fn get_supported_versions_raw(&self) -> &[u8] ⓘ
pub fn get_supported_versions_raw(&self) -> &[u8] ⓘ
Get the raw &u8 value of the {name} field, without copying
sourcepub fn get_supported_versions(&self) -> Vec<u8, Global>
pub fn get_supported_versions(&self) -> Vec<u8, Global>
Get the value of the {name} field (copies contents)