Skip to main content

InputQueue

Struct InputQueue 

Source
pub struct InputQueue<A = (), B = Box<dyn InputBuffer>> {
    pub queue: Mutex<VecDeque<InputQueueEntry<A, B>>>,
    pub consumer: Box<dyn InputConsumer>,
    pub transaction_in_progress: AtomicBool,
}
Expand description

A thread-safe queue for collecting and flushing input buffers.

Commonly used by InputReader implementations for staging buffers from worker threads.

Fields§

§queue: Mutex<VecDeque<InputQueueEntry<A, B>>>§consumer: Box<dyn InputConsumer>§transaction_in_progress: AtomicBool

Implementations§

Source§

impl<A, B: InputBuffer> InputQueue<A, B>

Source

pub fn new(consumer: Box<dyn InputConsumer>) -> Self

Source

pub fn push_entry(&self, entry: InputQueueEntry<A, B>, errors: Vec<ParseError>)

Source

pub fn push_with_aux( &self, (buffer, errors): (Option<B>, Vec<ParseError>), timestamp: DateTime<Utc>, aux: A, )

Appends buffer, to the queue, and associates it with aux. Reports to the controller that errors have occurred during parsing.

Source

pub fn flush_with_aux( &self, ) -> (BufferSize, Option<Xxh3Default>, Vec<(DateTime<Utc>, A)>)

Flushes a batch of records to the circuit and returns the auxiliary data that was associated with those records.

This always flushes whole buffers to the circuit (with flush), since auxiliary data is associated with a whole buffer rather than with individual records. If the auxiliary data type A is (), then [InputQueue<()>::flush] avoids that and so is a better choice.

Source

pub fn flush_with_aux_until( &self, stop_at: &dyn Fn(&A) -> bool, ) -> (BufferSize, Option<Xxh3Default>, Vec<(DateTime<Utc>, A)>)

Flushes a batch of records to the circuit and returns the auxiliary data that was associated with those records.

Stops after flushing at least max_batch_size records or after flushing a buffer whose auxiliary data satisfies the stop_at predicate, whichever happens first.

This always flushes whole buffers to the circuit (with flush), since auxiliary data is associated with a whole buffer rather than with individual records. If the auxiliary data type A is (), then [InputQueue<()>::flush] avoids that and so is a better choice.

Source

pub fn len(&self) -> usize

Source

pub fn is_empty(&self) -> bool

Source§

impl InputQueue<(), Box<dyn InputBuffer>>

Source

pub fn push( &self, (buffer, errors): (Option<Box<dyn InputBuffer>>, Vec<ParseError>), timestamp: DateTime<Utc>, )

Appends buffer, if nonempty,to the queue. Reports to the controller thaterrors` occurred during parsing.

Source

pub fn queue(&self)

Flushes a batch of records to the circuit and reports to the consumer that it was done.

Only non-fault-tolerant input adapters can use this.

Auto Trait Implementations§

§

impl<A = (), B = Box<dyn InputBuffer>> !Freeze for InputQueue<A, B>

§

impl<A = (), B = Box<dyn InputBuffer>> !RefUnwindSafe for InputQueue<A, B>

§

impl<A = (), B = Box<dyn InputBuffer>> !UnwindSafe for InputQueue<A, B>

§

impl<A, B> Send for InputQueue<A, B>
where A: Send, B: Send,

§

impl<A, B> Sync for InputQueue<A, B>
where A: Send, B: Send,

§

impl<A, B> Unpin for InputQueue<A, B>
where A: Unpin, B: Unpin,

§

impl<A, B> UnsafeUnpin for InputQueue<A, B>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
Source§

impl<T> AsAny for T
where T: 'static,

Source§

fn as_any(&self) -> &(dyn Any + 'static)

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<F, W, T, D> Deserialize<With<T, W>, D> for F
where W: DeserializeWith<F, T, D>, D: Fallible + ?Sized, F: ?Sized,

Source§

fn deserialize( &self, deserializer: &mut D, ) -> Result<With<T, W>, <D as Fallible>::Error>

Deserializes using the given deserializer
Source§

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
Source§

impl<T> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Gets the layout of the type.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The type for metadata in pointers and references to Self.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The type for metadata in pointers and references to Self.
Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<G1, G2> Within<G2> for G1
where G2: Contains<G1>,

Source§

fn is_within(&self, b: &G2) -> bool