Struct rusteron_archive::AeronArchiveReplayMerge

source ·
pub struct AeronArchiveReplayMerge { /* private fields */ }

Implementations§

source§

impl AeronArchiveReplayMerge

source

pub fn new( subscription: &AeronSubscription, aeron_archive: &AeronArchive, replay_channel: &str, replay_destination: &str, live_destination: &str, recording_id: i64, start_position: i64, epoch_clock: c_longlong, merge_progress_timeout_ms: i64, ) -> Result<Self, AeronCError>

Create an AeronArchiveReplayMerge to manage the merging of a replayed stream into a live stream.

§Parameters
  • replay_merge the AeronArchiveReplayMerge to create and initialize

  • subscription the subscription to use for the replay and live stream. Must be a multi-destination subscription

  • aeron_archive the archive client

  • replay_channel the channel to use for the replay

  • replay_destination the replay channel to use for the destination added by the subscription

  • live_destination the live stream channel to use for the destination added by the subscription

  • recording_id the recording id of the archive to replay

  • start_position the start position of the replay

  • epoch_clock the clock to use for progress checks

  • merge_progress_timeout_ms the timeout to use for progress checks

§Return

0 for success, -1 for failure

source

pub fn close(&self) -> Result<i32, AeronCError>

Close and delete the AeronArchiveReplayMerge struct.

§Return

0 for success, -1 for failure

source

pub fn do_work(&self, work_count_p: *mut c_int) -> Result<i32, AeronCError>

Process the operation of the merge. Do not call the processing of fragments on the subscription.

§Parameters
  • work_count_p an indicator of work done
§Return

0 for success, -1 for failure

source

pub fn poll<AeronFragmentHandlerHandlerImpl: AeronFragmentHandlerCallback>( &self, handler: Option<&Handler<AeronFragmentHandlerHandlerImpl>>, fragment_limit: c_int, ) -> Result<i32, AeronCError>

Poll the image used for the merging replay and live stream. The aeron_archive_replay_merge_do_work will be called before the poll so that processing of the merge can be done.

§Parameters
  • handler the handler to call for incoming fragments

  • clientd the clientd to provide to the handler

  • fragment_limit the max number of fragments to process before returning

§Return

= 0 indicates the number of fragments processed, -1 for failure

source

pub fn image(&self) -> AeronImage

The image used for the replay and live stream.

§Return

the AeronImage

source

pub fn is_merged(&self) -> bool

Is the live stream merged and the replay stopped?

§Return

true if merged, false otherwise

source

pub fn has_failed(&self) -> bool

Has the replay_merge failed due to an error?

§Return

true if an error occurred

source

pub fn is_live_added(&self) -> bool

Is the live destination added to the subscription?

§Return

true if the live destination is added to the subscription

source

pub fn get_inner(&self) -> *mut aeron_archive_replay_merge_t

Trait Implementations§

source§

impl Clone for AeronArchiveReplayMerge

source§

fn clone(&self) -> AeronArchiveReplayMerge

Returns a copy of the value. Read more
1.0.0 · source§

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

Performs copy-assignment from source. Read more
source§

impl Debug for AeronArchiveReplayMerge

source§

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

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

impl Deref for AeronArchiveReplayMerge

source§

type Target = aeron_archive_replay_merge_stct

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl From<&AeronArchiveReplayMerge> for *mut aeron_archive_replay_merge_t

source§

fn from(value: &AeronArchiveReplayMerge) -> Self

Converts to this type from the input type.
source§

impl From<*const aeron_archive_replay_merge_stct> for AeronArchiveReplayMerge

source§

fn from(value: *const aeron_archive_replay_merge_t) -> Self

Converts to this type from the input type.
source§

impl From<*mut aeron_archive_replay_merge_stct> for AeronArchiveReplayMerge

source§

fn from(value: *mut aeron_archive_replay_merge_t) -> Self

Converts to this type from the input type.
source§

impl From<AeronArchiveReplayMerge> for *mut aeron_archive_replay_merge_t

source§

fn from(value: AeronArchiveReplayMerge) -> Self

Converts to this type from the input type.
source§

impl From<AeronArchiveReplayMerge> for aeron_archive_replay_merge_t

source§

fn from(value: AeronArchiveReplayMerge) -> Self

Converts to this type from the input type.
source§

impl From<aeron_archive_replay_merge_stct> for AeronArchiveReplayMerge

source§

fn from(value: aeron_archive_replay_merge_t) -> Self

Converts to this type from the input type.

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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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.