Calendrical
Calendrical provides calendar-related functions that build upon the
conversion capabilities of Calendar available in Elixir from verison 1.5.0.
The conversion mechanism is based upon the definition of rata die as described
in Calendrical Calculations
by Dershowitz and Reingold. This rata die gives a numerical value to a moment in time
that is idependent of any specific calendar. As a result libraries such as Calendrical can
implement different calendars and calendar calculations in a conformant way.
Calendrical implements:
K-Day calculations in
Calendrical.KdayJulian Day conversion in
Calendrical.JulianDay. Note this is not the same thing as the Julian calendar.A calendar
Calendrical.Calendar.Gregorianthat is largely the same as the standard ElixirCalendar.ISO. The standard should be preferredSeveral calendars of primarily historic usage:
* `Calendrical.Calendar.Armenian`
* `Calendrical.Calendar.Coptic`
* `Calendrical.Calendar.Egyptian`
* `Calendrical.Calendar.Ethiopic`
* `Calendrical.Calendar.Julian`Roadmap
[ ] Date and time formatting which will be done in a locale sensitive way through the ex_cldr package after it is updated to provide that support. Expected in July 2017.
[ ] Hebrew, Islamic and Persian calendars (the arithmetic versions) are expected to land in July 2017
[ ] Astronomical calendar types will be implemented but only after the required astronomy library is built (ie not expected before year end 2017)
Elixir Version Support
Calendrical requires Elixir 1.5 or later. It is tested on Elixir 1.5.0-rc.0
Installation
-
Add
calendricalto your list of dependencies inmix.exs:
def deps do
[{:calendrical, "~> 0.1.2"}]
end-
Ensure
calendricalis started before your application:
def application do
[applications: [:calendrical]]
endThe docs can be found at https://hexdocs.pm/calendrical