%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
// © 2016 and later: Unicode, Inc. and others. // License & terms of use: http://www.unicode.org/copyright.html /* ******************************************************************************* * Copyright (C) 2016, International Business Machines * Corporation and others. All Rights Reserved. ******************************************************************************* * dayperiodrules.h * * created on: 2016-01-20 * created by: kazede */ #ifndef DAYPERIODRULES_H #define DAYPERIODRULES_H #include "unicode/locid.h" #include "unicode/unistr.h" #include "unicode/uobject.h" #include "unicode/utypes.h" #include "resource.h" #include "uhash.h" U_NAMESPACE_BEGIN struct DayPeriodRulesDataSink; class DayPeriodRules : public UMemory { friend struct DayPeriodRulesDataSink; public: enum DayPeriod { DAYPERIOD_UNKNOWN = -1, DAYPERIOD_MIDNIGHT, DAYPERIOD_NOON, DAYPERIOD_MORNING1, DAYPERIOD_AFTERNOON1, DAYPERIOD_EVENING1, DAYPERIOD_NIGHT1, DAYPERIOD_MORNING2, DAYPERIOD_AFTERNOON2, DAYPERIOD_EVENING2, DAYPERIOD_NIGHT2, DAYPERIOD_AM, DAYPERIOD_PM }; static const DayPeriodRules *getInstance(const Locale &locale, UErrorCode &errorCode); UBool hasMidnight() const { return fHasMidnight; } UBool hasNoon() const { return fHasNoon; } DayPeriod getDayPeriodForHour(int32_t hour) const { return fDayPeriodForHour[hour]; } // Returns the center of dayPeriod. Half hours are indicated with a .5 . double getMidPointForDayPeriod(DayPeriod dayPeriod, UErrorCode &errorCode) const; private: DayPeriodRules(); // Translates "morning1" to DAYPERIOD_MORNING1, for example. static DayPeriod getDayPeriodFromString(const char *type_str); static void U_CALLCONV load(UErrorCode &errorCode); // Sets period type for all hours in [startHour, limitHour). void add(int32_t startHour, int32_t limitHour, DayPeriod period); // Returns true if for all i, DayPeriodForHour[i] has a type other than UNKNOWN. // Values of HasNoon and HasMidnight do not affect the return value. UBool allHoursAreSet(); // Returns the hour that starts dayPeriod. Returns 0 for MIDNIGHT and 12 for NOON. int32_t getStartHourForDayPeriod(DayPeriod dayPeriod, UErrorCode &errorCode) const; // Returns the hour that ends dayPeriod, i.e. that starts the next period. // E.g. if fDayPeriodForHour[13] thru [16] are AFTERNOON1, then this function returns 17 if // queried with AFTERNOON1. // Returns 0 for MIDNIGHT and 12 for NOON. int32_t getEndHourForDayPeriod(DayPeriod dayPeriod, UErrorCode &errorCode) const; UBool fHasMidnight; UBool fHasNoon; DayPeriod fDayPeriodForHour[24]; }; U_NAMESPACE_END #endif /* DAYPERIODRULES_H */