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