icu_calendar/calendar.rs
1// This file is part of ICU4X. For terms of use, please see the file
2// called LICENSE at the top level of the ICU4X source tree
3// (online at: https://github.com/unicode-org/icu4x/blob/main/LICENSE ).
4
5use crate::any_calendar::AnyCalendarKind;
6use crate::{types, CalendarError, Date, DateDuration, DateDurationUnit, Iso};
7use core::fmt;
8
9/// A calendar implementation
10///
11/// Only implementors of [`Calendar`] should care about these methods, in general users of
12/// these calendars should use the methods on [`Date`] instead.
13///
14/// Individual [`Calendar`] implementations may have inherent utility methods
15/// allowing for direct construction, etc.
16///
17/// For ICU4X 1.0, implementing this trait or calling methods directly is considered
18/// unstable and prone to change, especially for `offset_date()` and `until()`.
19pub trait Calendar {
20 /// The internal type used to represent dates
21 type DateInner: PartialEq + Eq + Clone + fmt::Debug;
22 /// Construct a date from era/month codes and fields
23 fn date_from_codes(
24 &self,
25 era: types::Era,
26 year: i32,
27 month_code: types::MonthCode,
28 day: u8,
29 ) -> Result<Self::DateInner, CalendarError>;
30 /// Construct the date from an ISO date
31 fn date_from_iso(&self, iso: Date<Iso>) -> Self::DateInner;
32 /// Obtain an ISO date from this date
33 fn date_to_iso(&self, date: &Self::DateInner) -> Date<Iso>;
34 // fn validate_date(&self, e: Era, y: Year, m: MonthCode, d: Day) -> bool;
35 // // similar validators for YearMonth, etc
36
37 // fn is_leap<A: AsCalendar<Calendar = Self>>(&self, date: &Date<A>) -> bool;
38 /// Count the number of months in a given year, specified by providing a date
39 /// from that year
40 fn months_in_year(&self, date: &Self::DateInner) -> u8;
41 /// Count the number of days in a given year, specified by providing a date
42 /// from that year
43 fn days_in_year(&self, date: &Self::DateInner) -> u16;
44 /// Count the number of days in a given month, specified by providing a date
45 /// from that year/month
46 fn days_in_month(&self, date: &Self::DateInner) -> u8;
47 /// Calculate the day of the week and return it
48 fn day_of_week(&self, date: &Self::DateInner) -> types::IsoWeekday {
49 self.date_to_iso(date).day_of_week()
50 }
51 // fn week_of_year(&self, date: &Self::DateInner) -> u8;
52
53 #[doc(hidden)] // unstable
54 /// Add `offset` to `date`
55 fn offset_date(&self, date: &mut Self::DateInner, offset: DateDuration<Self>);
56
57 #[doc(hidden)] // unstable
58 /// Calculate `date2 - date` as a duration
59 ///
60 /// `calendar2` is the calendar object associated with `date2`. In case the specific calendar objects
61 /// differ on data, the data for the first calendar is used, and `date2` may be converted if necessary.
62 fn until(
63 &self,
64 date1: &Self::DateInner,
65 date2: &Self::DateInner,
66 calendar2: &Self,
67 largest_unit: DateDurationUnit,
68 smallest_unit: DateDurationUnit,
69 ) -> DateDuration<Self>;
70
71 /// Obtain a name for the calendar for debug printing
72 fn debug_name(&self) -> &'static str;
73 // fn since(&self, from: &Date<Self>, to: &Date<Self>) -> Duration<Self>, Error;
74
75 /// The calendar-specific year represented by `date`
76 fn year(&self, date: &Self::DateInner) -> types::FormattableYear;
77
78 /// Calculate if a date is in a leap year
79 fn is_in_leap_year(&self, date: &Self::DateInner) -> bool;
80
81 /// The calendar-specific month represented by `date`
82 fn month(&self, date: &Self::DateInner) -> types::FormattableMonth;
83
84 /// The calendar-specific day-of-month represented by `date`
85 fn day_of_month(&self, date: &Self::DateInner) -> types::DayOfMonth;
86
87 /// Information of the day of the year
88 fn day_of_year_info(&self, date: &Self::DateInner) -> types::DayOfYearInfo;
89
90 /// The [`AnyCalendarKind`] corresponding to this calendar,
91 /// if one exists. Implementors outside of `icu::calendar` should return `None`
92 fn any_calendar_kind(&self) -> Option<AnyCalendarKind> {
93 None
94 }
95}