Skip to main content

DataFragSubmessage

Struct DataFragSubmessage 

Source
pub struct DataFragSubmessage {
Show 13 fields pub extra_flags: u16, pub reader_id: EntityId, pub writer_id: EntityId, pub writer_sn: SequenceNumber, pub fragment_starting_num: FragmentNumber, pub fragments_in_submessage: u16, pub fragment_size: u16, pub sample_size: u32, pub serialized_payload: Arc<[u8]>, pub inline_qos_flag: bool, pub hash_key_flag: bool, pub key_flag: bool, pub non_standard_flag: bool,
}
Expand description

DATA_FRAG-Submessage. Traegt einen Ausschnitt (Fragmente) eines Samples, dessen Gesamtgroesse in sample_size steht.

Flags (Q/H/K/N) werden aus dem Submessage-Header gespiegelt. Encoder setzt diese Flags aktuell nicht; Decoder akzeptiert sie lesend.

Fields§

§extra_flags: u16

octetsToInlineQos-Analog zu DATA (§8.3.7.2 spricht von extraFlags+ octetsToInlineQos; Variante traegt 0).

§reader_id: EntityId

Reader-EntityId (Ziel).

§writer_id: EntityId

Writer-EntityId (Quelle).

§writer_sn: SequenceNumber

Sequence-Number des Samples, dessen Fragmente dies traegt.

§fragment_starting_num: FragmentNumber

Erstes Fragment in dieser Submessage (1-basiert).

§fragments_in_submessage: u16

Anzahl der Fragmente in dieser Submessage. Writer: immer 1.

§fragment_size: u16

Groesse eines einzelnen Fragments (das letzte darf kuerzer sein).

§sample_size: u32

Gesamtgroesse des Samples in Bytes.

§serialized_payload: Arc<[u8]>

Fragmentierter Payload-Ausschnitt. Arc-shared: Writer-Re-Sends bauen nur Refcount-Bumps, keine Kopie.

§inline_qos_flag: bool

Q-Flag aus dem Submessage-Header (inline_qos present).

§hash_key_flag: bool

H-Flag aus dem Submessage-Header (hash_key).

§key_flag: bool

K-Flag aus dem Submessage-Header (serialized_payload = Key).

§non_standard_flag: bool

N-Flag aus dem Submessage-Header (non-standard payload).

Implementations§

Source§

impl DataFragSubmessage

Source

pub const HEADER_WIRE_SIZE: usize = 32

Minimal-Body-Size ohne Payload: extraFlags(2) + octetsToInlineQos(2)

  • readerId(4) + writerId(4) + writerSN(8) + fragmentStartingNum(4)
  • fragmentsInSubmessage(2) + fragmentSize(2) + sampleSize(4) = 32.
Source

pub const OCTETS_TO_INLINE_QOS: u16 = 28

octetsToInlineQos: Offset vom Ende dieses Felds bis zum Beginn von inlineQos bzw. serializedPayload. Variante mit Q=false: Offset = 28 (readerId..sampleSize).

Source

pub fn write_body(&self, little_endian: bool) -> (Vec<u8>, u8)

Encoded den Body. Liefert (bytes, flags).

Source

pub fn read_body( body: &[u8], little_endian: bool, inline_qos_flag: bool, hash_key_flag: bool, key_flag: bool, non_standard_flag: bool, ) -> Result<Self, WireError>

Decoded den Body. Flags werden aus dem Submessage-Header vom Caller uebergeben.

§Errors

UnexpectedEof.

Trait Implementations§

Source§

impl Clone for DataFragSubmessage

Source§

fn clone(&self) -> DataFragSubmessage

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for DataFragSubmessage

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for DataFragSubmessage

Source§

fn eq(&self, other: &DataFragSubmessage) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for DataFragSubmessage

Source§

impl StructuralPartialEq for DataFragSubmessage

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.