]> git.saurik.com Git - apple/icu.git/blob - icuSources/i18n/dayperiodrules.h
ICU-64243.0.1.tar.gz
[apple/icu.git] / icuSources / i18n / dayperiodrules.h
1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4 *******************************************************************************
5 * Copyright (C) 2016, International Business Machines
6 * Corporation and others. All Rights Reserved.
7 *******************************************************************************
8 * dayperiodrules.h
9 *
10 * created on: 2016-01-20
11 * created by: kazede
12 */
13
14 #ifndef DAYPERIODRULES_H
15 #define DAYPERIODRULES_H
16
17 #include "unicode/locid.h"
18 #include "unicode/unistr.h"
19 #include "unicode/uobject.h"
20 #include "unicode/utypes.h"
21 #include "resource.h"
22 #include "uhash.h"
23
24
25
26 U_NAMESPACE_BEGIN
27
28 struct DayPeriodRulesDataSink;
29
30 class DayPeriodRules : public UMemory {
31 friend struct DayPeriodRulesDataSink;
32 public:
33 enum DayPeriod {
34 DAYPERIOD_UNKNOWN = -1,
35 DAYPERIOD_MIDNIGHT,
36 DAYPERIOD_NOON,
37 DAYPERIOD_MORNING1,
38 DAYPERIOD_AFTERNOON1,
39 DAYPERIOD_EVENING1,
40 DAYPERIOD_NIGHT1,
41 DAYPERIOD_MORNING2,
42 DAYPERIOD_AFTERNOON2,
43 DAYPERIOD_EVENING2,
44 DAYPERIOD_NIGHT2,
45 DAYPERIOD_AM,
46 DAYPERIOD_PM
47 };
48
49 static const DayPeriodRules *getInstance(const Locale &locale, UErrorCode &errorCode);
50
51 UBool hasMidnight() const { return fHasMidnight; }
52 UBool hasNoon() const { return fHasNoon; }
53 DayPeriod getDayPeriodForHour(int32_t hour) const { return fDayPeriodForHour[hour]; }
54
55 // Returns the center of dayPeriod. Half hours are indicated with a .5 .
56 double getMidPointForDayPeriod(DayPeriod dayPeriod, UErrorCode &errorCode) const;
57
58 private:
59 DayPeriodRules();
60
61 // Translates "morning1" to DAYPERIOD_MORNING1, for example.
62 static DayPeriod getDayPeriodFromString(const char *type_str);
63
64 static void U_CALLCONV load(UErrorCode &errorCode);
65
66 // Sets period type for all hours in [startHour, limitHour).
67 void add(int32_t startHour, int32_t limitHour, DayPeriod period);
68
69 // Returns TRUE if for all i, DayPeriodForHour[i] has a type other than UNKNOWN.
70 // Values of HasNoon and HasMidnight do not affect the return value.
71 UBool allHoursAreSet();
72
73 // Returns the hour that starts dayPeriod. Returns 0 for MIDNIGHT and 12 for NOON.
74 int32_t getStartHourForDayPeriod(DayPeriod dayPeriod, UErrorCode &errorCode) const;
75
76 // Returns the hour that ends dayPeriod, i.e. that starts the next period.
77 // E.g. if fDayPeriodForHour[13] thru [16] are AFTERNOON1, then this function returns 17 if
78 // queried with AFTERNOON1.
79 // Returns 0 for MIDNIGHT and 12 for NOON.
80 int32_t getEndHourForDayPeriod(DayPeriod dayPeriod, UErrorCode &errorCode) const;
81
82 UBool fHasMidnight;
83 UBool fHasNoon;
84 DayPeriod fDayPeriodForHour[24];
85 };
86
87 U_NAMESPACE_END
88
89 #endif /* DAYPERIODRULES_H */