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

Source§

type Target = StatMsg

The Python output type
Source§

type Output = Bound<'py, <StatMsg as IntoPyObject<'py>>::Target>

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 as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::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 PyClass for StatMsg

Source§

type Frozen = False

Whether the pyclass is frozen. Read more
Source§

impl PyClassImpl for StatMsg

Source§

const IS_BASETYPE: bool = false

#[pyclass(subclass)]
Source§

const IS_SUBCLASS: bool = false

#[pyclass(extends=…)]
Source§

const IS_MAPPING: bool = false

#[pyclass(mapping)]
Source§

const IS_SEQUENCE: bool = false

#[pyclass(sequence)]
Source§

const IS_IMMUTABLE_TYPE: bool = false

#[pyclass(immutable_type)]
Source§

const RAW_DOC: &'static CStr = /// A statistics message. A catchall for various data disseminated by publishers. The /// [`stat_type`](Self::stat_type) indicates the statistic contained in the message.

Docstring for the class provided on the struct or enum. Read more
Source§

const DOC: &'static CStr

Fully rendered class doc, including the text_signature if a constructor is defined. Read more
Source§

type BaseType = PyAny

Base class
Source§

type ThreadChecker = SendablePyClass<StatMsg>

This handles following two situations: Read more
Source§

type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild

Immutable or mutable
Source§

type Dict = PyClassDictSlot

Specify this class has #[pyclass(dict)] or not.
Source§

type WeakRef = PyClassDummySlot

Specify this class has #[pyclass(weakref)] or not.
Source§

type BaseNativeType = PyAny

The closest native ancestor. This is PyAny by default, and when you declare #[pyclass(extends=PyDict)], it’s PyDict.
Source§

fn items_iter() -> PyClassItemsIter

Source§

fn dict_offset() -> Option<Py_ssize_t>

Source§

fn lazy_type_object() -> &'static LazyTypeObject<Self>

Source§

fn weaklist_offset() -> Option<isize>

Source§

impl PyClassNewTextSignature for StatMsg

Available on crate feature python only.
Source§

const TEXT_SIGNATURE: &'static str = "(publisher_id, instrument_id, ts_event, ts_recv, ts_ref, price, quantity, stat_type, sequence=0, ts_in_delta=0, channel_id=None, update_action=None, stat_flags=0)"

Source§

impl PyMethods<StatMsg> for PyClassImplCollector<StatMsg>

Available on crate feature python only.
Source§

fn py_methods(self) -> &'static PyClassItems

Source§

impl PyTypeInfo for StatMsg

Source§

const NAME: &'static str = "StatMsg"

Class name.
Source§

const MODULE: Option<&'static str>

Module name, if any.
Source§

fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject

Returns the PyTypeObject instance for this type.
Source§

fn type_object(py: Python<'_>) -> Bound<'_, PyType>

Returns the safe abstraction over the type object.
Source§

fn is_type_of(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of this type or a subclass of this type.
Source§

fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of this type.
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 DerefToPyAny for StatMsg

Source§

impl Eq for StatMsg

Source§

impl ExtractPyClassWithClone 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<'a, 'py, T> FromPyObject<'a, 'py> for T
where T: PyClass + Clone + ExtractPyClassWithClone,

Source§

type Error = PyClassGuardError<'a, 'py>

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

fn extract( obj: Borrowed<'a, 'py, PyAny>, ) -> Result<T, <T as FromPyObject<'a, 'py>>::Error>

Extracts Self from the bound smart pointer obj. 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<'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> PyTypeCheck for T
where T: PyTypeInfo,

Source§

const NAME: &'static str = T::NAME

👎Deprecated since 0.27.0: Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
Name of self. This is used in error messages, for example.
Source§

fn type_check(object: &Bound<'_, PyAny>) -> bool

Checks if object is an instance of Self, which may include a subtype. Read more
Source§

fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>

Returns the expected type as a possible argument for the isinstance and issubclass function. Read more
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<'py, T> FromPyObjectOwned<'py> for T
where T: for<'a> FromPyObject<'a, 'py>,

Source§

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