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 TZRULE_H
10 #define TZRULE_H
11 
12 /**
13  * \file
14  * \brief C++ API: Time zone rule classes
15  */
16 
17 #include "unicode/utypes.h"
18 
19 #if !UCONFIG_NO_FORMATTING
20 
21 #include "unicode/uobject.h"
22 #include "unicode/unistr.h"
23 #include "unicode/dtrule.h"
24 
25 U_NAMESPACE_BEGIN
26 
27 /**
28  * <code>TimeZoneRule</code> is a class representing a rule for time zone.
29  * <code>TimeZoneRule</code> has a set of time zone attributes, such as zone name,
30  * raw offset (UTC offset for standard time) and daylight saving time offset.
31  *
32  * @stable ICU 3.8
33  */
34 class U_I18N_API TimeZoneRule : public UObject {
35 public:
36     /**
37      * Destructor.
38      * @stable ICU 3.8
39      */
40     virtual ~TimeZoneRule();
41 
42     /**
43      * Clone this TimeZoneRule object polymorphically. The caller owns the result and
44      * should delete it when done.
45      * @return  A copy of the object.
46      * @stable ICU 3.8
47      */
48     virtual TimeZoneRule* clone(void) const = 0;
49 
50     /**
51      * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
52      * of different subclasses are considered unequal.
53      * @param that  The object to be compared with.
54      * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
55      * @stable ICU 3.8
56      */
57     virtual UBool operator==(const TimeZoneRule& that) const;
58 
59     /**
60      * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
61      * of different subclasses are considered unequal.
62      * @param that  The object to be compared with.
63      * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
64      * @stable ICU 3.8
65      */
66     virtual UBool operator!=(const TimeZoneRule& that) const;
67 
68     /**
69      * Fills in "name" with the name of this time zone.
70      * @param name  Receives the name of this time zone.
71      * @return  A reference to "name"
72      * @stable ICU 3.8
73      */
74     UnicodeString& getName(UnicodeString& name) const;
75 
76     /**
77      * Gets the standard time offset.
78      * @return  The standard time offset from UTC in milliseconds.
79      * @stable ICU 3.8
80      */
81     int32_t getRawOffset(void) const;
82 
83     /**
84      * Gets the amount of daylight saving delta time from the standard time.
85      * @return  The amount of daylight saving offset used by this rule
86      *          in milliseconds.
87      * @stable ICU 3.8
88      */
89     int32_t getDSTSavings(void) const;
90 
91     /**
92      * Returns if this rule represents the same rule and offsets as another.
93      * When two <code>TimeZoneRule</code> objects differ only its names, this method
94      * returns true.
95      * @param other The <code>TimeZoneRule</code> object to be compared with.
96      * @return  true if the other <code>TimeZoneRule</code> is the same as this one.
97      * @stable ICU 3.8
98      */
99     virtual UBool isEquivalentTo(const TimeZoneRule& other) const;
100 
101     /**
102      * Gets the very first time when this rule takes effect.
103      * @param prevRawOffset     The standard time offset from UTC before this rule
104      *                          takes effect in milliseconds.
105      * @param prevDSTSavings    The amount of daylight saving offset from the
106      *                          standard time.
107      * @param result            Receives the very first time when this rule takes effect.
108      * @return  true if the start time is available.  When false is returned, output parameter
109      *          "result" is unchanged.
110      * @stable ICU 3.8
111      */
112     virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const = 0;
113 
114     /**
115      * Gets the final time when this rule takes effect.
116      * @param prevRawOffset     The standard time offset from UTC before this rule
117      *                          takes effect in milliseconds.
118      * @param prevDSTSavings    The amount of daylight saving offset from the
119      *                          standard time.
120      * @param result            Receives the final time when this rule takes effect.
121      * @return  true if the start time is available.  When false is returned, output parameter
122      *          "result" is unchanged.
123      * @stable ICU 3.8
124      */
125     virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const = 0;
126 
127     /**
128      * Gets the first time when this rule takes effect after the specified time.
129      * @param base              The first start time after this base time will be returned.
130      * @param prevRawOffset     The standard time offset from UTC before this rule
131      *                          takes effect in milliseconds.
132      * @param prevDSTSavings    The amount of daylight saving offset from the
133      *                          standard time.
134      * @param inclusive         Whether the base time is inclusive or not.
135      * @param result            Receives The first time when this rule takes effect after
136      *                          the specified base time.
137      * @return  true if the start time is available.  When false is returned, output parameter
138      *          "result" is unchanged.
139      * @stable ICU 3.8
140      */
141     virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
142         UBool inclusive, UDate& result) const = 0;
143 
144     /**
145      * Gets the most recent time when this rule takes effect before the specified time.
146      * @param base              The most recent time before this base time will be returned.
147      * @param prevRawOffset     The standard time offset from UTC before this rule
148      *                          takes effect in milliseconds.
149      * @param prevDSTSavings    The amount of daylight saving offset from the
150      *                          standard time.
151      * @param inclusive         Whether the base time is inclusive or not.
152      * @param result            Receives The most recent time when this rule takes effect before
153      *                          the specified base time.
154      * @return  true if the start time is available.  When false is returned, output parameter
155      *          "result" is unchanged.
156      * @stable ICU 3.8
157      */
158     virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
159         UBool inclusive, UDate& result) const = 0;
160 
161 protected:
162 
163     /**
164      * Constructs a <code>TimeZoneRule</code> with the name, the GMT offset of its
165      * standard time and the amount of daylight saving offset adjustment.
166      * @param name          The time zone name.
167      * @param rawOffset     The UTC offset of its standard time in milliseconds.
168      * @param dstSavings    The amount of daylight saving offset adjustment in milliseconds.
169      *                      If this ia a rule for standard time, the value of this argument is 0.
170      * @stable ICU 3.8
171      */
172     TimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings);
173 
174     /**
175      * Copy constructor.
176      * @param source    The TimeZoneRule object to be copied.
177      * @stable ICU 3.8
178      */
179     TimeZoneRule(const TimeZoneRule& source);
180 
181     /**
182      * Assignment operator.
183      * @param right The object to be copied.
184      * @stable ICU 3.8
185      */
186     TimeZoneRule& operator=(const TimeZoneRule& right);
187 
188 private:
189     UnicodeString fName; // time name
190     int32_t fRawOffset;  // UTC offset of the standard time in milliseconds
191     int32_t fDSTSavings; // DST saving amount in milliseconds
192 };
193 
194 /**
195  * <code>InitialTimeZoneRule</code> represents a time zone rule
196  * representing a time zone effective from the beginning and
197  * has no actual start times.
198  * @stable ICU 3.8
199  */
200 class U_I18N_API InitialTimeZoneRule : public TimeZoneRule {
201 public:
202     /**
203      * Constructs an <code>InitialTimeZoneRule</code> with the name, the GMT offset of its
204      * standard time and the amount of daylight saving offset adjustment.
205      * @param name          The time zone name.
206      * @param rawOffset     The UTC offset of its standard time in milliseconds.
207      * @param dstSavings    The amount of daylight saving offset adjustment in milliseconds.
208      *                      If this ia a rule for standard time, the value of this argument is 0.
209      * @stable ICU 3.8
210      */
211     InitialTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings);
212 
213     /**
214      * Copy constructor.
215      * @param source    The InitialTimeZoneRule object to be copied.
216      * @stable ICU 3.8
217      */
218     InitialTimeZoneRule(const InitialTimeZoneRule& source);
219 
220     /**
221      * Destructor.
222      * @stable ICU 3.8
223      */
224     virtual ~InitialTimeZoneRule();
225 
226     /**
227      * Clone this InitialTimeZoneRule object polymorphically. The caller owns the result and
228      * should delete it when done.
229      * @return    A copy of the object.
230      * @stable ICU 3.8
231      */
232     virtual InitialTimeZoneRule* clone(void) const;
233 
234     /**
235      * Assignment operator.
236      * @param right The object to be copied.
237      * @stable ICU 3.8
238      */
239     InitialTimeZoneRule& operator=(const InitialTimeZoneRule& right);
240 
241     /**
242      * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
243      * of different subclasses are considered unequal.
244      * @param that  The object to be compared with.
245      * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
246      * @stable ICU 3.8
247      */
248     virtual UBool operator==(const TimeZoneRule& that) const;
249 
250     /**
251      * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
252      * of different subclasses are considered unequal.
253      * @param that  The object to be compared with.
254      * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
255      * @stable ICU 3.8
256      */
257     virtual UBool operator!=(const TimeZoneRule& that) const;
258 
259     /**
260      * Gets the time when this rule takes effect in the given year.
261      * @param year              The Gregorian year, with 0 == 1 BCE, -1 == 2 BCE, etc.
262      * @param prevRawOffset     The standard time offset from UTC before this rule
263      *                          takes effect in milliseconds.
264      * @param prevDSTSavings    The amount of daylight saving offset from the
265      *                          standard time.
266      * @param result            Receives the start time in the year.
267      * @return  true if this rule takes effect in the year and the result is set to
268      *          "result".
269      * @stable ICU 3.8
270      */
271     UBool getStartInYear(int32_t year, int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
272 
273     /**
274      * Returns if this rule represents the same rule and offsets as another.
275      * When two <code>TimeZoneRule</code> objects differ only its names, this method
276      * returns true.
277      * @param that  The <code>TimeZoneRule</code> object to be compared with.
278      * @return  true if the other <code>TimeZoneRule</code> is equivalent to this one.
279      * @stable ICU 3.8
280      */
281     virtual UBool isEquivalentTo(const TimeZoneRule& that) const;
282 
283     /**
284      * Gets the very first time when this rule takes effect.
285      * @param prevRawOffset     The standard time offset from UTC before this rule
286      *                          takes effect in milliseconds.
287      * @param prevDSTSavings    The amount of daylight saving offset from the
288      *                          standard time.
289      * @param result            Receives the very first time when this rule takes effect.
290      * @return  true if the start time is available.  When false is returned, output parameter
291      *          "result" is unchanged.
292      * @stable ICU 3.8
293      */
294     virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
295 
296     /**
297      * Gets the final time when this rule takes effect.
298      * @param prevRawOffset     The standard time offset from UTC before this rule
299      *                          takes effect in milliseconds.
300      * @param prevDSTSavings    The amount of daylight saving offset from the
301      *                          standard time.
302      * @param result            Receives the final time when this rule takes effect.
303      * @return  true if the start time is available.  When false is returned, output parameter
304      *          "result" is unchanged.
305      * @stable ICU 3.8
306      */
307     virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
308 
309     /**
310      * Gets the first time when this rule takes effect after the specified time.
311      * @param base              The first start time after this base time will be returned.
312      * @param prevRawOffset     The standard time offset from UTC before this rule
313      *                          takes effect in milliseconds.
314      * @param prevDSTSavings    The amount of daylight saving offset from the
315      *                          standard time.
316      * @param inclusive         Whether the base time is inclusive or not.
317      * @param result            Receives The first time when this rule takes effect after
318      *                          the specified base time.
319      * @return  true if the start time is available.  When false is returned, output parameter
320      *          "result" is unchanged.
321      * @stable ICU 3.8
322      */
323     virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
324         UBool inclusive, UDate& result) const;
325 
326     /**
327      * Gets the most recent time when this rule takes effect before the specified time.
328      * @param base              The most recent time before this base time will be returned.
329      * @param prevRawOffset     The standard time offset from UTC before this rule
330      *                          takes effect in milliseconds.
331      * @param prevDSTSavings    The amount of daylight saving offset from the
332      *                          standard time.
333      * @param inclusive         Whether the base time is inclusive or not.
334      * @param result            Receives The most recent time when this rule takes effect before
335      *                          the specified base time.
336      * @return  true if the start time is available.  When false is returned, output parameter
337      *          "result" is unchanged.
338      * @stable ICU 3.8
339      */
340     virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
341         UBool inclusive, UDate& result) const;
342 
343 public:
344     /**
345      * Return the class ID for this class. This is useful only for comparing to
346      * a return value from getDynamicClassID(). For example:
347      * <pre>
348      * .   Base* polymorphic_pointer = createPolymorphicObject();
349      * .   if (polymorphic_pointer->getDynamicClassID() ==
350      * .       erived::getStaticClassID()) ...
351      * </pre>
352      * @return          The class ID for all objects of this class.
353      * @stable ICU 3.8
354      */
355     static UClassID U_EXPORT2 getStaticClassID(void);
356 
357     /**
358      * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
359      * method is to implement a simple version of RTTI, since not all C++
360      * compilers support genuine RTTI. Polymorphic operator==() and clone()
361      * methods call this method.
362      *
363      * @return          The class ID for this object. All objects of a
364      *                  given class have the same class ID.  Objects of
365      *                  other classes have different class IDs.
366      * @stable ICU 3.8
367      */
368     virtual UClassID getDynamicClassID(void) const;
369 };
370 
371 /**
372  * <code>AnnualTimeZoneRule</code> is a class used for representing a time zone
373  * rule which takes effect annually.  The calenday system used for the rule is
374  * is based on Gregorian calendar
375  *
376  * @stable ICU 3.8
377  */
378 class U_I18N_API AnnualTimeZoneRule : public TimeZoneRule {
379 public:
380     /**
381      * The constant representing the maximum year used for designating
382      * a rule is permanent.
383      */
384     static const int32_t MAX_YEAR;
385 
386     /**
387      * Constructs a <code>AnnualTimeZoneRule</code> with the name, the GMT offset of its
388      * standard time, the amount of daylight saving offset adjustment, the annual start
389      * time rule and the start/until years.  The input DateTimeRule is copied by this
390      * constructor, so the caller remains responsible for deleting the object.
391      * @param name          The time zone name.
392      * @param rawOffset     The GMT offset of its standard time in milliseconds.
393      * @param dstSavings    The amount of daylight saving offset adjustment in
394      *                      milliseconds.  If this ia a rule for standard time,
395      *                      the value of this argument is 0.
396      * @param dateTimeRule  The start date/time rule repeated annually.
397      * @param startYear     The first year when this rule takes effect.
398      * @param endYear       The last year when this rule takes effect.  If this
399      *                      rule is effective forever in future, specify MAX_YEAR.
400      * @stable ICU 3.8
401      */
402     AnnualTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
403             const DateTimeRule& dateTimeRule, int32_t startYear, int32_t endYear);
404 
405     /**
406      * Constructs a <code>AnnualTimeZoneRule</code> with the name, the GMT offset of its
407      * standard time, the amount of daylight saving offset adjustment, the annual start
408      * time rule and the start/until years.  The input DateTimeRule object is adopted
409      * by this object, therefore, the caller must not delete the object.
410      * @param name          The time zone name.
411      * @param rawOffset     The GMT offset of its standard time in milliseconds.
412      * @param dstSavings    The amount of daylight saving offset adjustment in
413      *                      milliseconds.  If this ia a rule for standard time,
414      *                      the value of this argument is 0.
415      * @param dateTimeRule  The start date/time rule repeated annually.
416      * @param startYear     The first year when this rule takes effect.
417      * @param endYear       The last year when this rule takes effect.  If this
418      *                      rule is effective forever in future, specify MAX_YEAR.
419      * @stable ICU 3.8
420      */
421     AnnualTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
422             DateTimeRule* dateTimeRule, int32_t startYear, int32_t endYear);
423 
424     /**
425      * Copy constructor.
426      * @param source    The AnnualTimeZoneRule object to be copied.
427      * @stable ICU 3.8
428      */
429     AnnualTimeZoneRule(const AnnualTimeZoneRule& source);
430 
431     /**
432      * Destructor.
433      * @stable ICU 3.8
434      */
435     virtual ~AnnualTimeZoneRule();
436 
437     /**
438      * Clone this AnnualTimeZoneRule object polymorphically. The caller owns the result and
439      * should delete it when done.
440      * @return    A copy of the object.
441      * @stable ICU 3.8
442      */
443     virtual AnnualTimeZoneRule* clone(void) const;
444 
445     /**
446      * Assignment operator.
447      * @param right The object to be copied.
448      * @stable ICU 3.8
449      */
450     AnnualTimeZoneRule& operator=(const AnnualTimeZoneRule& right);
451 
452     /**
453      * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
454      * of different subclasses are considered unequal.
455      * @param that  The object to be compared with.
456      * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
457      * @stable ICU 3.8
458      */
459     virtual UBool operator==(const TimeZoneRule& that) const;
460 
461     /**
462      * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
463      * of different subclasses are considered unequal.
464      * @param that  The object to be compared with.
465      * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
466      * @stable ICU 3.8
467      */
468     virtual UBool operator!=(const TimeZoneRule& that) const;
469 
470     /**
471      * Gets the start date/time rule used by this rule.
472      * @return  The <code>AnnualDateTimeRule</code> which represents the start date/time
473      *          rule used by this time zone rule.
474      * @stable ICU 3.8
475      */
476     const DateTimeRule* getRule(void) const;
477 
478     /**
479      * Gets the first year when this rule takes effect.
480      * @return  The start year of this rule.  The year is in Gregorian calendar
481      *          with 0 == 1 BCE, -1 == 2 BCE, etc.
482      * @stable ICU 3.8
483      */
484     int32_t getStartYear(void) const;
485 
486     /**
487      * Gets the end year when this rule takes effect.
488      * @return  The end year of this rule (inclusive). The year is in Gregorian calendar
489      *          with 0 == 1 BCE, -1 == 2 BCE, etc.
490      * @stable ICU 3.8
491      */
492     int32_t getEndYear(void) const;
493 
494     /**
495      * Gets the time when this rule takes effect in the given year.
496      * @param year              The Gregorian year, with 0 == 1 BCE, -1 == 2 BCE, etc.
497      * @param prevRawOffset     The standard time offset from UTC before this rule
498      *                          takes effect in milliseconds.
499      * @param prevDSTSavings    The amount of daylight saving offset from the
500      *                          standard time.
501      * @param result            Receives the start time in the year.
502      * @return  true if this rule takes effect in the year and the result is set to
503      *          "result".
504      * @stable ICU 3.8
505      */
506     UBool getStartInYear(int32_t year, int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
507 
508     /**
509      * Returns if this rule represents the same rule and offsets as another.
510      * When two <code>TimeZoneRule</code> objects differ only its names, this method
511      * returns true.
512      * @param that  The <code>TimeZoneRule</code> object to be compared with.
513      * @return  true if the other <code>TimeZoneRule</code> is equivalent to this one.
514      * @stable ICU 3.8
515      */
516     virtual UBool isEquivalentTo(const TimeZoneRule& that) const;
517 
518     /**
519      * Gets the very first time when this rule takes effect.
520      * @param prevRawOffset     The standard time offset from UTC before this rule
521      *                          takes effect in milliseconds.
522      * @param prevDSTSavings    The amount of daylight saving offset from the
523      *                          standard time.
524      * @param result            Receives the very first time when this rule takes effect.
525      * @return  true if the start time is available.  When false is returned, output parameter
526      *          "result" is unchanged.
527      * @stable ICU 3.8
528      */
529     virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
530 
531     /**
532      * Gets the final time when this rule takes effect.
533      * @param prevRawOffset     The standard time offset from UTC before this rule
534      *                          takes effect in milliseconds.
535      * @param prevDSTSavings    The amount of daylight saving offset from the
536      *                          standard time.
537      * @param result            Receives the final time when this rule takes effect.
538      * @return  true if the start time is available.  When false is returned, output parameter
539      *          "result" is unchanged.
540      * @stable ICU 3.8
541      */
542     virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
543 
544     /**
545      * Gets the first time when this rule takes effect after the specified time.
546      * @param base              The first start time after this base time will be returned.
547      * @param prevRawOffset     The standard time offset from UTC before this rule
548      *                          takes effect in milliseconds.
549      * @param prevDSTSavings    The amount of daylight saving offset from the
550      *                          standard time.
551      * @param inclusive         Whether the base time is inclusive or not.
552      * @param result            Receives The first time when this rule takes effect after
553      *                          the specified base time.
554      * @return  true if the start time is available.  When false is returned, output parameter
555      *          "result" is unchanged.
556      * @stable ICU 3.8
557      */
558     virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
559         UBool inclusive, UDate& result) const;
560 
561     /**
562      * Gets the most recent time when this rule takes effect before the specified time.
563      * @param base              The most recent time before this base time will be returned.
564      * @param prevRawOffset     The standard time offset from UTC before this rule
565      *                          takes effect in milliseconds.
566      * @param prevDSTSavings    The amount of daylight saving offset from the
567      *                          standard time.
568      * @param inclusive         Whether the base time is inclusive or not.
569      * @param result            Receives The most recent time when this rule takes effect before
570      *                          the specified base time.
571      * @return  true if the start time is available.  When false is returned, output parameter
572      *          "result" is unchanged.
573      * @stable ICU 3.8
574      */
575     virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
576         UBool inclusive, UDate& result) const;
577 
578 
579 private:
580     DateTimeRule* fDateTimeRule;
581     int32_t fStartYear;
582     int32_t fEndYear;
583 
584 public:
585     /**
586      * Return the class ID for this class. This is useful only for comparing to
587      * a return value from getDynamicClassID(). For example:
588      * <pre>
589      * .   Base* polymorphic_pointer = createPolymorphicObject();
590      * .   if (polymorphic_pointer->getDynamicClassID() ==
591      * .       erived::getStaticClassID()) ...
592      * </pre>
593      * @return          The class ID for all objects of this class.
594      * @stable ICU 3.8
595      */
596     static UClassID U_EXPORT2 getStaticClassID(void);
597 
598     /**
599      * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
600      * method is to implement a simple version of RTTI, since not all C++
601      * compilers support genuine RTTI. Polymorphic operator==() and clone()
602      * methods call this method.
603      *
604      * @return          The class ID for this object. All objects of a
605      *                  given class have the same class ID.  Objects of
606      *                  other classes have different class IDs.
607      * @stable ICU 3.8
608      */
609     virtual UClassID getDynamicClassID(void) const;
610 };
611 
612 /**
613  * <code>TimeArrayTimeZoneRule</code> represents a time zone rule whose start times are
614  * defined by an array of milliseconds since the standard base time.
615  *
616  * @stable ICU 3.8
617  */
618 class U_I18N_API TimeArrayTimeZoneRule : public TimeZoneRule {
619 public:
620     /**
621      * Constructs a <code>TimeArrayTimeZoneRule</code> with the name, the GMT offset of its
622      * standard time, the amount of daylight saving offset adjustment and
623      * the array of times when this rule takes effect.
624      * @param name          The time zone name.
625      * @param rawOffset     The UTC offset of its standard time in milliseconds.
626      * @param dstSavings    The amount of daylight saving offset adjustment in
627      *                      milliseconds.  If this ia a rule for standard time,
628      *                      the value of this argument is 0.
629      * @param startTimes    The array start times in milliseconds since the base time
630      *                      (January 1, 1970, 00:00:00).
631      * @param numStartTimes The number of elements in the parameter "startTimes"
632      * @param timeRuleType  The time type of the start times, which is one of
633      *                      <code>DataTimeRule::WALL_TIME</code>, <code>STANDARD_TIME</code>
634      *                      and <code>UTC_TIME</code>.
635      * @stable ICU 3.8
636      */
637     TimeArrayTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
638         const UDate* startTimes, int32_t numStartTimes, DateTimeRule::TimeRuleType timeRuleType);
639 
640     /**
641      * Copy constructor.
642      * @param source    The TimeArrayTimeZoneRule object to be copied.
643      * @stable ICU 3.8
644      */
645     TimeArrayTimeZoneRule(const TimeArrayTimeZoneRule& source);
646 
647     /**
648      * Destructor.
649      * @stable ICU 3.8
650      */
651     virtual ~TimeArrayTimeZoneRule();
652 
653     /**
654      * Clone this TimeArrayTimeZoneRule object polymorphically. The caller owns the result and
655      * should delete it when done.
656      * @return    A copy of the object.
657      * @stable ICU 3.8
658      */
659     virtual TimeArrayTimeZoneRule* clone(void) const;
660 
661     /**
662      * Assignment operator.
663      * @param right The object to be copied.
664      * @stable ICU 3.8
665      */
666     TimeArrayTimeZoneRule& operator=(const TimeArrayTimeZoneRule& right);
667 
668     /**
669      * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
670      * of different subclasses are considered unequal.
671      * @param that  The object to be compared with.
672      * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
673      * @stable ICU 3.8
674      */
675     virtual UBool operator==(const TimeZoneRule& that) const;
676 
677     /**
678      * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
679      * of different subclasses are considered unequal.
680      * @param that  The object to be compared with.
681      * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
682      * @stable ICU 3.8
683      */
684     virtual UBool operator!=(const TimeZoneRule& that) const;
685 
686     /**
687      * Gets the time type of the start times used by this rule.  The return value
688      * is either <code>DateTimeRule::WALL_TIME</code> or <code>STANDARD_TIME</code>
689      * or <code>UTC_TIME</code>.
690      *
691      * @return The time type used of the start times used by this rule.
692      * @stable ICU 3.8
693      */
694     DateTimeRule::TimeRuleType getTimeType(void) const;
695 
696     /**
697      * Gets a start time at the index stored in this rule.
698      * @param index     The index of start times
699      * @param result    Receives the start time at the index
700      * @return  true if the index is within the valid range and
701      *          and the result is set.  When false, the output
702      *          parameger "result" is unchanged.
703      * @stable ICU 3.8
704      */
705     UBool getStartTimeAt(int32_t index, UDate& result) const;
706 
707     /**
708      * Returns the number of start times stored in this rule
709      * @return The number of start times.
710      * @stable ICU 3.8
711      */
712     int32_t countStartTimes(void) const;
713 
714     /**
715      * Returns if this rule represents the same rule and offsets as another.
716      * When two <code>TimeZoneRule</code> objects differ only its names, this method
717      * returns true.
718      * @param that  The <code>TimeZoneRule</code> object to be compared with.
719      * @return  true if the other <code>TimeZoneRule</code> is equivalent to this one.
720      * @stable ICU 3.8
721      */
722     virtual UBool isEquivalentTo(const TimeZoneRule& that) const;
723 
724     /**
725      * Gets the very first time when this rule takes effect.
726      * @param prevRawOffset     The standard time offset from UTC before this rule
727      *                          takes effect in milliseconds.
728      * @param prevDSTSavings    The amount of daylight saving offset from the
729      *                          standard time.
730      * @param result            Receives the very first time when this rule takes effect.
731      * @return  true if the start time is available.  When false is returned, output parameter
732      *          "result" is unchanged.
733      * @stable ICU 3.8
734      */
735     virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
736 
737     /**
738      * Gets the final time when this rule takes effect.
739      * @param prevRawOffset     The standard time offset from UTC before this rule
740      *                          takes effect in milliseconds.
741      * @param prevDSTSavings    The amount of daylight saving offset from the
742      *                          standard time.
743      * @param result            Receives the final time when this rule takes effect.
744      * @return  true if the start time is available.  When false is returned, output parameter
745      *          "result" is unchanged.
746      * @stable ICU 3.8
747      */
748     virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;
749 
750     /**
751      * Gets the first time when this rule takes effect after the specified time.
752      * @param base              The first start time after this base time will be returned.
753      * @param prevRawOffset     The standard time offset from UTC before this rule
754      *                          takes effect in milliseconds.
755      * @param prevDSTSavings    The amount of daylight saving offset from the
756      *                          standard time.
757      * @param inclusive         Whether the base time is inclusive or not.
758      * @param result            Receives The first time when this rule takes effect after
759      *                          the specified base time.
760      * @return  true if the start time is available.  When false is returned, output parameter
761      *          "result" is unchanged.
762      * @stable ICU 3.8
763      */
764     virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
765         UBool inclusive, UDate& result) const;
766 
767     /**
768      * Gets the most recent time when this rule takes effect before the specified time.
769      * @param base              The most recent time before this base time will be returned.
770      * @param prevRawOffset     The standard time offset from UTC before this rule
771      *                          takes effect in milliseconds.
772      * @param prevDSTSavings    The amount of daylight saving offset from the
773      *                          standard time.
774      * @param inclusive         Whether the base time is inclusive or not.
775      * @param result            Receives The most recent time when this rule takes effect before
776      *                          the specified base time.
777      * @return  true if the start time is available.  When false is returned, output parameter
778      *          "result" is unchanged.
779      * @stable ICU 3.8
780      */
781     virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
782         UBool inclusive, UDate& result) const;
783 
784 
785 private:
786     enum { TIMEARRAY_STACK_BUFFER_SIZE = 32 };
787     UBool initStartTimes(const UDate source[], int32_t size, UErrorCode& ec);
788     UDate getUTC(UDate time, int32_t raw, int32_t dst) const;
789 
790     DateTimeRule::TimeRuleType  fTimeRuleType;
791     int32_t fNumStartTimes;
792     UDate*  fStartTimes;
793     UDate   fLocalStartTimes[TIMEARRAY_STACK_BUFFER_SIZE];
794 
795 public:
796     /**
797      * Return the class ID for this class. This is useful only for comparing to
798      * a return value from getDynamicClassID(). For example:
799      * <pre>
800      * .   Base* polymorphic_pointer = createPolymorphicObject();
801      * .   if (polymorphic_pointer->getDynamicClassID() ==
802      * .       erived::getStaticClassID()) ...
803      * </pre>
804      * @return          The class ID for all objects of this class.
805      * @stable ICU 3.8
806      */
807     static UClassID U_EXPORT2 getStaticClassID(void);
808 
809     /**
810      * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
811      * method is to implement a simple version of RTTI, since not all C++
812      * compilers support genuine RTTI. Polymorphic operator==() and clone()
813      * methods call this method.
814      *
815      * @return          The class ID for this object. All objects of a
816      *                  given class have the same class ID.  Objects of
817      *                  other classes have different class IDs.
818      * @stable ICU 3.8
819      */
820     virtual UClassID getDynamicClassID(void) const;
821 };
822 
823 
824 U_NAMESPACE_END
825 
826 #endif /* #if !UCONFIG_NO_FORMATTING */
827 
828 #endif // TZRULE_H
829 
830 //eof
831