xref: /aosp_15_r20/external/cronet/base/i18n/time_formatting.h (revision 6777b5387eb2ff775bb5750e3f5d96f37fb7352b)
1*6777b538SAndroid Build Coastguard Worker // Copyright 2011 The Chromium Authors
2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be
3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file.
4*6777b538SAndroid Build Coastguard Worker 
5*6777b538SAndroid Build Coastguard Worker // Basic time formatting methods.  Most methods format based on the current
6*6777b538SAndroid Build Coastguard Worker // locale. *TimeFormatWithPattern() are special; see comments there.
7*6777b538SAndroid Build Coastguard Worker 
8*6777b538SAndroid Build Coastguard Worker #ifndef BASE_I18N_TIME_FORMATTING_H_
9*6777b538SAndroid Build Coastguard Worker #define BASE_I18N_TIME_FORMATTING_H_
10*6777b538SAndroid Build Coastguard Worker 
11*6777b538SAndroid Build Coastguard Worker #include <string>
12*6777b538SAndroid Build Coastguard Worker #include <string_view>
13*6777b538SAndroid Build Coastguard Worker 
14*6777b538SAndroid Build Coastguard Worker #include "base/i18n/base_i18n_export.h"
15*6777b538SAndroid Build Coastguard Worker #include "build/build_config.h"
16*6777b538SAndroid Build Coastguard Worker #include "build/chromeos_buildflags.h"
17*6777b538SAndroid Build Coastguard Worker #include "third_party/icu/source/common/unicode/uversion.h"
18*6777b538SAndroid Build Coastguard Worker 
19*6777b538SAndroid Build Coastguard Worker U_NAMESPACE_BEGIN
20*6777b538SAndroid Build Coastguard Worker class TimeZone;
21*6777b538SAndroid Build Coastguard Worker U_NAMESPACE_END
22*6777b538SAndroid Build Coastguard Worker 
23*6777b538SAndroid Build Coastguard Worker namespace base {
24*6777b538SAndroid Build Coastguard Worker 
25*6777b538SAndroid Build Coastguard Worker class Time;
26*6777b538SAndroid Build Coastguard Worker class TimeDelta;
27*6777b538SAndroid Build Coastguard Worker 
28*6777b538SAndroid Build Coastguard Worker // Argument type used to specify the hour clock type.
29*6777b538SAndroid Build Coastguard Worker enum HourClockType {
30*6777b538SAndroid Build Coastguard Worker   k12HourClock,  // Uses 1-12. e.g., "3:07 PM"
31*6777b538SAndroid Build Coastguard Worker   k24HourClock,  // Uses 0-23. e.g., "15:07"
32*6777b538SAndroid Build Coastguard Worker };
33*6777b538SAndroid Build Coastguard Worker 
34*6777b538SAndroid Build Coastguard Worker // Argument type used to specify whether or not to include AM/PM sign.
35*6777b538SAndroid Build Coastguard Worker enum AmPmClockType {
36*6777b538SAndroid Build Coastguard Worker   kDropAmPm,  // Drops AM/PM sign. e.g., "3:07"
37*6777b538SAndroid Build Coastguard Worker   kKeepAmPm,  // Keeps AM/PM sign. e.g., "3:07 PM"
38*6777b538SAndroid Build Coastguard Worker };
39*6777b538SAndroid Build Coastguard Worker 
40*6777b538SAndroid Build Coastguard Worker // Should match UMeasureFormatWidth in measfmt.h; replicated here to avoid
41*6777b538SAndroid Build Coastguard Worker // requiring third_party/icu dependencies with this file.
42*6777b538SAndroid Build Coastguard Worker enum DurationFormatWidth {
43*6777b538SAndroid Build Coastguard Worker   DURATION_WIDTH_WIDE,    // "3 hours, 7 minutes"
44*6777b538SAndroid Build Coastguard Worker   DURATION_WIDTH_SHORT,   // "3 hr, 7 min"
45*6777b538SAndroid Build Coastguard Worker   DURATION_WIDTH_NARROW,  // "3h 7m"
46*6777b538SAndroid Build Coastguard Worker   DURATION_WIDTH_NUMERIC  // "3:07"
47*6777b538SAndroid Build Coastguard Worker };
48*6777b538SAndroid Build Coastguard Worker 
49*6777b538SAndroid Build Coastguard Worker // Date formats from third_party/icu/source/i18n/unicode/udat.h. Add more as
50*6777b538SAndroid Build Coastguard Worker // necessary.
51*6777b538SAndroid Build Coastguard Worker enum DateFormat {
52*6777b538SAndroid Build Coastguard Worker   // November 2007
53*6777b538SAndroid Build Coastguard Worker   DATE_FORMAT_YEAR_MONTH,
54*6777b538SAndroid Build Coastguard Worker   // Tuesday, 7 November
55*6777b538SAndroid Build Coastguard Worker   DATE_FORMAT_MONTH_WEEKDAY_DAY,
56*6777b538SAndroid Build Coastguard Worker };
57*6777b538SAndroid Build Coastguard Worker 
58*6777b538SAndroid Build Coastguard Worker // Returns the time of day, e.g., "3:07 PM".
59*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatTimeOfDay(const Time& time);
60*6777b538SAndroid Build Coastguard Worker 
61*6777b538SAndroid Build Coastguard Worker // Returns the time of day in 24-hour clock format with millisecond accuracy,
62*6777b538SAndroid Build Coastguard Worker // e.g., "15:07:30.568"
63*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatTimeOfDayWithMilliseconds(
64*6777b538SAndroid Build Coastguard Worker     const Time& time);
65*6777b538SAndroid Build Coastguard Worker 
66*6777b538SAndroid Build Coastguard Worker // Returns the time of day in the specified hour clock type. e.g.
67*6777b538SAndroid Build Coastguard Worker // "3:07 PM" (type == k12HourClock, ampm == kKeepAmPm).
68*6777b538SAndroid Build Coastguard Worker // "3:07"    (type == k12HourClock, ampm == kDropAmPm).
69*6777b538SAndroid Build Coastguard Worker // "15:07"   (type == k24HourClock).
70*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatTimeOfDayWithHourClockType(
71*6777b538SAndroid Build Coastguard Worker     const Time& time,
72*6777b538SAndroid Build Coastguard Worker     HourClockType type,
73*6777b538SAndroid Build Coastguard Worker     AmPmClockType ampm);
74*6777b538SAndroid Build Coastguard Worker 
75*6777b538SAndroid Build Coastguard Worker // Returns a shortened date, e.g. "Nov 7, 2007"
76*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatShortDate(const Time& time);
77*6777b538SAndroid Build Coastguard Worker 
78*6777b538SAndroid Build Coastguard Worker // Returns a numeric date such as 12/13/52.
79*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatShortDateNumeric(const Time& time);
80*6777b538SAndroid Build Coastguard Worker 
81*6777b538SAndroid Build Coastguard Worker // Returns a numeric date and time such as "12/13/52 2:44:30 PM".
82*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatShortDateAndTime(const Time& time);
83*6777b538SAndroid Build Coastguard Worker 
84*6777b538SAndroid Build Coastguard Worker #if BUILDFLAG(IS_CHROMEOS_ASH)
85*6777b538SAndroid Build Coastguard Worker // Returns a month and year, e.g. "November 2007" for the specified time zone.
86*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatMonthAndYearForTimeZone(
87*6777b538SAndroid Build Coastguard Worker     const Time& time,
88*6777b538SAndroid Build Coastguard Worker     const icu::TimeZone* time_zone);
89*6777b538SAndroid Build Coastguard Worker #endif  // BUILDFLAG(IS_CHROMEOS_ASH)
90*6777b538SAndroid Build Coastguard Worker 
91*6777b538SAndroid Build Coastguard Worker // Returns a month and year, e.g. "November 2007"
92*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatMonthAndYear(const Time& time);
93*6777b538SAndroid Build Coastguard Worker 
94*6777b538SAndroid Build Coastguard Worker // Returns a numeric date and time with time zone such as
95*6777b538SAndroid Build Coastguard Worker // "12/13/52 2:44:30 PM PST".
96*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatShortDateAndTimeWithTimeZone(
97*6777b538SAndroid Build Coastguard Worker     const Time& time);
98*6777b538SAndroid Build Coastguard Worker 
99*6777b538SAndroid Build Coastguard Worker // Formats a time in a friendly sentence format, e.g.
100*6777b538SAndroid Build Coastguard Worker // "Monday, March 6, 2008 2:44:30 PM".
101*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatFriendlyDateAndTime(const Time& time);
102*6777b538SAndroid Build Coastguard Worker 
103*6777b538SAndroid Build Coastguard Worker // Formats a time in a friendly sentence format, e.g.
104*6777b538SAndroid Build Coastguard Worker // "Monday, March 6, 2008".
105*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string TimeFormatFriendlyDate(const Time& time);
106*6777b538SAndroid Build Coastguard Worker 
107*6777b538SAndroid Build Coastguard Worker // Formats a time using a pattern to produce output for different locales when
108*6777b538SAndroid Build Coastguard Worker // an unusual time format is needed, e.g. "Feb. 2, 18:00". See
109*6777b538SAndroid Build Coastguard Worker // https://unicode-org.github.io/icu/userguide/format_parse/datetime/#datetime-format-syntax
110*6777b538SAndroid Build Coastguard Worker // for pattern details.
111*6777b538SAndroid Build Coastguard Worker //
112*6777b538SAndroid Build Coastguard Worker // Use this version when you want to display the resulting string to the user.
113*6777b538SAndroid Build Coastguard Worker //
114*6777b538SAndroid Build Coastguard Worker // This localizes more than you might expect: it does not simply translate days
115*6777b538SAndroid Build Coastguard Worker // of the week, etc., and then feed them into the provided pattern. The pattern
116*6777b538SAndroid Build Coastguard Worker // will also be run through a pattern localizer that will add spacing,
117*6777b538SAndroid Build Coastguard Worker // delimiters, etc. appropriate for the current locale. If you don't want this,
118*6777b538SAndroid Build Coastguard Worker // look at `UnlocalizedTimeFormatWithPattern()` below. If you want translation
119*6777b538SAndroid Build Coastguard Worker // but don't want to adjust the pattern as well, talk to base/ OWNERS about your
120*6777b538SAndroid Build Coastguard Worker // use case.
121*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string LocalizedTimeFormatWithPattern(
122*6777b538SAndroid Build Coastguard Worker     const Time& time,
123*6777b538SAndroid Build Coastguard Worker     std::string_view pattern);
124*6777b538SAndroid Build Coastguard Worker 
125*6777b538SAndroid Build Coastguard Worker // Formats a time using a pattern to produce en-US-like output, e.g. "Feb. 2,
126*6777b538SAndroid Build Coastguard Worker // 18:00". See
127*6777b538SAndroid Build Coastguard Worker // https://unicode-org.github.io/icu/userguide/format_parse/datetime/#datetime-format-syntax
128*6777b538SAndroid Build Coastguard Worker // for pattern details. NOTE: While ICU only supports millisecond precision
129*6777b538SAndroid Build Coastguard Worker // (fractional second patterns "SSS..." will be filled with zeroes after the
130*6777b538SAndroid Build Coastguard Worker // third 'S'), this supports microsecond precision (up to six 'S's may become
131*6777b538SAndroid Build Coastguard Worker // non-zero values), since some callers need that.
132*6777b538SAndroid Build Coastguard Worker //
133*6777b538SAndroid Build Coastguard Worker // `time_zone` can be set to a desired time zone (e.g.
134*6777b538SAndroid Build Coastguard Worker // icu::TimeZone::getGMT()); if left as null, the local time zone will be used.
135*6777b538SAndroid Build Coastguard Worker //
136*6777b538SAndroid Build Coastguard Worker // Use this version when you want to control the output format precisely, e.g.
137*6777b538SAndroid Build Coastguard Worker // for logging or to format a string for consumption by some server.
138*6777b538SAndroid Build Coastguard Worker //
139*6777b538SAndroid Build Coastguard Worker // This always outputs in US English and does not change the provided pattern at
140*6777b538SAndroid Build Coastguard Worker // all before formatting. It returns a `std::string` instead of a
141*6777b538SAndroid Build Coastguard Worker // `std::u16string` under the assumption that it will not be used in UI.
142*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::string UnlocalizedTimeFormatWithPattern(
143*6777b538SAndroid Build Coastguard Worker     const Time& time,
144*6777b538SAndroid Build Coastguard Worker     std::string_view pattern,
145*6777b538SAndroid Build Coastguard Worker     const icu::TimeZone* time_zone = nullptr);
146*6777b538SAndroid Build Coastguard Worker 
147*6777b538SAndroid Build Coastguard Worker // Formats a time compliant to ISO 8601 in UTC, e.g. "2020-12-31T23:59:59.999Z".
148*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::string TimeFormatAsIso8601(const Time& time);
149*6777b538SAndroid Build Coastguard Worker 
150*6777b538SAndroid Build Coastguard Worker // Formats a time in the IMF-fixdate format defined by RFC 7231 (satisfying its
151*6777b538SAndroid Build Coastguard Worker // HTTP-date format), e.g. "Sun, 06 Nov 1994 08:49:37 GMT".
152*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::string TimeFormatHTTP(const Time& time);
153*6777b538SAndroid Build Coastguard Worker 
154*6777b538SAndroid Build Coastguard Worker // Formats a time duration of hours and minutes into various formats, e.g.,
155*6777b538SAndroid Build Coastguard Worker // "3:07" or "3 hours, 7 minutes", and returns true on success. See
156*6777b538SAndroid Build Coastguard Worker // DurationFormatWidth for details.
157*6777b538SAndroid Build Coastguard Worker [[nodiscard]] BASE_I18N_EXPORT bool TimeDurationFormat(
158*6777b538SAndroid Build Coastguard Worker     TimeDelta time,
159*6777b538SAndroid Build Coastguard Worker     DurationFormatWidth width,
160*6777b538SAndroid Build Coastguard Worker     std::u16string* out);
161*6777b538SAndroid Build Coastguard Worker 
162*6777b538SAndroid Build Coastguard Worker // Formats a time duration of hours, minutes and seconds into various formats,
163*6777b538SAndroid Build Coastguard Worker // e.g., "3:07:30" or "3 hours, 7 minutes, 30 seconds", and returns true on
164*6777b538SAndroid Build Coastguard Worker // success. See DurationFormatWidth for details.
165*6777b538SAndroid Build Coastguard Worker [[nodiscard]] BASE_I18N_EXPORT bool TimeDurationFormatWithSeconds(
166*6777b538SAndroid Build Coastguard Worker     TimeDelta time,
167*6777b538SAndroid Build Coastguard Worker     DurationFormatWidth width,
168*6777b538SAndroid Build Coastguard Worker     std::u16string* out);
169*6777b538SAndroid Build Coastguard Worker 
170*6777b538SAndroid Build Coastguard Worker // Formats a date interval into various formats, e.g. "2 December - 4 December"
171*6777b538SAndroid Build Coastguard Worker // or "March 2016 - December 2016". See DateFormat for details.
172*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT std::u16string DateIntervalFormat(const Time& begin_time,
173*6777b538SAndroid Build Coastguard Worker                                                    const Time& end_time,
174*6777b538SAndroid Build Coastguard Worker                                                    DateFormat format);
175*6777b538SAndroid Build Coastguard Worker 
176*6777b538SAndroid Build Coastguard Worker // Gets the hour clock type of the current locale. e.g.
177*6777b538SAndroid Build Coastguard Worker // k12HourClock (en-US).
178*6777b538SAndroid Build Coastguard Worker // k24HourClock (en-GB).
179*6777b538SAndroid Build Coastguard Worker BASE_I18N_EXPORT HourClockType GetHourClockType();
180*6777b538SAndroid Build Coastguard Worker 
181*6777b538SAndroid Build Coastguard Worker }  // namespace base
182*6777b538SAndroid Build Coastguard Worker 
183*6777b538SAndroid Build Coastguard Worker #endif  // BASE_I18N_TIME_FORMATTING_H_
184