pub struct PipelineData {
pub buffer: Arc<ZeroCopyBuffer>,
pub metadata: PipelineMetadata,
pub stage: PipelineStage,
pub segments: Vec<SegmentView>,
}
Expand description
Zero-copy pipeline data flowing between stages
Fields§
§buffer: Arc<ZeroCopyBuffer>
Core data buffer with zero-copy views
metadata: PipelineMetadata
Metadata about the data
stage: PipelineStage
Current processing stage
segments: Vec<SegmentView>
Segment views for different data types
Implementations§
Source§impl PipelineData
impl PipelineData
pub fn new(capacity: usize) -> Self
Sourcepub fn add_segment(&mut self, segment: SegmentView)
pub fn add_segment(&mut self, segment: SegmentView)
Add a segment view without copying data
Sourcepub fn create_view(&self, offset: usize, length: usize) -> Result<SegmentView>
pub fn create_view(&self, offset: usize, length: usize) -> Result<SegmentView>
Create a new view of existing data
Sourcepub fn total_size(&self) -> usize
pub fn total_size(&self) -> usize
Get total data size across all segments
Sourcepub fn advance_stage(&mut self, stage: PipelineStage)
pub fn advance_stage(&mut self, stage: PipelineStage)
Advance to next pipeline stage
Trait Implementations§
Source§impl Clone for PipelineData
impl Clone for PipelineData
Source§fn clone(&self) -> PipelineData
fn clone(&self) -> PipelineData
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreAuto Trait Implementations§
impl Freeze for PipelineData
impl RefUnwindSafe for PipelineData
impl Send for PipelineData
impl Sync for PipelineData
impl Unpin for PipelineData
impl UnwindSafe for PipelineData
Blanket Implementations§
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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> 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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request