pub struct TopologyBuilder<T: Bufferable> { /* private fields */ }
Expand description
Builder for constructing buffer topologies.
Implementations§
source§impl<T: Bufferable> TopologyBuilder<T>
impl<T: Bufferable> TopologyBuilder<T>
sourcepub fn stage<S>(&mut self, stage: S, when_full: WhenFull) -> &mut Selfwhere
S: IntoBuffer<T> + 'static,
pub fn stage<S>(&mut self, stage: S, when_full: WhenFull) -> &mut Selfwhere
S: IntoBuffer<T> + 'static,
Adds a new stage to the buffer topology.
The “when full” behavior can be optionally configured here. If no behavior is specified, and an overflow buffer is not added to the topology after this, then the “when full” behavior will use a default value of “block”. If a “when full” behavior is specified, and an overflow buffer is added to the topology after this, then the specified “when full” behavior will be ignored and will be set to “overflow” mode.
Callers can configure what to do when a buffer is full by setting when_full
. Three modes
are available – block, drop newest, and overflow – which are documented in more detail by
BufferSender
.
Two notes about what modes are not valid in certain scenarios:
- the innermost stage (the last stage given to the builder) cannot be set to “overflow” mode, as there is no other stage to overflow to
- a stage cannot use the “block” or “drop newest” mode when there is a subsequent stage, and must user the “overflow” mode
Any occurrence of either of these scenarios will result in an error during build.
sourcepub async fn build(
self,
buffer_id: String,
span: Span,
) -> Result<(BufferSender<T>, BufferReceiver<T>), TopologyError>
pub async fn build( self, buffer_id: String, span: Span, ) -> Result<(BufferSender<T>, BufferReceiver<T>), TopologyError>
Consumes this builder, returning the sender and receiver that can be used by components.
§Errors
If there was a configuration error with one of the stages, an error variant will be returned explaining the issue.
source§impl<T: Bufferable> TopologyBuilder<T>
impl<T: Bufferable> TopologyBuilder<T>
sourcepub async fn standalone_memory(
max_events: NonZeroUsize,
when_full: WhenFull,
receiver_span: &Span,
) -> (BufferSender<T>, BufferReceiver<T>)
pub async fn standalone_memory( max_events: NonZeroUsize, when_full: WhenFull, receiver_span: &Span, ) -> (BufferSender<T>, BufferReceiver<T>)
Creates a memory-only buffer topology.
The overflow mode (i.e. WhenFull
) can be configured to either block or drop the newest
values, but cannot be configured to use overflow mode. If overflow mode is selected, it
will be changed to blocking mode.
This is a convenience method for vector
as it is used for inter-transform channels, and we
can simplifying needing to require callers to do all the boilerplate to create the builder,
create the stage, installing buffer usage metrics that aren’t required, and so on.
Trait Implementations§
source§impl<T: Bufferable> Default for TopologyBuilder<T>
impl<T: Bufferable> Default for TopologyBuilder<T>
Auto Trait Implementations§
impl<T> Freeze for TopologyBuilder<T>
impl<T> !RefUnwindSafe for TopologyBuilder<T>
impl<T> Send for TopologyBuilder<T>
impl<T> !Sync for TopologyBuilder<T>
impl<T> Unpin for TopologyBuilder<T>
impl<T> !UnwindSafe for TopologyBuilder<T>
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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
§impl<F, W, T, D> Deserialize<With<T, W>, D> for F
impl<F, W, T, D> Deserialize<With<T, W>, D> for F
§fn deserialize(
&self,
deserializer: &mut D,
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§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>
§impl<Source, Target> OctetsInto<Target> for Sourcewhere
Target: OctetsFrom<Source>,
impl<Source, Target> OctetsInto<Target> for Sourcewhere
Target: OctetsFrom<Source>,
type Error = <Target as OctetsFrom<Source>>::Error
§fn try_octets_into(
self,
) -> Result<Target, <Source as OctetsInto<Target>>::Error>
fn try_octets_into( self, ) -> Result<Target, <Source as OctetsInto<Target>>::Error>
§fn octets_into(self) -> Targetwhere
Self::Error: Into<Infallible>,
fn octets_into(self) -> Targetwhere
Self::Error: Into<Infallible>,
§impl<D> OwoColorize for D
impl<D> OwoColorize for D
§fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
fn fg<C>(&self) -> FgColorDisplay<'_, C, Self>where
C: Color,
§fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
fn bg<C>(&self) -> BgColorDisplay<'_, C, Self>where
C: Color,
§fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
fn on_magenta(&self) -> BgColorDisplay<'_, Magenta, Self>
§fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
fn default_color(&self) -> FgColorDisplay<'_, Default, Self>
§fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
fn on_default_color(&self) -> BgColorDisplay<'_, Default, Self>
§fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
fn bright_black(&self) -> FgColorDisplay<'_, BrightBlack, Self>
§fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
fn on_bright_black(&self) -> BgColorDisplay<'_, BrightBlack, Self>
§fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
fn bright_red(&self) -> FgColorDisplay<'_, BrightRed, Self>
§fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
fn on_bright_red(&self) -> BgColorDisplay<'_, BrightRed, Self>
§fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
fn bright_green(&self) -> FgColorDisplay<'_, BrightGreen, Self>
§fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
fn on_bright_green(&self) -> BgColorDisplay<'_, BrightGreen, Self>
§fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
fn bright_yellow(&self) -> FgColorDisplay<'_, BrightYellow, Self>
§fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
fn on_bright_yellow(&self) -> BgColorDisplay<'_, BrightYellow, Self>
§fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
fn bright_blue(&self) -> FgColorDisplay<'_, BrightBlue, Self>
§fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
fn on_bright_blue(&self) -> BgColorDisplay<'_, BrightBlue, Self>
§fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_magenta(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
§fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_magenta(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
§fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
fn bright_purple(&self) -> FgColorDisplay<'_, BrightMagenta, Self>
§fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
fn on_bright_purple(&self) -> BgColorDisplay<'_, BrightMagenta, Self>
§fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
fn bright_cyan(&self) -> FgColorDisplay<'_, BrightCyan, Self>
§fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
fn on_bright_cyan(&self) -> BgColorDisplay<'_, BrightCyan, Self>
§fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
fn bright_white(&self) -> FgColorDisplay<'_, BrightWhite, Self>
§fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
fn on_bright_white(&self) -> BgColorDisplay<'_, BrightWhite, Self>
§fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
fn blink_fast(&self) -> BlinkFastDisplay<'_, Self>
§fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
fn strikethrough(&self) -> StrikeThroughDisplay<'_, Self>
§fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn color<Color>(&self, color: Color) -> FgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::fg
] or
a color-specific method, such as [OwoColorize::green
], Read more§fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
fn on_color<Color>(&self, color: Color) -> BgDynColorDisplay<'_, Color, Self>where
Color: DynColor,
OwoColorize::bg
] or
a color-specific method, such as [OwoColorize::on_yellow
], Read more