28 releases (6 breaking)
0.11.0 | Dec 30, 2024 |
---|---|
0.9.1 | Nov 26, 2024 |
0.6.18 | Nov 27, 2023 |
0.6.15 | Jun 14, 2023 |
0.6.4 | Aug 12, 2022 |
#265 in Date and time
583 downloads per month
Used in opening-hours
28KB
294 lines
Compact representation for a calendar
This modules basically builds a data-structure for a set of days based on bit-maps. This is built to store a collection of regional holidays for the opening-hours crate.
Data layout
Here is how serialized data is represented:
start size year 1 year 2 ...
┌──────┬──────┬───────────────┬───────────────┬────
│ 8B │ 8B │ 8B * 12 = 96B │ 8B * 12 = 96B │ ...
└──────┴──────┴───────────────┴───────────────┴────
Each year is just an array of 12 u32
where the least significant bits each
represent a day.
While a bitset might not be the most efficient way to store a collection of dates for sparse data, this approached proved to be very compact when combined with a Zlib encoder. This methods allowed to store all holidays from 2000 to 2100 as described by workalendar in only 60kb of data.
"Root Package"
"Root Package"
"Documentation"
"Workalendar Python Package"
Dependencies
~1MB
~18K SLoC