Skip to main content

StatMsg

Struct StatMsg 

Source
pub struct StatMsg {
    pub hd: RecordHeader,
    pub ts_recv: u64,
    pub ts_ref: u64,
    pub price: i64,
    pub quantity: i64,
    pub sequence: u32,
    pub ts_in_delta: i32,
    pub stat_type: u16,
    pub channel_id: u16,
    pub update_action: u8,
    pub stat_flags: u8,
    /* private fields */
}
Expand description

A statistics message. A catchall for various data disseminated by publishers. The stat_type indicates the statistic contained in the message.

Fields§

§hd: RecordHeader

The common header.

§ts_recv: u64

The capture-server-received timestamp expressed as the number of nanoseconds since the UNIX epoch.

See ts_recv.

§ts_ref: u64

The reference timestamp of the statistic value expressed as the number of nanoseconds since the UNIX epoch. Will be UNDEF_TIMESTAMP when unused.

§price: i64

The value for price statistics where every 1 unit corresponds to 1e-9, i.e. 1/1,000,000,000 or 0.000000001. Will be UNDEF_PRICE when unused.

See Prices.

§quantity: i64

The value for non-price statistics. Will be UNDEF_STAT_QUANTITY when unused.

§sequence: u32

The message sequence number assigned at the venue.

§ts_in_delta: i32

The matching-engine-sending timestamp expressed as the number of nanoseconds before ts_recv.

See ts_in_delta.

§stat_type: u16

The type of statistic value contained in the message. Refer to the StatType enum for possible variants.

§channel_id: u16

The channel ID assigned by Databento as an incrementing integer starting at zero.

§update_action: u8

Indicates if the statistic is newly added (1) or deleted (2). (Deleted is only used with some stat types).

§stat_flags: u8

Additional flags associate with certain stat types.

Implementations§

Source§

impl StatMsg

Source

pub fn ts_recv(&self) -> Option<OffsetDateTime>

Parses the capture-server-received timestamp into a datetime. Returns None if ts_recv contains the sentinel for a null timestamp.

Source

pub fn ts_ref(&self) -> Option<OffsetDateTime>

Parses the reference timestamp of the statistic value into a datetime. Returns None if ts_ref contains the sentinel for a null timestamp.

Source

pub fn price_f64(&self) -> f64

Converts the value for price statistics to a floating point.

UNDEF_PRICE will be converted to NaN.

This may introduce floating-point error.
Source

pub fn ts_in_delta(&self) -> Duration

Parses the difference between ts_recv and the matching-engine-sending timestamp into a duration.

Source

pub fn stat_type(&self) -> Result<StatType>

Parses the type of statistic value into an enum.

§Errors

This function returns an error if the stat_type field does not contain a valid StatType.

Source

pub fn update_action(&self) -> Result<StatUpdateAction>

Parses the update action into an enum.

§Errors

This function returns an error if the update_action field does not contain a valid StatUpdateAction.

Trait Implementations§

Source§

impl AsRef<[u8]> for StatMsg

Source§

fn as_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl Clone for StatMsg

Source§

fn clone(&self) -> StatMsg

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for StatMsg

Source§

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

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

impl Default for StatMsg

Source§

fn default() -> Self

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

impl<'de> Deserialize<'de> for StatMsg

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl<'a> From<&'a StatMsg> for RecordRefEnum<'a>

Source§

fn from(rec: &'a StatMsg) -> Self

Converts to this type from the input type.
Source§

impl From<&StatMsgV1> for StatMsg

Source§

fn from(old: &StatMsg) -> Self

Converts to this type from the input type.
Source§

impl From<StatMsg> for RecordEnum

Source§

fn from(rec: StatMsg) -> Self

Converts to this type from the input type.
Source§

impl HasRType for StatMsg

Source§

fn has_rtype(rtype: u8) -> bool

Returns true if rtype matches the value associated with the implementing type.
Source§

impl Hash for StatMsg

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl<'py> IntoPyObject<'py> for StatMsg

Available on crate feature python only.

Convert bare StatMsg to Python by wrapping with UNDEF_TIMESTAMP for ts_out.

Source§

type Target = PyAny

The Python output type
Source§

type Output = Bound<'py, PyAny>

The smart pointer type to use. Read more
Source§

type Error = PyErr

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

fn into_pyobject(self, py: Python<'py>) -> Result<Self::Output, Self::Error>

Performs the conversion.
Source§

impl PartialEq for StatMsg

Source§

fn eq(&self, other: &StatMsg) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for StatMsg

Source§

fn partial_cmp(&self, other: &Self) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Record for StatMsg

Source§

fn header(&self) -> &RecordHeader

Returns a reference to the RecordHeader that comes at the beginning of all record types.
Source§

fn raw_index_ts(&self) -> u64

Returns the raw primary timestamp for the record. Read more
Source§

fn record_size(&self) -> usize

Returns the size of the record in bytes.
Source§

fn rtype(&self) -> Result<RType>

Tries to convert the raw record type into an enum which is useful for exhaustive pattern matching. Read more
Source§

fn publisher(&self) -> Result<Publisher>

Tries to convert the raw publisher_id into an enum which is useful for exhaustive pattern matching. Read more
Source§

fn index_ts(&self) -> Option<OffsetDateTime>

Returns the primary timestamp for the record. Returns None if the primary timestamp contains the sentinel value for a null timestamp. Read more
Source§

fn index_date(&self) -> Option<Date>

Returns the primary date for the record; the date component of the primary timestamp (index_ts()). Returns None if the primary timestamp contains the sentinel value for a null timestamp.
Source§

impl RecordMut for StatMsg

Source§

fn header_mut(&mut self) -> &mut RecordHeader

Returns a mutable reference to the RecordHeader that comes at the beginning of all record types.
Source§

impl Serialize for StatMsg

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StatRec for StatMsg

Source§

const UNDEF_STAT_QUANTITY: i64 = UNDEF_STAT_QUANTITY

The sentinel value for a null quantity.
Source§

fn stat_type(&self) -> Result<StatType>

Tries to convert the raw type of the statistic value to an enum. Read more
Source§

fn ts_recv(&self) -> Option<OffsetDateTime>

Parses the raw capture-server-received timestamp into a datetime. Returns None if ts_recv contains the sentinel for a null timestamp.
Source§

fn ts_ref(&self) -> Option<OffsetDateTime>

Parses the raw reference timestamp of the statistic value into a datetime. Returns None if ts_ref contains the sentinel for a null timestamp.
Source§

fn update_action(&self) -> Result<StatUpdateAction>

Tries to convert the raw update_action to an enum. Read more
Source§

fn price(&self) -> i64

The value for price statistics expressed as a signed integer where every 1 unit corresponds to 1e-9, i.e. 1/1,000,000,000 or 0.000000001. Will be UNDEF_PRICE when unused.
Source§

fn quantity(&self) -> i64

The value for quantity statistics. Will be UNDEF_STAT_QUANTITY when unused.
Source§

impl WritePyRepr for StatMsg

Available on crate feature python only.
Source§

fn write_py_repr(&self, s: &mut String) -> Result

Writes a Python-style string representation to s. Read more
Source§

const SHOULD_FLATTEN: bool = false

Whether this type’s fields should be flattened into the parent repr.
Source§

impl Copy for StatMsg

Source§

impl Eq for StatMsg

Source§

impl StructuralPartialEq for StatMsg

Auto Trait Implementations§

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> 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<T> CloneToUninit for T
where T: Clone,

Source§

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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<'py, T> IntoPyObjectExt<'py> for T
where T: IntoPyObject<'py>,

Source§

fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>

Converts self into an owned Python object, dropping type information.
Source§

fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>

Converts self into an owned Python object, dropping type information and unbinding it from the 'py lifetime.
Source§

fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>

Converts self into a Python object. Read more
Source§

impl<T> PyErrArguments for T
where T: for<'py> IntoPyObject<'py> + Send + Sync,

Source§

fn arguments(self, py: Python<'_>) -> Py<PyAny>

Arguments for exception
Source§

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

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

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

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

Uses borrowed data to replace owned data, usually by cloning. Read more
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<T> DbnEncodable for T
where T: Record + CsvSerialize + Debug + JsonSerialize,

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

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