#holidays #date-time #calendar #nyse #business-day

bin+lib nyse-holiday-cal

NYSE holiday calendar library

3 unstable releases

0.2.1 Jan 12, 2024
0.2.0 Apr 28, 2023
0.1.0 Mar 25, 2023

#175 in Date and time

Download history 88/week @ 2024-08-17 1/week @ 2024-08-24 46/week @ 2024-08-31 4/week @ 2024-09-07 53/week @ 2024-09-14 213/week @ 2024-09-21 56/week @ 2024-09-28 125/week @ 2024-10-05 113/week @ 2024-10-12 127/week @ 2024-10-19 102/week @ 2024-10-26 251/week @ 2024-11-02 140/week @ 2024-11-09 295/week @ 2024-11-16 133/week @ 2024-11-23 86/week @ 2024-11-30

704 downloads per month

MIT license

45KB
816 lines

Overview

Library crate for looking up market holiday information as observed by the New York Stock Exchange.

Use-cases

  • Determine if a specific date is/was an NYSE market holiday
  • Determine which holiday NYSE observed or plans to observe on a specific date
  • Iterate over sequences of consecutive business days
  • Perform basic business-day arithmetic on dates
  • Convert between dates and business day of month ordinals

Usage

This crate is designed to work with foreign date types which represent dates in the proleptic Gregorian calendar. By default, chrono::NaiveDate is used as the date type, but with optional crate feature time enabled, support for time::Date is added as well.

The main interface for looking up holiday and business day information is trait HolidayCal. This trait is implemented for all supported foreign date types.

The main interface for performing business-day arithmetic is struct DeltaBusinessDays. This struct represents an integer number of business days and can be used in arithmetic with supported foreign date types via the Add and Sub traits from the standard library.

Why not other crates?

There are several other holiday calendar crates in the Rust ecosystem, which provide a framework for developing holiday calendar functionality:

However, these crates are ill-suited for implementing NYSE holiday calendars because they all assume that the holiday status of any date can be determined. In general, it is only possible to determine if a date is an NYSE market holiday if it is before 31 December of the year of the latest published official NYSE holiday calendar.

Design

The design of the this create is simple, it maintains a list of observed and planned market holidays according to NYSE's officially released schedule. This list of known market holidays defines a range spanning from 1 Jan in the year MIN_YEAR to 31 December in the year MAX_YEAR. Dates that fall in this range are considered market holidays if and only if they are equal to one of the dates in the holiday list. For dates that fall outside this range, it is not possible to determine whether or not they are NYSE market holidays and so generally, Err(OutOfRange) is returned for queries involving such dates.

When the NYSE publishes their market holiday calendar for a new year, the holidays list will be updated accordingly, MAX_YEAR will be incremented accordingly, and the patch version of this crate will be incremented.

Typically, NYSE publishes holiday calendars 1-2 years in advance of the current date.

Dependencies

~1–1.4MB
~21K SLoC