Changelog for Cldr Calendars v1.11.0-rc.0
This is the changelog for Cldr Calendars v1.11.0-rc.0 released on October 27th, 2020. For older changelogs please consult the release tag on GitHub
Enhancements
- Add support for CLDR 38
Changelog for Cldr Calendars v1.10.1
This is the changelog for Cldr Calendars v1.10.1 released on September 26th, 2020. For older changelogs please consult the release tag on GitHub
Bug Fixes
- Add a shim for
default_backend/0that delegates toCldr.default_backend/0orCldr.default_backend!/0depending onex_cldrrelease. Releases from2.18.0useCldr.default_backend!/0.
Changelog for Cldr Calendars v1.10.0
This is the changelog for Cldr Calendars v1.10.0 released on August 29th, 2020. For older changelogs please consult the release tag on GitHub
Enhancements
- Supports upcoming Elixir 1.11.0. The
Calendarcallback forday_of_week/3has been changed today_of_week/4to allow for a different start day of week. SinceCldr Calendarsalready supports defining calendars with different start days of the week (ie other than Monday), the impementation only supports the:defaultparameter. Thanks to @lostkobrakai for the report. ClosesCldr Dates Timesissue #17.
Changelog for Cldr Calendars v1.9.0
This is the changelog for Cldr Calendars v1.9.0 released on June 7th, 2020. For older changelogs please consult the release tag on GitHub
Enhancements
Add
Cldr.Calendar.plus/{3,4}that allows adding aCldr.Calendar.Durationto aCalendar.date. Support for adding durations todatetimes is not yet available.Add support for
datetimestoCldr.Calendar.Duration.new/2Add support for
Date.Range.tandCalendarInterval.ttoCldr.Calendar.Duration.new/1
Bug Fixes
- More complete test coverage on durations with some additional corner case fixes
Changelog for Cldr Calendars v1.8.1
This is the changelog for Cldr Calendars v1.8.1 released on June 4th, 2020. For older changelogs please consult the release tag on GitHub
Bug Fixes
- Fix duration calculation when the year and month are the same and the day of the last date is greater than the day of the first date
Changelog for Cldr Calendars v1.8.0
This is the changelog for Cldr Calendars v1.8.0 released on May 4th, 2020. For older changelogs please consult the release tag on GitHub
Breaking Change (that you might notice but probably won't)
- The
min_days_in_first_weekfor the calendarCldr.Calendar.Gregorianis changed to be1rather than the previous value of4. This only affects week-related processing for the calendar. The reason for the change is that the majority of territories have a preference for1formin_days_in_first_weeksoCldr.Calendar.Gregorianmore closely aligns to majority expectations.
Breaking changes (that you shouldn't notice)
- The return result from
Cldr.Calendar.new/3may return{:module_already_exists, module}. It previously returned{:already_exists, module}
Bug Fixes
Use
backend.get_locale/0instead ofCldr.get_locale/0for all optionsEnsure that the default values for a locale's
min_daysandfirst_day_of_weekare correctly applied inCldr.Calendar.new/3. Any values passed as options take precedence over those defined for a locale.
Enhancements
Add
Cldr.Calendar.calendar_for_locale/2which will create (or return) a gregorian-based calendar configured for the supplied locale. This typically means applying the correct values formin_daysandfirst_day_of_week. For now all calendars created in this way are Gregorian monthly calendars.Add
Cldr.Calendar.Preference.calendar_for_locale/1which returns the appropriate calendar for a locale based upon locale preferences and configured calendars. UnlikeCldr.Calendar.calendar_for_locale/2, this function may return non-Gregorian calendars. For example, for the localefa-IRit will returnCldr.Calendar.Persian(if ex_cldr_calendars_persian is configured) because that is the locale preference.Add
Cldr.Calendar.Preference.calendar_for_territory/1provides the same result asCldr.Calendar.Preference.calendar_for_locale/2except that argument is a territory code.Add
Cldr.Calendar.validate_calendar/1which returns{:ok, calendar}if the argument is aCldr.Calendarcalendar module or{:error, {exception, reason}}if not.
Changelog for Cldr Calendars v1.7.1
This is the changelog for Cldr Calendars v1.7.1 released on January 26th, 2020. For older changelogs please consult the release tag on GitHub
Bug Fixes
- Fix doc link in
MyApp.Cldr.Calendar.strftime_options!/2
Changelog for Cldr Calendars v1.7.0
This is the changelog for Cldr Calendars v1.7.0 released on January 2nd, 2020. For older changelogs please consult the release tag on GitHub
Enhancements
- Remove call to deprecated
Code.ensure_compiled?/1in Elixir 1.10
Changelog for Cldr Calendars v1.6.0
This is the changelog for Cldr Calendars v1.6.0 released on December 9th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
- Adds support for localizing Persian, Coptic and Ethiopic calendar localization. These calendars are published separately but they rely upon localization support from this package.
Changelog for Cldr Calendars v1.5.1
This is the changelog for Cldr Calendars v1.5.1 released on November 10th, 2019. For older changelogs please consult the release tag on GitHub
Bug Fixes
- Fix
Cldr.Calendar.next/3andCldr.Calendar.previous/3for months with week-based calendars. Thanks to @bglusman for the report. Closes #3. Note that the use of the:coerceoption is recommended in most cases.
Changelog for Cldr Calendars v1.5.0
This is the changelog for Cldr Calendars v1.5.0 released on November 3rd, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
- Adds
MyApp.Cldr.Calendar.strftime_options!/2to return a keyword list of options that can be applied toNimbleStrftime.format/3
Changelog for Cldr Calendars v1.4.0
This is the changelog for Cldr Calendars v1.4.0 released on September 14th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
- Adjusts
<calendar>.add/3to<calendar>.add/5so that it takes individual date and time elements and not formal structs. This is consistent with other calendar behaviours.
Changelog for Cldr Calendars v1.3.0
This is the changelog for Cldr Calendars v1.3.0 released on September 1st, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
Adds <calendar>.add/3 to add :quarter or :week to a naive datetime. This adds to the existing support for :year and :month.
Changelog for Cldr Calendars v1.2.0
This is the changelog for Cldr Calendars v1.2.0 released on August 31st, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
Adds
Cldr.Calendar.Durationto create a duration struct defining the difference between two dates, times or date_times as a calendar difference in years, months, days, hours, minutes, seconds and microseconds. SeeCldr.Calendar.Duration.new/2andCldr.Calendar.Duration.to_string/1.Changes
sigil_d/2from a function to a macro so that dates are created at compile time
Changelog for Cldr Calendars v1.1.0
This is the changelog for Cldr Calendars v1.1.0 released on August 30th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
Adds
<calendar>.add/3to add:yearor:monthto a naive datetime. This function supports the library calendar_interval allowing intervals to be used withex_cldr_calendars[https://hex.pm/packages/ex_cldr_calendars]. The mid-term objective is to addadd/3to theCalendarbehaviour and thereby also simplify the interface toCalendarInterval.Changes the output of
to_string/1to consistently use the full name of the calendar module, not an appreviated name.
Changelog for Cldr Calendars v1.0.0
This is the changelog for Cldr Calendars v1.0.0 released on June 16th, 2019. For older changelogs please consult the release tag on GitHub
Breaking changes
The format produced by inspecting a Date (or DateTime or NaiveDateTime) has changed. The parsing of dates in
sigil_d(the~dsigil) has also changed in order to facilitate roundtrip conversions. Previously a date would inspect as (using the NRF calendar)~d[2019-W01-1]NRF. It now inspects as~d[2019-W01-1 NRF]. The same approach is used for all calendars. See the examples inCldr.Calendar.Sigils. This change is applicable to Elixir 1.10 and later.The calendar configuration option
:min_dayshas been renamed:min_days_in_first_week. The configuration option:dayhas been renamed to:day_of_weekand the option:monthhas been renamed to:month_of_year. An exception will be raised if existing calendars are not updated.An exception will be raised if a calendar is configured with an unknown option.
Enhancements
Implements
inspect_date/4,inspect_datetime/11,inspect_naive_datetime/8andinspect_time/5for allCldr.Calendarcalendars. This implementation supports the revisedInspectprotocol implementation forDate,Time,DateTimeandNaiveDateTimestructs. The purpose of that change is to allow customer calendars to be inspected. This change is applicable to Elixir 1.10 and later.Adds
Cldr.Calendar.week_of_month/1andCldr.Calendarcallbackweek_of_month/4to return the week of a month. The weeks are calculated on the basis of the calendar configuration. As a result, the week of the month, like the week of the year, may be in a different Gregorian year and month compared to the specified date.Adds
Cldr.Calendar.weeks_in_year/1to return the number of weeks in a year.Adds a calendar configuration where weeks start on the first day of the year. This configuration is valid only for
:monthbased calendars. The configuration optionday: :firsttriggers this behaviour. This configuration can result in the last week of the year being less than 7 days.Adds
Cldr.Calendar.inspect/2that can be used as an:inspect_funoption inInspect.Optsfor Elixir version 1.9. It will not be required for Elixir 1.10 and later since this commit introducesinspect_*callbacks forDate,Time,DateTimeandNaiveDateTime. An:inspect_funcan be configured inIExby:
iex> IEx.configure(inspect: [inspect_fun: &Cldr.Calendar.inspect/2])
:okBug Fixes
Ensure that
Cldr.Calendarcallbacks return aCalendar.ISOcalendar if called with one (either as part of a date or as a separate argument).Ensure the return calendar types of a an Interval are
Calendar.ISOis the date provided isCalendar.ISOFix
Cldr.Calendar.plus/4for:monthswhen the month wraps into the previous year(s)Fix
sigil_dto correctly parse ISO Week dates that have only a single digit day
Changelog for Cldr Calendars v0.9.0
This is the changelog for Cldr Calendars v0.9.0 released on June 9th, 2019. For older changelogs please consult the release tag on GitHub
Breaking changes
- Depends on Elixir 1.8 and above since it requires recent
Calendarfunctionality.
Changelog for Cldr Calendars v0.8.0
This is the changelog for Cldr v0.8.0 released on June 8th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
Adds option
:typetoCldr.Calendar.localize/3. This determines the format type to be localized. The valid types are:format(the default) or:stand_alone.Add
Cldr.Calendar.day_periods/2to support localization of the day periods of a timeAdd
Cldr.Calendar.default_calendar/0. ReturnsCldr.Calendar.GregorianAdd
Cldr.Calendar.default_cldr_calendar/0. Returns:gregorian
Changelog for Cldr Calendars v0.7.0
This is the changelog for Cldr Calendars v0.7.0 released on June 1st, 2019. For older changelogs please consult the release tag on GitHub
Breaking Changes
- Moved
year/1,quarter/1,month/1,week/1andday/1to a new moduleCldr.Calendar.Interval
Enhancements
Adds
Cldr.Calendar.Interval.compare/2to compare two intervals (date ranges) using Allen's Interval Algebra taxonomy.Defaults the calendar to
Cldr.Calendar.GregorianforCldr.Calendar.Interval.year/2,Cldr.Calendar.Interval.quarter/3,Cldr.Calendar.Interval.month/3,Cldr.Calendar.Interval.week/3andCldr.Calendar.Interval.day/3
Changelog for Cldr Calendars v0.6.0
This is the changelog for Cldr Calendars v0.6.0 released on April 28th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
- Remove the need for nimble_csv as a dependency
Changelog for Cldr Calendars v0.5.0
This is the changelog for Cldr Calendars v0.5.0 released on April 21th, 2019. For older changelogs please consult the release tag on GitHub
Breaking changes
Cldr.Calendar.localize/3for:days_of_weeknow returns a list of 2-tuples that are of the format{day_of_week, day_name}.
Enhancements
- Add
Cldr.Calendar.localize/6which localises numbers as part of a date without parameter checking. This is considered a private implementation for now.
Changelog for Cldr Calendars v0.4.1
This is the changelog for Cldr Calendars v0.4.1 released on April 19th, 2019. For older changelogs please consult the release tag on GitHub
Bug Fixes
- Fix calculation of
days_in_monthfor the last month in long year of a week-based calendar
Changelog for Cldr Calendars v0.4.0
This is the changelog for Cldr Calendars v0.4.0 released on April 19th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
Adds
Cldr.Calendar.interval_stream/3which returns a stream function that when enumerated generates a list of dates with a specified precision of either:years,:quarters,:months,:weeksor:days. This function has the same arguments and generates the same results asCldr.Calendar.interval/3except it generates the results lazily.Adds
:days_of_weekoption toCldr.Calendar.localize/3which returns a list of the localized names of the days of the week in calendar order.Adds
calendar_base/0to identify whether the calendar is week or month based.
Bug Fixes
- Fix
Cldr.Calendar.day_of_week/1for week-based calendars
Changelog for Cldr Calendars v0.3.0
This is the changelog for Cldr Calendars v0.3.0 released on April 16th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
- Adds
Cldr.Calendar.interval/3which generates an enumerable list of dates with a specified precision of either:years,:quarters,:months,:weeksor:days.
Examples:
iex> import Cldr.Calendar.Sigils
Cldr.Calendar.Sigils
iex> d = ~d[2019-01-31]
%Date{calendar: Cldr.Calendar.Gregorian, day: 31, month: 1, year: 2019}
iex> d2 = ~d[2019-05-31]
%Date{calendar: Cldr.Calendar.Gregorian, day: 31, month: 5, year: 2019}
iex> Cldr.Calendar.interval d, 3, :months
[
%Date{calendar: Cldr.Calendar.Gregorian, day: 28, month: 2, year: 2019},
%Date{calendar: Cldr.Calendar.Gregorian, day: 31, month: 3, year: 2019},
%Date{calendar: Cldr.Calendar.Gregorian, day: 30, month: 4, year: 2019}
]
iex> Cldr.Calendar.interval d, d2, :months
[
%Date{calendar: Cldr.Calendar.Gregorian, day: 31, month: 1, year: 2019},
%Date{calendar: Cldr.Calendar.Gregorian, day: 28, month: 2, year: 2019},
%Date{calendar: Cldr.Calendar.Gregorian, day: 31, month: 3, year: 2019},
%Date{calendar: Cldr.Calendar.Gregorian, day: 30, month: 4, year: 2019},
%Date{calendar: Cldr.Calendar.Gregorian, day: 31, month: 5, year: 2019}
]Changelog for Cldr Calendars v0.2.0
This is the changelog for Cldr Calendars v0.2.0 released on April 14th, 2019. For older changelogs please consult the release tag on GitHub
Breaking Changes
All calendars now return
{year, month, day}tuples fromdate_from_iso_days/1. Previously in some cases they returned aDate.tfirst_day_of_year/1andlast_day_of_year/1,first_gregorian_day_of_year/1andlast_gregorian_day_of_year/1now all return aDate.tor an error tuple. Previously the returned result types were inconsistent.Remove
first_gregorian_day_of_year/1andlast_gregorian_day_of_year/1fromCldr.Calendarcallbacks.
Enhancements
- Adds
Cldr.Calendar.Julianimplementing the Julian calendar. This calendar does not implementweek/2,week_of_year/3oriso_week_of_year/3.
Bug Fixes
- Fixes calculating negative offsets for months in a week-based calendar. Thanks to @bglusman. Closes #2.
Changelog for Cldr Calendars v0.1.0
This is the changelog for Cldr Calendars v0.1.0 released on April 5th, 2019. For older changelogs please consult the release tag on GitHub
Enhancements
- Initial release. See the README for a description of this project.