pub struct CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,{
tx: CompactingTransactionJournalTx<W>,
rx: CompactingTransactionJournalRx<R>,
}
Expand description
Journal which will store the events locally in memory until it is either committed or rolled back
Fields§
§tx: CompactingTransactionJournalTx<W>
§rx: CompactingTransactionJournalRx<R>
Implementations§
source§impl CompactingTransactionJournal<Box<dyn WritableJournal + Send + Sync>, Box<dyn ReadableJournal + Send + Sync>>
impl CompactingTransactionJournal<Box<dyn WritableJournal + Send + Sync>, Box<dyn ReadableJournal + Send + Sync>>
sourcepub fn new<J>(
inner: J,
) -> CompactingTransactionJournal<Box<dyn WritableJournal + Send + Sync>, Box<dyn ReadableJournal + Send + Sync>>where
J: Journal,
pub fn new<J>(
inner: J,
) -> CompactingTransactionJournal<Box<dyn WritableJournal + Send + Sync>, Box<dyn ReadableJournal + Send + Sync>>where
J: Journal,
Creates a compacting transactional journal which will hold events in memory until the journal is either committed or rolled back.
When the journal is commited it will perform a compaction of the events before they are misseeed to the underlying journal
source§impl<W, R> CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,
impl<W, R> CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,
pub fn into_inner(self) -> TransactionJournal<W, R>
Trait Implementations§
source§impl<W, R> Debug for CompactingTransactionJournal<W, R>
impl<W, R> Debug for CompactingTransactionJournal<W, R>
source§impl Journal for CompactingTransactionJournal<Box<dyn WritableJournal + Send + Sync>, Box<dyn ReadableJournal + Send + Sync>>
impl Journal for CompactingTransactionJournal<Box<dyn WritableJournal + Send + Sync>, Box<dyn ReadableJournal + Send + Sync>>
source§impl<W, R> ReadableJournal for CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,
impl<W, R> ReadableJournal for CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,
source§fn read(&self) -> Result<Option<LogReadResult<'_>>, Error>
fn read(&self) -> Result<Option<LogReadResult<'_>>, Error>
Returns a stream of snapshot objects that the runtime will use
to restore the state of a WASM process to a previous moment in time
source§fn as_restarted(&self) -> Result<Box<dyn ReadableJournal + Send + Sync>, Error>
fn as_restarted(&self) -> Result<Box<dyn ReadableJournal + Send + Sync>, Error>
Resets the journal so that reads will start from the
beginning again
source§impl<W, R> WritableJournal for CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,
impl<W, R> WritableJournal for CompactingTransactionJournal<W, R>where
W: WritableJournal,
R: ReadableJournal,
Auto Trait Implementations§
impl<W, R> Freeze for CompactingTransactionJournal<W, R>
impl<W, R> RefUnwindSafe for CompactingTransactionJournal<W, R>where
W: RefUnwindSafe,
R: RefUnwindSafe,
impl<W, R> Send for CompactingTransactionJournal<W, R>
impl<W, R> Sync for CompactingTransactionJournal<W, R>
impl<W, R> Unpin for CompactingTransactionJournal<W, R>
impl<W, R> UnwindSafe for CompactingTransactionJournal<W, R>where
W: UnwindSafe,
R: UnwindSafe,
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Returns the layout of the type.
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Pointee for T
impl<T> Pointee for T
§impl<T> Upcastable for T
impl<T> Upcastable for T
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_box(self: Box<T>) -> Box<dyn Any>
§impl<T> Upcastable for T
impl<T> Upcastable for T
§fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
upcast ref
§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
upcast mut ref
§fn upcast_any_box(self: Box<T>) -> Box<dyn Any>
fn upcast_any_box(self: Box<T>) -> Box<dyn Any>
upcast boxed dyn