pub struct PoolSnapshot {
pub instrument_id: InstrumentId,
pub state: PoolState,
pub positions: Vec<PoolPosition>,
pub ticks: Vec<PoolTick>,
pub analytics: PoolAnalytics,
pub block_position: BlockPosition,
}Expand description
Complete snapshot of a liquidity pool’s state at a specific point in time.
PoolSnapshot provides a self-contained representation of a pool’s
entire state, bundling together the global state variables, all liquidity positions,
and the complete tick distribution.
Fields§
§instrument_id: InstrumentIdThe instrument ID of the pool this snapshot represents.
state: PoolStateGlobal pool state including price, tick, fees, and cumulative flows.
positions: Vec<PoolPosition>All liquidity positions in the pool.
ticks: Vec<PoolTick>Complete tick distribution across the pool’s price range.
analytics: PoolAnalyticsAnalytics counters for the pool.
block_position: BlockPositionBlock position where this snapshot was taken.
Implementations§
Source§impl PoolSnapshot
impl PoolSnapshot
Sourcepub fn new(
instrument_id: InstrumentId,
state: PoolState,
positions: Vec<PoolPosition>,
ticks: Vec<PoolTick>,
analytics: PoolAnalytics,
block_position: BlockPosition,
) -> Self
pub fn new( instrument_id: InstrumentId, state: PoolState, positions: Vec<PoolPosition>, ticks: Vec<PoolTick>, analytics: PoolAnalytics, block_position: BlockPosition, ) -> Self
Creates a new PoolSnapshot with the specified parameters.
Trait Implementations§
Source§impl Clone for PoolSnapshot
impl Clone for PoolSnapshot
Source§fn clone(&self) -> PoolSnapshot
fn clone(&self) -> PoolSnapshot
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for PoolSnapshot
impl Debug for PoolSnapshot
Source§impl<'de> Deserialize<'de> for PoolSnapshot
impl<'de> Deserialize<'de> for PoolSnapshot
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl From<PoolSnapshot> for DefiData
impl From<PoolSnapshot> for DefiData
Source§fn from(value: PoolSnapshot) -> Self
fn from(value: PoolSnapshot) -> Self
Source§impl<'a, 'py> FromPyObject<'a, 'py> for PoolSnapshotwhere
Self: Clone,
impl<'a, 'py> FromPyObject<'a, 'py> for PoolSnapshotwhere
Self: Clone,
Source§impl<'py> IntoPyObject<'py> for PoolSnapshot
impl<'py> IntoPyObject<'py> for PoolSnapshot
Source§type Target = PoolSnapshot
type Target = PoolSnapshot
Source§type Output = Bound<'py, <PoolSnapshot as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <PoolSnapshot as IntoPyObject<'py>>::Target>
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Source§impl PartialEq for PoolSnapshot
impl PartialEq for PoolSnapshot
Source§impl PyClass for PoolSnapshot
impl PyClass for PoolSnapshot
Source§impl PyClassImpl for PoolSnapshot
impl PyClassImpl for PoolSnapshot
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
Source§const RAW_DOC: &'static CStr = /// Complete snapshot of a liquidity pool's state at a specific point in time.
///
/// `PoolSnapshot` provides a self-contained representation of a pool's
/// entire state, bundling together the global state variables, all liquidity positions,
/// and the complete tick distribution.
const RAW_DOC: &'static CStr = /// Complete snapshot of a liquidity pool's state at a specific point in time. /// /// `PoolSnapshot` provides a self-contained representation of a pool's /// entire state, bundling together the global state variables, all liquidity positions, /// and the complete tick distribution.
Source§const DOC: &'static CStr
const DOC: &'static CStr
text_signature if a constructor is defined. Read moreSource§type Layout = <<PoolSnapshot as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<PoolSnapshot>
type Layout = <<PoolSnapshot as PyClassImpl>::BaseNativeType as PyClassBaseType>::Layout<PoolSnapshot>
Source§type ThreadChecker = NoopThreadChecker
type ThreadChecker = NoopThreadChecker
type Inventory = Pyo3MethodsInventoryForPoolSnapshot
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
§fn dict_offset() -> Option<PyObjectOffset>
fn dict_offset() -> Option<PyObjectOffset>
§fn weaklist_offset() -> Option<PyObjectOffset>
fn weaklist_offset() -> Option<PyObjectOffset>
Source§impl PyStubType for PoolSnapshot
impl PyStubType for PoolSnapshot
Source§fn type_output() -> TypeInfo
fn type_output() -> TypeInfo
§fn type_input() -> TypeInfo
fn type_input() -> TypeInfo
Source§impl PyTypeInfo for PoolSnapshot
impl PyTypeInfo for PoolSnapshot
Source§const NAME: &str = <Self as ::pyo3::PyClass>::NAME
const NAME: &str = <Self as ::pyo3::PyClass>::NAME
prefer using ::type_object(py).name() to get the correct runtime value
Source§const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
const MODULE: Option<&str> = <Self as ::pyo3::impl_::pyclass::PyClassImpl>::MODULE
prefer using ::type_object(py).module() to get the correct runtime value
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
object is an instance of this type.Source§impl Serialize for PoolSnapshot
impl Serialize for PoolSnapshot
impl DerefToPyAny for PoolSnapshot
impl StructuralPartialEq for PoolSnapshot
Auto Trait Implementations§
impl Freeze for PoolSnapshot
impl RefUnwindSafe for PoolSnapshot
impl Send for PoolSnapshot
impl Sync for PoolSnapshot
impl Unpin for PoolSnapshot
impl UnsafeUnpin for PoolSnapshot
impl UnwindSafe for PoolSnapshot
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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>
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>
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§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
self into a Python object. Read more§impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
impl<'py, T> IntoPyObjectNautilusExt<'py> for Twhere
T: IntoPyObjectExt<'py>,
§fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
fn into_py_any_unwrap(self, py: Python<'py>) -> Py<PyAny>
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
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.
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
isinstance and issubclass function. Read more