pub struct PunctuatedGenerator<F>{ /* private fields */ }Expand description
Punctuated watermark generator that emits based on special events.
Uses a predicate function to identify watermark-carrying events. When the
predicate returns Some(watermark), that watermark is emitted.
§Example
use laminar_core::time::{PunctuatedGenerator, WatermarkGenerator, Watermark};
// Emit watermark on every 1000ms boundary
let mut gen = PunctuatedGenerator::new(|ts| {
if ts % 1000 == 0 {
Some(Watermark::new(ts))
} else {
None
}
});
assert_eq!(gen.on_event(999), None);
assert_eq!(gen.on_event(1000), Some(Watermark::new(1000)));Implementations§
Trait Implementations§
Source§impl<F> WatermarkGenerator for PunctuatedGenerator<F>
impl<F> WatermarkGenerator for PunctuatedGenerator<F>
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<F> Freeze for PunctuatedGenerator<F>where
F: Freeze,
impl<F> RefUnwindSafe for PunctuatedGenerator<F>where
F: RefUnwindSafe,
impl<F> Send for PunctuatedGenerator<F>
impl<F> Sync for PunctuatedGenerator<F>where
F: Sync,
impl<F> Unpin for PunctuatedGenerator<F>where
F: Unpin,
impl<F> UnwindSafe for PunctuatedGenerator<F>where
F: 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.