govuk-bank-holidays

Crates.iogovuk-bank-holidays
lib.rsgovuk-bank-holidays
version0.2.1
sourcesrc
created_at2024-01-26 14:21:25.065241
updated_at2024-11-20 10:38:42.991333
descriptionLibrary for loading the official list of bank holidays in the United Kingdom from GOV.UK
homepage
repositoryhttps://github.com/ministryofjustice/govuk-bank-holidays-rs
max_upload_size
id1115578
size157,666
(ushkarev)

documentation

README

GOV.UK Bank Holidays

This rust library loads the official list of bank holidays in the United Kingdom as supplied by GOV.UK, which tends to provide this list for only a year or two into the future.

A cached backup list of known bank holidays is stored in this package, though it is not updated often. GOV.UK no longer provide bank holidays for some of the older years still part of this backup list.

Bank holidays differ around the UK. The GOV.UK source currently lists these for 3 “divisions”:

  • England and Wales
  • Scotland
  • Northern Ireland

Methods on BankHolidayCalendar that take a division parameter will consider bank holidays only for the provided division (Some(Division)) or only those that are common to all divisions for None.

Using the library

github crates.io docs.rs

Add to your project with:

cargo add govuk-bank-holidays

See docs.rs for API information, usage samples and feature flags.

Developing library

Requirements

  • rust 1.75+ (using rustup is recommended)
  • just – for scripted shortcuts; like make

Releasing a new version

TODO

  • Better tests, coverage
  • Optionally merge in older known bank holidays into newly-downloaded GOV.UK data? Cached data starts in 2012, but currently GOV.UK provides nothing before 2018.
  • Performance improvements (particularly around memory and iterators)
  • Can DataSource be made private, exposing methods on LoadDataSource trait or elsewhere?
  • Allow for unknown “divisions”? Make enum non-exhaustive?

References

See also:

History

0.2.1

Updated dependencies

0.2.0

Allow for custom sources of bank holidays using LoadDataSource trait.

0.1.1

Very minor changes – tidier code and improved documentation.

0.1.0

Initial release with API likely to be unstable.

Commit count: 19

cargo fmt