pub struct PeriodicGenerator<G: WatermarkGenerator> { /* private fields */ }Expand description
Periodic watermark generator that emits at fixed wall-clock intervals.
Wraps another generator and emits watermarks periodically even when no events are arriving. Useful for handling idle sources and ensuring time-based windows eventually trigger.
§Example
use laminar_core::time::{
PeriodicGenerator, BoundedOutOfOrdernessGenerator, WatermarkGenerator,
};
use std::time::Duration;
let inner = BoundedOutOfOrdernessGenerator::new(100);
let mut gen = PeriodicGenerator::new(inner, Duration::from_millis(500));
// First event
gen.on_event(1000);
// Later, periodic check may emit watermark
// (depends on wall-clock time elapsed)
let wm = gen.on_periodic();Implementations§
Source§impl<G: WatermarkGenerator> PeriodicGenerator<G>
impl<G: WatermarkGenerator> PeriodicGenerator<G>
Trait Implementations§
Source§impl<G: WatermarkGenerator> WatermarkGenerator for PeriodicGenerator<G>
impl<G: WatermarkGenerator> WatermarkGenerator for PeriodicGenerator<G>
Source§fn on_event(&mut self, timestamp: i64) -> Option<Watermark>
fn on_event(&mut self, timestamp: i64) -> Option<Watermark>
Process an event timestamp and potentially emit a new watermark. Read more
Source§fn on_periodic(&mut self) -> Option<Watermark>
fn on_periodic(&mut self) -> Option<Watermark>
Called periodically to emit watermarks based on wall-clock time. Read more
Source§fn current_watermark(&self) -> i64
fn current_watermark(&self) -> i64
Returns the current watermark value without advancing it.
Auto Trait Implementations§
impl<G> Freeze for PeriodicGenerator<G>where
G: Freeze,
impl<G> RefUnwindSafe for PeriodicGenerator<G>where
G: RefUnwindSafe,
impl<G> Send for PeriodicGenerator<G>
impl<G> Sync for PeriodicGenerator<G>where
G: Sync,
impl<G> Unpin for PeriodicGenerator<G>where
G: Unpin,
impl<G> UnwindSafe for PeriodicGenerator<G>where
G: UnwindSafe,
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
Source§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
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§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.
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Returns whether the given value has been niched. Read more
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
Writes data to
out indicating that a T is niched.