QuoteCache

Struct QuoteCache 

Source
pub struct QuoteCache { /* private fields */ }
Expand description

A cache for storing the last known quote per instrument.

This is particularly useful for handling partial quote updates from exchange WebSocket feeds, where updates may only include one side of the market (bid or ask). The cache maintains the most recent complete quote for each instrument, allowing adapters to fill in missing information when processing partial updates.

§Thread Safety

This cache is not thread-safe. If shared across threads, wrap it in an appropriate synchronization primitive such as Arc<RwLock<QuoteCache>> or Arc<Mutex<QuoteCache>>.

Implementations§

Source§

impl QuoteCache

Source

pub fn new() -> Self

Creates a new empty QuoteCache.

Source

pub fn get(&self, instrument_id: &InstrumentId) -> Option<&QuoteTick>

Returns the cached quote for the given instrument, if available.

Source

pub fn insert( &mut self, instrument_id: InstrumentId, quote: QuoteTick, ) -> Option<QuoteTick>

Inserts or updates a quote in the cache for the given instrument.

Returns the previously cached quote if one existed.

Source

pub fn remove(&mut self, instrument_id: &InstrumentId) -> Option<QuoteTick>

Removes the cached quote for the given instrument.

Returns the removed quote if one existed.

Source

pub fn contains(&self, instrument_id: &InstrumentId) -> bool

Returns true if the cache contains a quote for the given instrument.

Source

pub fn len(&self) -> usize

Returns the number of cached quotes.

Source

pub fn is_empty(&self) -> bool

Returns true if the cache is empty.

Source

pub fn clear(&mut self)

Clears all cached quotes.

This is typically called after a reconnection to ensure stale quotes from before the disconnect are not used.

Source

pub fn process( &mut self, instrument_id: InstrumentId, bid_price: Option<Price>, ask_price: Option<Price>, bid_size: Option<Quantity>, ask_size: Option<Quantity>, ts_event: UnixNanos, ts_init: UnixNanos, ) -> Result<QuoteTick>

Processes a partial quote update, merging with cached values when needed.

This method handles partial quote updates where some fields may be missing. If any field is None, it will use the corresponding field from the cached quote. If there is no cached quote and any field is missing, an error is returned.

§Errors

Returns an error if:

  • Any required field is None and there is no cached quote.
  • The first quote received is incomplete (no cached values to merge with).

Trait Implementations§

Source§

impl Clone for QuoteCache

Source§

fn clone(&self) -> QuoteCache

Returns a duplicate of the value. Read more
1.0.0§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for QuoteCache

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for QuoteCache

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

§

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

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

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

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

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

§

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

Mutably borrows from an owned value. Read more
§

impl<T> CloneToUninit for T
where T: Clone,

§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

fn in_current_span(self) -> Instrumented<Self>

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

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

§

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> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> ToOwned for T
where T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

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

§

type Error = Infallible

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

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

Performs the conversion.
§

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

§

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

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

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

Performs the conversion.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<T> Allocation for T
where T: RefUnwindSafe + Send + Sync,

§

impl<T> Ungil for T
where T: Send,