Skip to main content

ReaderProxy

Struct ReaderProxy 

Source
pub struct ReaderProxy {
    pub remote_reader_guid: Guid,
    pub unicast_locators: Vec<Locator>,
    pub multicast_locators: Vec<Locator>,
    pub is_reliable: bool,
    /* private fields */
}
Expand description

Writer-seitiger State fuer einen Remote-Reader.

Fields§

§remote_reader_guid: Guid

GUID des Remote-Reader-Endpoints.

§unicast_locators: Vec<Locator>

Unicast-Empfangs-Locator(s) des Readers.

§multicast_locators: Vec<Locator>

Multicast-Empfangs-Locator(s).

§is_reliable: bool

Reliable-Kind (immer true in WP 1.1).

Implementations§

Source§

impl ReaderProxy

Source

pub fn new( remote_reader_guid: Guid, unicast_locators: Vec<Locator>, multicast_locators: Vec<Locator>, is_reliable: bool, ) -> Self

Erzeugt einen frischen Proxy.

Source

pub fn set_negotiated_data_representation(&mut self, id: i16)

Setzt das ausgehandelte Wire-Format fuer diesen Reader. Wird vom DCPS-SEDP-Match-Pfad nach negotiate(...) aufgerufen.

Source

pub fn negotiated_data_representation(&self) -> i16

Liefert das ausgehandelte Wire-Format.

Source

pub fn note_activity(&mut self, now: Duration)

Spec §8.4.15.6 — markiert eingehende Reader-Aktivitaet (jeder ACKNACK / NACK_FRAG ruft das aus dem Receiver-Pfad).

Source

pub fn is_inactive(&self, now: Duration, threshold: Duration) -> bool

Spec §8.4.15.6 — true wenn der Reader laenger als threshold keine Aktivitaet gezeigt hat. Caller (z.B. ReliableWriter) nutzt das, um den Proxy aus der matched_readers-Liste zu reclaimen, sodass Strict-Reliability nicht den Cache OOM laufen laesst.

Source

pub fn last_activity(&self) -> Duration

Liefert den Last-Activity-Zeitpunkt (Diagnose).

Source

pub fn skip_samples_up_to(&mut self, sn: SequenceNumber)

Markiert Samples bis zu und einschliesslich sn als “nicht mehr relevant” fuer diesen Proxy — sowohl gesendet als auch acked. Wird z.B. bei Volatile-Durability aufgerufen, wenn ein neuer Reader-Proxy hinzukommt: der soll keine Historic-Samples bekommen, also springen wir direkt auf den aktuellen Cache- Stand.

Spec-Bezug: OMG DDS 1.4 §2.2.3.4 DurabilityQosPolicy Volatile: “The Service will not attempt to retain old data beyond what is currently held by the DataWriter for live Readers”.

Source

pub fn acked_changes_set(&mut self, base: SequenceNumber)

Aktualisiert auf ACKNACK-Base — Reader hat alle SNs < base acked. base entspricht reader_sn_state.bitmap_base.

Source

pub fn requested_changes_set( &mut self, sns: impl IntoIterator<Item = SequenceNumber>, )

Merkt sich die im ACKNACK-Bitmap angefragten SNs fuer Re-Send.

Source

pub fn next_requested_change(&mut self) -> Option<SequenceNumber>

Zieht die kleinste offene Requested-SN und entfernt sie.

Source

pub fn next_unsent_change( &mut self, cache_max: SequenceNumber, ) -> Option<SequenceNumber>

Liefert die naechste noch nicht gesendete SN, falls im Cache vorhanden.

cache_max ist die groesste SN, die aktuell im Writer-Cache liegt.

Source

pub fn unacked_changes(&self, cache_max: SequenceNumber) -> bool

True wenn zwischen highest_acked und cache_max noch unbestaetigte Samples liegen.

Source

pub fn highest_acked_sn(&self) -> SequenceNumber

Getter fuer highest_acked_sn.

Source

pub fn highest_sent_sn(&self) -> SequenceNumber

Getter fuer highest_sent_sn.

Source

pub fn pending_requested_count(&self) -> usize

Anzahl vorgemerkter Resend-Requests.

Source

pub fn requested_fragments_set( &mut self, sn: SequenceNumber, fragments: impl IntoIterator<Item = FragmentNumber>, )

Merkt sich Fragment-granulare Resend-Requests aus einem NACK_FRAG. SN-Werte ≤ highest_acked_sn werden ignoriert.

Source

pub fn next_requested_fragment( &mut self, ) -> Option<(SequenceNumber, FragmentNumber)>

Zieht das kleinste offene (SN, FragmentNumber)-Paar und entfernt es.

Source

pub fn pending_requested_fragment_count(&self) -> usize

Anzahl vorgemerkter Fragment-Resends (Summe ueber alle SNs).

Trait Implementations§

Source§

impl Clone for ReaderProxy

Source§

fn clone(&self) -> ReaderProxy

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 ReaderProxy

Source§

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

Formats the value using the given formatter. Read more

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.