pub struct Cal {
pub holidays: IndexSet<NaiveDateTime>,
pub week_mask: HashSet<Weekday>,
}
Expand description
A basic business day calendar containing holidays.
Fields§
§holidays: IndexSet<NaiveDateTime>
A vector of specific dates that are defined as non-business days.
week_mask: HashSet<Weekday>
A vector of days in the week that are defined as non-business days. E.g. [5, 6]
for Saturday and Sunday.
Implementations§
Trait Implementations§
Source§impl CalendarAdjustment for Cal
impl CalendarAdjustment for Cal
Source§fn adjust(&self, udate: &NaiveDateTime, adjuster: &Adjuster) -> NaiveDateTime
fn adjust(&self, udate: &NaiveDateTime, adjuster: &Adjuster) -> NaiveDateTime
Adjust a date under an adjustment rule.
Source§fn adjusts(
&self,
udates: &Vec<NaiveDateTime>,
adjuster: &Adjuster,
) -> Vec<NaiveDateTime>
fn adjusts( &self, udates: &Vec<NaiveDateTime>, adjuster: &Adjuster, ) -> Vec<NaiveDateTime>
Adjust a vector of dates under an adjustment rule;
Source§impl DateRoll for Cal
impl DateRoll for Cal
Source§fn is_weekday(&self, date: &NaiveDateTime) -> bool
fn is_weekday(&self, date: &NaiveDateTime) -> bool
Returns whether the date is part of the general working week.
Source§fn is_holiday(&self, date: &NaiveDateTime) -> bool
fn is_holiday(&self, date: &NaiveDateTime) -> bool
Returns whether the date is a specific holiday excluded from the regular working week.
Source§fn is_settlement(&self, _date: &NaiveDateTime) -> bool
fn is_settlement(&self, _date: &NaiveDateTime) -> bool
Returns whether the date is valid relative to an associated settlement calendar. Read more
Source§fn is_bus_day(&self, date: &NaiveDateTime) -> bool
fn is_bus_day(&self, date: &NaiveDateTime) -> bool
Returns whether the date is a business day, i.e. part of the working week and not a holiday.
Source§fn is_non_bus_day(&self, date: &NaiveDateTime) -> bool
fn is_non_bus_day(&self, date: &NaiveDateTime) -> bool
Returns whether the date is not a business day, i.e. either not in working week or a specific holiday.
Source§fn roll_forward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
fn roll_forward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
Return the
date
, if a business day, or get the next business date after date
.Source§fn roll_backward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
fn roll_backward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
Return the
date
, if a business day, or get the business day preceding date
.Source§fn roll_mod_forward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
fn roll_mod_forward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
Return the
date
, if a business day, or get the proceeding business date, without rolling
into a new month.Source§fn roll_mod_backward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
fn roll_mod_backward_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
Return the
date
, if a business day, or get the proceeding business date, without rolling
into a new month.Source§fn roll_forward_settled_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
fn roll_forward_settled_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
Return the date, if a business day that can be settled, or the proceeding date that is such. Read more
Source§fn roll_backward_settled_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
fn roll_backward_settled_bus_day(&self, date: &NaiveDateTime) -> NaiveDateTime
Return the date, if a business day that can be settled, or the preceding date that is such. Read more
Source§fn roll_forward_mod_settled_bus_day(
&self,
date: &NaiveDateTime,
) -> NaiveDateTime
fn roll_forward_mod_settled_bus_day( &self, date: &NaiveDateTime, ) -> NaiveDateTime
Return the
date
, if a business day that can be settled, or get the proceeding
such date, without rolling into a new month.Source§fn roll_backward_mod_settled_bus_day(
&self,
date: &NaiveDateTime,
) -> NaiveDateTime
fn roll_backward_mod_settled_bus_day( &self, date: &NaiveDateTime, ) -> NaiveDateTime
Return the
date
, if a business day that can be settled, or get the preceding such date, without rolling
into a new month.Source§fn lag_bus_days(
&self,
date: &NaiveDateTime,
days: i32,
settlement: bool,
) -> NaiveDateTime
fn lag_bus_days( &self, date: &NaiveDateTime, days: i32, settlement: bool, ) -> NaiveDateTime
Adjust a date by a number of business days, under lag rules. Read more
Source§fn add_cal_days(
&self,
date: &NaiveDateTime,
days: i32,
adjuster: &Adjuster,
) -> NaiveDateTimewhere
Self: Sized,
fn add_cal_days(
&self,
date: &NaiveDateTime,
days: i32,
adjuster: &Adjuster,
) -> NaiveDateTimewhere
Self: Sized,
Add a given number of calendar days to a
date
with the result adjusted to a business day that may or may not
allow settlement
.Source§fn add_bus_days(
&self,
date: &NaiveDateTime,
days: i32,
settlement: bool,
) -> Result<NaiveDateTime, PyErr>
fn add_bus_days( &self, date: &NaiveDateTime, days: i32, settlement: bool, ) -> Result<NaiveDateTime, PyErr>
Add a given number of business days to a
date
with the result adjusted to a business day that may or may
not allow settlement
. Read moreSource§fn bus_date_range(
&self,
start: &NaiveDateTime,
end: &NaiveDateTime,
) -> Result<Vec<NaiveDateTime>, PyErr>
fn bus_date_range( &self, start: &NaiveDateTime, end: &NaiveDateTime, ) -> Result<Vec<NaiveDateTime>, PyErr>
Return a vector of business dates between a start and end, inclusive.
Source§fn cal_date_range(
&self,
start: &NaiveDateTime,
end: &NaiveDateTime,
) -> Result<Vec<NaiveDateTime>, PyErr>
fn cal_date_range( &self, start: &NaiveDateTime, end: &NaiveDateTime, ) -> Result<Vec<NaiveDateTime>, PyErr>
Return a vector of calendar dates between a start and end, inclusive
Source§impl<'de> Deserialize<'de> for Cal
impl<'de> Deserialize<'de> for Cal
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>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<'py> IntoPyObject<'py> for Cal
impl<'py> IntoPyObject<'py> for Cal
Source§impl PyClassImpl for Cal
impl PyClassImpl for Cal
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
#[pyclass(subclass)]
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
#[pyclass(extends=…)]
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
#[pyclass(mapping)]
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
#[pyclass(sequence)]
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
#[pyclass(immutable_type)]
Source§type ThreadChecker = SendablePyClass<Cal>
type ThreadChecker = SendablePyClass<Cal>
This handles following two situations: Read more
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Immutable or mutable
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
The closest native ancestor. This is
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<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyClassNewTextSignature<Cal> for PyClassImplCollector<Cal>
impl PyClassNewTextSignature<Cal> for PyClassImplCollector<Cal>
fn new_text_signature(self) -> Option<&'static str>
Source§impl PyMethods<Cal> for PyClassImplCollector<Cal>
impl PyMethods<Cal> for PyClassImplCollector<Cal>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for Cal
impl PyTypeInfo for Cal
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
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
Checks if
object
is an instance of this type.impl DerefToPyAny for Cal
impl StructuralPartialEq for Cal
Auto Trait Implementations§
impl Freeze for Cal
impl RefUnwindSafe for Cal
impl Send for Cal
impl Sync for Cal
impl Unpin for Cal
impl UnwindSafe for Cal
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> FromPyObject<'_> for Twhere
T: PyClass + Clone,
impl<T> FromPyObject<'_> for Twhere
T: PyClass + Clone,
§fn extract_bound(obj: &Bound<'_, PyAny>) -> Result<T, PyErr>
fn extract_bound(obj: &Bound<'_, PyAny>) -> Result<T, PyErr>
§impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
impl<'py, T> FromPyObjectBound<'_, 'py> for Twhere
T: FromPyObject<'py>,
§fn from_py_object_bound(ob: Borrowed<'_, 'py, PyAny>) -> Result<T, PyErr>
fn from_py_object_bound(ob: Borrowed<'_, 'py, PyAny>) -> Result<T, PyErr>
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>
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 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>
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§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>
Converts
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>
Converts
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>
Converts
self
into a Python object. Read more§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
self
to the equivalent element of its superset.