1 // Copyright (C) 2016 and later: Unicode, Inc. and others. 2 // License & terms of use: http://www.unicode.org/copyright.html 3 /* 4 ******************************************************************************* 5 * Copyright (C) 2007-2008, International Business Machines Corporation and * 6 * others. All Rights Reserved. * 7 ******************************************************************************* 8 */ 9 #ifndef DTRULE_H 10 #define DTRULE_H 11 12 #include "unicode/utypes.h" 13 14 /** 15 * \file 16 * \brief C++ API: Rule for specifying date and time in an year 17 */ 18 19 #if !UCONFIG_NO_FORMATTING 20 21 #include "unicode/uobject.h" 22 23 U_NAMESPACE_BEGIN 24 /** 25 * <code>DateTimeRule</code> is a class representing a time in a year by 26 * a rule specified by month, day of month, day of week and 27 * time in the day. 28 * 29 * @stable ICU 3.8 30 */ 31 class U_I18N_API DateTimeRule : public UObject { 32 public: 33 34 /** 35 * Date rule type constants. 36 * @stable ICU 3.8 37 */ 38 enum DateRuleType { 39 DOM = 0, /**< The exact day of month, 40 for example, March 11. */ 41 DOW, /**< The Nth occurence of the day of week, 42 for example, 2nd Sunday in March. */ 43 DOW_GEQ_DOM, /**< The first occurence of the day of week on or after the day of monnth, 44 for example, first Sunday on or after March 8. */ 45 DOW_LEQ_DOM /**< The last occurence of the day of week on or before the day of month, 46 for example, first Sunday on or before March 14. */ 47 }; 48 49 /** 50 * Time rule type constants. 51 * @stable ICU 3.8 52 */ 53 enum TimeRuleType { 54 WALL_TIME = 0, /**< The local wall clock time */ 55 STANDARD_TIME, /**< The local standard time */ 56 UTC_TIME /**< The UTC time */ 57 }; 58 59 /** 60 * Constructs a <code>DateTimeRule</code> by the day of month and 61 * the time rule. The date rule type for an instance created by 62 * this constructor is <code>DOM</code>. 63 * 64 * @param month The rule month, for example, <code>Calendar::JANUARY</code> 65 * @param dayOfMonth The day of month, 1-based. 66 * @param millisInDay The milliseconds in the rule date. 67 * @param timeType The time type, <code>WALL_TIME</code> or <code>STANDARD_TIME</code> 68 * or <code>UTC_TIME</code>. 69 * @stable ICU 3.8 70 */ 71 DateTimeRule(int32_t month, int32_t dayOfMonth, 72 int32_t millisInDay, TimeRuleType timeType); 73 74 /** 75 * Constructs a <code>DateTimeRule</code> by the day of week and its oridinal 76 * number and the time rule. The date rule type for an instance created 77 * by this constructor is <code>DOW</code>. 78 * 79 * @param month The rule month, for example, <code>Calendar::JANUARY</code>. 80 * @param weekInMonth The ordinal number of the day of week. Negative number 81 * may be used for specifying a rule date counted from the 82 * end of the rule month. 83 * @param dayOfWeek The day of week, for example, <code>Calendar::SUNDAY</code>. 84 * @param millisInDay The milliseconds in the rule date. 85 * @param timeType The time type, <code>WALL_TIME</code> or <code>STANDARD_TIME</code> 86 * or <code>UTC_TIME</code>. 87 * @stable ICU 3.8 88 */ 89 DateTimeRule(int32_t month, int32_t weekInMonth, int32_t dayOfWeek, 90 int32_t millisInDay, TimeRuleType timeType); 91 92 /** 93 * Constructs a <code>DateTimeRule</code> by the first/last day of week 94 * on or after/before the day of month and the time rule. The date rule 95 * type for an instance created by this constructor is either 96 * <code>DOM_GEQ_DOM</code> or <code>DOM_LEQ_DOM</code>. 97 * 98 * @param month The rule month, for example, <code>Calendar::JANUARY</code> 99 * @param dayOfMonth The day of month, 1-based. 100 * @param dayOfWeek The day of week, for example, <code>Calendar::SUNDAY</code>. 101 * @param after true if the rule date is on or after the day of month. 102 * @param millisInDay The milliseconds in the rule date. 103 * @param timeType The time type, <code>WALL_TIME</code> or <code>STANDARD_TIME</code> 104 * or <code>UTC_TIME</code>. 105 * @stable ICU 3.8 106 */ 107 DateTimeRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek, UBool after, 108 int32_t millisInDay, TimeRuleType timeType); 109 110 /** 111 * Copy constructor. 112 * @param source The DateTimeRule object to be copied. 113 * @stable ICU 3.8 114 */ 115 DateTimeRule(const DateTimeRule& source); 116 117 /** 118 * Destructor. 119 * @stable ICU 3.8 120 */ 121 ~DateTimeRule(); 122 123 /** 124 * Clone this DateTimeRule object polymorphically. The caller owns the result and 125 * should delete it when done. 126 * @return A copy of the object. 127 * @stable ICU 3.8 128 */ 129 DateTimeRule* clone(void) const; 130 131 /** 132 * Assignment operator. 133 * @param right The object to be copied. 134 * @stable ICU 3.8 135 */ 136 DateTimeRule& operator=(const DateTimeRule& right); 137 138 /** 139 * Return true if the given DateTimeRule objects are semantically equal. Objects 140 * of different subclasses are considered unequal. 141 * @param that The object to be compared with. 142 * @return true if the given DateTimeRule objects are semantically equal. 143 * @stable ICU 3.8 144 */ 145 UBool operator==(const DateTimeRule& that) const; 146 147 /** 148 * Return true if the given DateTimeRule objects are semantically unequal. Objects 149 * of different subclasses are considered unequal. 150 * @param that The object to be compared with. 151 * @return true if the given DateTimeRule objects are semantically unequal. 152 * @stable ICU 3.8 153 */ 154 UBool operator!=(const DateTimeRule& that) const; 155 156 /** 157 * Gets the date rule type, such as <code>DOM</code> 158 * @return The date rule type. 159 * @stable ICU 3.8 160 */ 161 DateRuleType getDateRuleType(void) const; 162 163 /** 164 * Gets the time rule type 165 * @return The time rule type, either <code>WALL_TIME</code> or <code>STANDARD_TIME</code> 166 * or <code>UTC_TIME</code>. 167 * @stable ICU 3.8 168 */ 169 TimeRuleType getTimeRuleType(void) const; 170 171 /** 172 * Gets the rule month. 173 * @return The rule month. 174 * @stable ICU 3.8 175 */ 176 int32_t getRuleMonth(void) const; 177 178 /** 179 * Gets the rule day of month. When the date rule type 180 * is <code>DOW</code>, the value is always 0. 181 * @return The rule day of month 182 * @stable ICU 3.8 183 */ 184 int32_t getRuleDayOfMonth(void) const; 185 186 /** 187 * Gets the rule day of week. When the date rule type 188 * is <code>DOM</code>, the value is always 0. 189 * @return The rule day of week. 190 * @stable ICU 3.8 191 */ 192 int32_t getRuleDayOfWeek(void) const; 193 194 /** 195 * Gets the ordinal number of the occurence of the day of week 196 * in the month. When the date rule type is not <code>DOW</code>, 197 * the value is always 0. 198 * @return The rule day of week ordinal number in the month. 199 * @stable ICU 3.8 200 */ 201 int32_t getRuleWeekInMonth(void) const; 202 203 /** 204 * Gets the rule time in the rule day. 205 * @return The time in the rule day in milliseconds. 206 * @stable ICU 3.8 207 */ 208 int32_t getRuleMillisInDay(void) const; 209 210 private: 211 int32_t fMonth; 212 int32_t fDayOfMonth; 213 int32_t fDayOfWeek; 214 int32_t fWeekInMonth; 215 int32_t fMillisInDay; 216 DateRuleType fDateRuleType; 217 TimeRuleType fTimeRuleType; 218 219 public: 220 /** 221 * Return the class ID for this class. This is useful only for comparing to 222 * a return value from getDynamicClassID(). For example: 223 * <pre> 224 * . Base* polymorphic_pointer = createPolymorphicObject(); 225 * . if (polymorphic_pointer->getDynamicClassID() == 226 * . erived::getStaticClassID()) ... 227 * </pre> 228 * @return The class ID for all objects of this class. 229 * @stable ICU 3.8 230 */ 231 static UClassID U_EXPORT2 getStaticClassID(void); 232 233 /** 234 * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This 235 * method is to implement a simple version of RTTI, since not all C++ 236 * compilers support genuine RTTI. Polymorphic operator==() and clone() 237 * methods call this method. 238 * 239 * @return The class ID for this object. All objects of a 240 * given class have the same class ID. Objects of 241 * other classes have different class IDs. 242 * @stable ICU 3.8 243 */ 244 virtual UClassID getDynamicClassID(void) const; 245 }; 246 247 U_NAMESPACE_END 248 249 #endif /* #if !UCONFIG_NO_FORMATTING */ 250 251 #endif // DTRULE_H 252 //eof 253