$28 GRAYBYTE WORDPRESS FILE MANAGER $40

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/alt/libicu/usr/include/unicode/

HOME
Current File : /opt/alt/libicu/usr/include/unicode//tzrule.h
// © 2016 and later: Unicode, Inc. and others.
// License & terms of use: http://www.unicode.org/copyright.html
/*
*******************************************************************************
* Copyright (C) 2007-2008, International Business Machines Corporation and    *
* others. All Rights Reserved.                                                *
*******************************************************************************
*/
#ifndef TZRULE_H
#define TZRULE_H

/**
 * \file 
 * \brief C++ API: Time zone rule classes
 */

#include "unicode/utypes.h"

#if !UCONFIG_NO_FORMATTING

#include "unicode/uobject.h"
#include "unicode/unistr.h"
#include "unicode/dtrule.h"

U_NAMESPACE_BEGIN

/**
 * <code>TimeZoneRule</code> is a class representing a rule for time zone.
 * <code>TimeZoneRule</code> has a set of time zone attributes, such as zone name,
 * raw offset (UTC offset for standard time) and daylight saving time offset.
 * 
 * @stable ICU 3.8
 */
class U_I18N_API TimeZoneRule : public UObject {
public:
    /**
     * Destructor.
     * @stable ICU 3.8
     */
    virtual ~TimeZoneRule();

    /**
     * Clone this TimeZoneRule object polymorphically. The caller owns the result and
     * should delete it when done.
     * @return  A copy of the object.
     * @stable ICU 3.8
     */
    virtual TimeZoneRule* clone(void) const = 0;

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
     * @stable ICU 3.8
     */
    virtual UBool operator==(const TimeZoneRule& that) const;

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
     * @stable ICU 3.8
     */
    virtual UBool operator!=(const TimeZoneRule& that) const;

    /**
     * Fills in "name" with the name of this time zone.
     * @param name  Receives the name of this time zone.
     * @return  A reference to "name"
     * @stable ICU 3.8
     */
    UnicodeString& getName(UnicodeString& name) const;

    /**
     * Gets the standard time offset.
     * @return  The standard time offset from UTC in milliseconds.
     * @stable ICU 3.8
     */
    int32_t getRawOffset(void) const;

    /**
     * Gets the amount of daylight saving delta time from the standard time.
     * @return  The amount of daylight saving offset used by this rule
     *          in milliseconds.
     * @stable ICU 3.8
     */
    int32_t getDSTSavings(void) const;

    /**
     * Returns if this rule represents the same rule and offsets as another.
     * When two <code>TimeZoneRule</code> objects differ only its names, this method
     * returns true.
     * @param other The <code>TimeZoneRule</code> object to be compared with.
     * @return  true if the other <code>TimeZoneRule</code> is the same as this one.
     * @stable ICU 3.8
     */
    virtual UBool isEquivalentTo(const TimeZoneRule& other) const;

    /**
     * Gets the very first time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the very first time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const = 0;

    /**
     * Gets the final time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the final time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const = 0;

    /**
     * Gets the first time when this rule takes effect after the specified time.
     * @param base              The first start time after this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The first time when this rule takes effect after
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const = 0;

    /**
     * Gets the most recent time when this rule takes effect before the specified time.
     * @param base              The most recent time before this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The most recent time when this rule takes effect before
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const = 0;

protected:

    /**
     * Constructs a <code>TimeZoneRule</code> with the name, the GMT offset of its
     * standard time and the amount of daylight saving offset adjustment.
     * @param name          The time zone name.
     * @param rawOffset     The UTC offset of its standard time in milliseconds.
     * @param dstSavings    The amount of daylight saving offset adjustment in milliseconds.
     *                      If this ia a rule for standard time, the value of this argument is 0.
     * @stable ICU 3.8
     */
    TimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings);

    /**
     * Copy constructor.
     * @param source    The TimeZoneRule object to be copied.
     * @stable ICU 3.8
     */
    TimeZoneRule(const TimeZoneRule& source);

    /**
     * Assignment operator.
     * @param right The object to be copied.
     * @stable ICU 3.8
     */
    TimeZoneRule& operator=(const TimeZoneRule& right);

private:
    UnicodeString fName; // time name
    int32_t fRawOffset;  // UTC offset of the standard time in milliseconds
    int32_t fDSTSavings; // DST saving amount in milliseconds
};

/**
 * <code>InitialTimeZoneRule</code> represents a time zone rule
 * representing a time zone effective from the beginning and
 * has no actual start times.
 * @stable ICU 3.8
 */
class U_I18N_API InitialTimeZoneRule : public TimeZoneRule {
public:
    /**
     * Constructs an <code>InitialTimeZoneRule</code> with the name, the GMT offset of its
     * standard time and the amount of daylight saving offset adjustment.
     * @param name          The time zone name.
     * @param rawOffset     The UTC offset of its standard time in milliseconds.
     * @param dstSavings    The amount of daylight saving offset adjustment in milliseconds.
     *                      If this ia a rule for standard time, the value of this argument is 0.
     * @stable ICU 3.8
     */
    InitialTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings);

    /**
     * Copy constructor.
     * @param source    The InitialTimeZoneRule object to be copied.
     * @stable ICU 3.8
     */
    InitialTimeZoneRule(const InitialTimeZoneRule& source);

    /**
     * Destructor.
     * @stable ICU 3.8
     */
    virtual ~InitialTimeZoneRule();

    /**
     * Clone this InitialTimeZoneRule object polymorphically. The caller owns the result and
     * should delete it when done.
     * @return    A copy of the object.
     * @stable ICU 3.8
     */
    virtual InitialTimeZoneRule* clone(void) const;

    /**
     * Assignment operator.
     * @param right The object to be copied.
     * @stable ICU 3.8
     */
    InitialTimeZoneRule& operator=(const InitialTimeZoneRule& right);

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
     * @stable ICU 3.8
     */
    virtual UBool operator==(const TimeZoneRule& that) const;

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
     * @stable ICU 3.8
     */
    virtual UBool operator!=(const TimeZoneRule& that) const;

    /**
     * Gets the time when this rule takes effect in the given year.
     * @param year              The Gregorian year, with 0 == 1 BCE, -1 == 2 BCE, etc.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the start time in the year.
     * @return  true if this rule takes effect in the year and the result is set to
     *          "result".
     * @stable ICU 3.8
     */
    UBool getStartInYear(int32_t year, int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Returns if this rule represents the same rule and offsets as another.
     * When two <code>TimeZoneRule</code> objects differ only its names, this method
     * returns true.
     * @param that  The <code>TimeZoneRule</code> object to be compared with.
     * @return  true if the other <code>TimeZoneRule</code> is equivalent to this one.
     * @stable ICU 3.8
     */
    virtual UBool isEquivalentTo(const TimeZoneRule& that) const;

    /**
     * Gets the very first time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the very first time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Gets the final time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the final time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Gets the first time when this rule takes effect after the specified time.
     * @param base              The first start time after this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The first time when this rule takes effect after
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const;

    /**
     * Gets the most recent time when this rule takes effect before the specified time.
     * @param base              The most recent time before this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The most recent time when this rule takes effect before
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const;

public:
    /**
     * Return the class ID for this class. This is useful only for comparing to
     * a return value from getDynamicClassID(). For example:
     * <pre>
     * .   Base* polymorphic_pointer = createPolymorphicObject();
     * .   if (polymorphic_pointer->getDynamicClassID() ==
     * .       erived::getStaticClassID()) ...
     * </pre>
     * @return          The class ID for all objects of this class.
     * @stable ICU 3.8
     */
    static UClassID U_EXPORT2 getStaticClassID(void);

    /**
     * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
     * method is to implement a simple version of RTTI, since not all C++
     * compilers support genuine RTTI. Polymorphic operator==() and clone()
     * methods call this method.
     *
     * @return          The class ID for this object. All objects of a
     *                  given class have the same class ID.  Objects of
     *                  other classes have different class IDs.
     * @stable ICU 3.8
     */
    virtual UClassID getDynamicClassID(void) const;
};

/**
 * <code>AnnualTimeZoneRule</code> is a class used for representing a time zone
 * rule which takes effect annually.  The calenday system used for the rule is
 * is based on Gregorian calendar
 * 
 * @stable ICU 3.8
 */
class U_I18N_API AnnualTimeZoneRule : public TimeZoneRule {
public:
    /**
     * The constant representing the maximum year used for designating
     * a rule is permanent.
     */
    static const int32_t MAX_YEAR;

    /**
     * Constructs a <code>AnnualTimeZoneRule</code> with the name, the GMT offset of its
     * standard time, the amount of daylight saving offset adjustment, the annual start
     * time rule and the start/until years.  The input DateTimeRule is copied by this
     * constructor, so the caller remains responsible for deleting the object.
     * @param name          The time zone name.
     * @param rawOffset     The GMT offset of its standard time in milliseconds.
     * @param dstSavings    The amount of daylight saving offset adjustment in
     *                      milliseconds.  If this ia a rule for standard time,
     *                      the value of this argument is 0.
     * @param dateTimeRule  The start date/time rule repeated annually.
     * @param startYear     The first year when this rule takes effect.
     * @param endYear       The last year when this rule takes effect.  If this
     *                      rule is effective forever in future, specify MAX_YEAR.
     * @stable ICU 3.8
     */
    AnnualTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
            const DateTimeRule& dateTimeRule, int32_t startYear, int32_t endYear);

    /**
     * Constructs a <code>AnnualTimeZoneRule</code> with the name, the GMT offset of its
     * standard time, the amount of daylight saving offset adjustment, the annual start
     * time rule and the start/until years.  The input DateTimeRule object is adopted
     * by this object, therefore, the caller must not delete the object.
     * @param name          The time zone name.
     * @param rawOffset     The GMT offset of its standard time in milliseconds.
     * @param dstSavings    The amount of daylight saving offset adjustment in
     *                      milliseconds.  If this ia a rule for standard time,
     *                      the value of this argument is 0.
     * @param dateTimeRule  The start date/time rule repeated annually.
     * @param startYear     The first year when this rule takes effect.
     * @param endYear       The last year when this rule takes effect.  If this
     *                      rule is effective forever in future, specify MAX_YEAR.
     * @stable ICU 3.8
     */
    AnnualTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
            DateTimeRule* dateTimeRule, int32_t startYear, int32_t endYear);

    /**
     * Copy constructor.
     * @param source    The AnnualTimeZoneRule object to be copied.
     * @stable ICU 3.8
     */
    AnnualTimeZoneRule(const AnnualTimeZoneRule& source);

    /**
     * Destructor.
     * @stable ICU 3.8
     */
    virtual ~AnnualTimeZoneRule();

    /**
     * Clone this AnnualTimeZoneRule object polymorphically. The caller owns the result and
     * should delete it when done.
     * @return    A copy of the object.
     * @stable ICU 3.8
     */
    virtual AnnualTimeZoneRule* clone(void) const;

    /**
     * Assignment operator.
     * @param right The object to be copied.
     * @stable ICU 3.8
     */
    AnnualTimeZoneRule& operator=(const AnnualTimeZoneRule& right);

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
     * @stable ICU 3.8
     */
    virtual UBool operator==(const TimeZoneRule& that) const;

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
     * @stable ICU 3.8
     */
    virtual UBool operator!=(const TimeZoneRule& that) const;

    /**
     * Gets the start date/time rule used by this rule.
     * @return  The <code>AnnualDateTimeRule</code> which represents the start date/time
     *          rule used by this time zone rule.
     * @stable ICU 3.8
     */
    const DateTimeRule* getRule(void) const;

    /**
     * Gets the first year when this rule takes effect.
     * @return  The start year of this rule.  The year is in Gregorian calendar
     *          with 0 == 1 BCE, -1 == 2 BCE, etc.
     * @stable ICU 3.8
     */
    int32_t getStartYear(void) const;

    /**
     * Gets the end year when this rule takes effect.
     * @return  The end year of this rule (inclusive). The year is in Gregorian calendar
     *          with 0 == 1 BCE, -1 == 2 BCE, etc.
     * @stable ICU 3.8
     */
    int32_t getEndYear(void) const;

    /**
     * Gets the time when this rule takes effect in the given year.
     * @param year              The Gregorian year, with 0 == 1 BCE, -1 == 2 BCE, etc.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the start time in the year.
     * @return  true if this rule takes effect in the year and the result is set to
     *          "result".
     * @stable ICU 3.8
     */
    UBool getStartInYear(int32_t year, int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Returns if this rule represents the same rule and offsets as another.
     * When two <code>TimeZoneRule</code> objects differ only its names, this method
     * returns true.
     * @param that  The <code>TimeZoneRule</code> object to be compared with.
     * @return  true if the other <code>TimeZoneRule</code> is equivalent to this one.
     * @stable ICU 3.8
     */
    virtual UBool isEquivalentTo(const TimeZoneRule& that) const;

    /**
     * Gets the very first time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the very first time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Gets the final time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the final time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Gets the first time when this rule takes effect after the specified time.
     * @param base              The first start time after this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The first time when this rule takes effect after
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const;

    /**
     * Gets the most recent time when this rule takes effect before the specified time.
     * @param base              The most recent time before this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The most recent time when this rule takes effect before
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const;


private:
    DateTimeRule* fDateTimeRule;
    int32_t fStartYear;
    int32_t fEndYear;

public:
    /**
     * Return the class ID for this class. This is useful only for comparing to
     * a return value from getDynamicClassID(). For example:
     * <pre>
     * .   Base* polymorphic_pointer = createPolymorphicObject();
     * .   if (polymorphic_pointer->getDynamicClassID() ==
     * .       erived::getStaticClassID()) ...
     * </pre>
     * @return          The class ID for all objects of this class.
     * @stable ICU 3.8
     */
    static UClassID U_EXPORT2 getStaticClassID(void);

    /**
     * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
     * method is to implement a simple version of RTTI, since not all C++
     * compilers support genuine RTTI. Polymorphic operator==() and clone()
     * methods call this method.
     *
     * @return          The class ID for this object. All objects of a
     *                  given class have the same class ID.  Objects of
     *                  other classes have different class IDs.
     * @stable ICU 3.8
     */
    virtual UClassID getDynamicClassID(void) const;
};

/**
 * <code>TimeArrayTimeZoneRule</code> represents a time zone rule whose start times are
 * defined by an array of milliseconds since the standard base time.
 * 
 * @stable ICU 3.8
 */
class U_I18N_API TimeArrayTimeZoneRule : public TimeZoneRule {
public:
    /**
     * Constructs a <code>TimeArrayTimeZoneRule</code> with the name, the GMT offset of its
     * standard time, the amount of daylight saving offset adjustment and
     * the array of times when this rule takes effect.
     * @param name          The time zone name.
     * @param rawOffset     The UTC offset of its standard time in milliseconds.
     * @param dstSavings    The amount of daylight saving offset adjustment in
     *                      milliseconds.  If this ia a rule for standard time,
     *                      the value of this argument is 0.
     * @param startTimes    The array start times in milliseconds since the base time
     *                      (January 1, 1970, 00:00:00).
     * @param numStartTimes The number of elements in the parameter "startTimes"
     * @param timeRuleType  The time type of the start times, which is one of
     *                      <code>DataTimeRule::WALL_TIME</code>, <code>STANDARD_TIME</code>
     *                      and <code>UTC_TIME</code>.
     * @stable ICU 3.8
     */
    TimeArrayTimeZoneRule(const UnicodeString& name, int32_t rawOffset, int32_t dstSavings,
        const UDate* startTimes, int32_t numStartTimes, DateTimeRule::TimeRuleType timeRuleType);

    /**
     * Copy constructor.
     * @param source    The TimeArrayTimeZoneRule object to be copied.
     * @stable ICU 3.8
     */
    TimeArrayTimeZoneRule(const TimeArrayTimeZoneRule& source);

    /**
     * Destructor.
     * @stable ICU 3.8
     */
    virtual ~TimeArrayTimeZoneRule();

    /**
     * Clone this TimeArrayTimeZoneRule object polymorphically. The caller owns the result and
     * should delete it when done.
     * @return    A copy of the object.
     * @stable ICU 3.8
     */
    virtual TimeArrayTimeZoneRule* clone(void) const;

    /**
     * Assignment operator.
     * @param right The object to be copied.
     * @stable ICU 3.8
     */
    TimeArrayTimeZoneRule& operator=(const TimeArrayTimeZoneRule& right);

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically equal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically equal.
     * @stable ICU 3.8
     */
    virtual UBool operator==(const TimeZoneRule& that) const;

    /**
     * Return true if the given <code>TimeZoneRule</code> objects are semantically unequal. Objects
     * of different subclasses are considered unequal.
     * @param that  The object to be compared with.
     * @return  true if the given <code>TimeZoneRule</code> objects are semantically unequal.
     * @stable ICU 3.8
     */
    virtual UBool operator!=(const TimeZoneRule& that) const;

    /**
     * Gets the time type of the start times used by this rule.  The return value
     * is either <code>DateTimeRule::WALL_TIME</code> or <code>STANDARD_TIME</code>
     * or <code>UTC_TIME</code>.
     * 
     * @return The time type used of the start times used by this rule.
     * @stable ICU 3.8
     */
    DateTimeRule::TimeRuleType getTimeType(void) const;

    /**
     * Gets a start time at the index stored in this rule.
     * @param index     The index of start times
     * @param result    Receives the start time at the index
     * @return  true if the index is within the valid range and
     *          and the result is set.  When false, the output
     *          parameger "result" is unchanged.
     * @stable ICU 3.8
     */
    UBool getStartTimeAt(int32_t index, UDate& result) const;

    /**
     * Returns the number of start times stored in this rule
     * @return The number of start times.
     * @stable ICU 3.8
     */
    int32_t countStartTimes(void) const;

    /**
     * Returns if this rule represents the same rule and offsets as another.
     * When two <code>TimeZoneRule</code> objects differ only its names, this method
     * returns true.
     * @param that  The <code>TimeZoneRule</code> object to be compared with.
     * @return  true if the other <code>TimeZoneRule</code> is equivalent to this one.
     * @stable ICU 3.8
     */
    virtual UBool isEquivalentTo(const TimeZoneRule& that) const;

    /**
     * Gets the very first time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the very first time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFirstStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Gets the final time when this rule takes effect.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param result            Receives the final time when this rule takes effect.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getFinalStart(int32_t prevRawOffset, int32_t prevDSTSavings, UDate& result) const;

    /**
     * Gets the first time when this rule takes effect after the specified time.
     * @param base              The first start time after this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The first time when this rule takes effect after
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getNextStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const;

    /**
     * Gets the most recent time when this rule takes effect before the specified time.
     * @param base              The most recent time before this base time will be returned.
     * @param prevRawOffset     The standard time offset from UTC before this rule
     *                          takes effect in milliseconds.
     * @param prevDSTSavings    The amount of daylight saving offset from the
     *                          standard time.
     * @param inclusive         Whether the base time is inclusive or not.
     * @param result            Receives The most recent time when this rule takes effect before
     *                          the specified base time.
     * @return  true if the start time is available.  When false is returned, output parameter
     *          "result" is unchanged.
     * @stable ICU 3.8
     */
    virtual UBool getPreviousStart(UDate base, int32_t prevRawOffset, int32_t prevDSTSavings,
        UBool inclusive, UDate& result) const;


private:
    enum { TIMEARRAY_STACK_BUFFER_SIZE = 32 };
    UBool initStartTimes(const UDate source[], int32_t size, UErrorCode& ec);
    UDate getUTC(UDate time, int32_t raw, int32_t dst) const;

    DateTimeRule::TimeRuleType  fTimeRuleType;
    int32_t fNumStartTimes;
    UDate*  fStartTimes;
    UDate   fLocalStartTimes[TIMEARRAY_STACK_BUFFER_SIZE];

public:
    /**
     * Return the class ID for this class. This is useful only for comparing to
     * a return value from getDynamicClassID(). For example:
     * <pre>
     * .   Base* polymorphic_pointer = createPolymorphicObject();
     * .   if (polymorphic_pointer->getDynamicClassID() ==
     * .       erived::getStaticClassID()) ...
     * </pre>
     * @return          The class ID for all objects of this class.
     * @stable ICU 3.8
     */
    static UClassID U_EXPORT2 getStaticClassID(void);

    /**
     * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This
     * method is to implement a simple version of RTTI, since not all C++
     * compilers support genuine RTTI. Polymorphic operator==() and clone()
     * methods call this method.
     *
     * @return          The class ID for this object. All objects of a
     *                  given class have the same class ID.  Objects of
     *                  other classes have different class IDs.
     * @stable ICU 3.8
     */
    virtual UClassID getDynamicClassID(void) const;
};


U_NAMESPACE_END

#endif /* #if !UCONFIG_NO_FORMATTING */

#endif // TZRULE_H

//eof

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
31 Aug 2024 7.04 AM
root / root
0755
alphaindex.h
26.421 KB
7 Nov 2019 1.58 PM
root / root
0644
appendable.h
8.43 KB
7 Nov 2019 1.58 PM
root / root
0644
basictz.h
8.843 KB
7 Nov 2019 1.58 PM
root / root
0644
brkiter.h
27.64 KB
7 Nov 2019 1.58 PM
root / root
0644
bytestream.h
9.538 KB
7 Nov 2019 1.58 PM
root / root
0644
bytestrie.h
19.256 KB
7 Nov 2019 1.58 PM
root / root
0644
bytestriebuilder.h
7.018 KB
7 Nov 2019 1.58 PM
root / root
0644
calendar.h
105.06 KB
7 Nov 2019 1.58 PM
root / root
0644
caniter.h
7.373 KB
7 Nov 2019 1.58 PM
root / root
0644
casemap.h
25.265 KB
7 Nov 2019 1.58 PM
root / root
0644
char16ptr.h
7.159 KB
7 Nov 2019 1.58 PM
root / root
0644
chariter.h
23.997 KB
7 Nov 2019 1.58 PM
root / root
0644
choicfmt.h
23.846 KB
7 Nov 2019 1.58 PM
root / root
0644
coleitr.h
13.704 KB
7 Nov 2019 1.58 PM
root / root
0644
coll.h
55.594 KB
7 Nov 2019 1.58 PM
root / root
0644
compactdecimalformat.h
6.808 KB
7 Nov 2019 1.58 PM
root / root
0644
curramt.h
3.693 KB
7 Nov 2019 1.58 PM
root / root
0644
currpinf.h
7.238 KB
7 Nov 2019 1.58 PM
root / root
0644
currunit.h
3.986 KB
7 Nov 2019 1.58 PM
root / root
0644
datefmt.h
40.365 KB
7 Nov 2019 1.58 PM
root / root
0644
dbbi.h
1.106 KB
7 Nov 2019 1.58 PM
root / root
0644
dcfmtsym.h
20.102 KB
7 Nov 2019 1.58 PM
root / root
0644
decimfmt.h
87.818 KB
7 Nov 2019 1.58 PM
root / root
0644
docmain.h
6.956 KB
7 Nov 2019 1.58 PM
root / root
0644
dtfmtsym.h
37.645 KB
7 Nov 2019 1.58 PM
root / root
0644
dtintrv.h
3.778 KB
7 Nov 2019 1.58 PM
root / root
0644
dtitvfmt.h
46.559 KB
7 Nov 2019 1.58 PM
root / root
0644
dtitvinf.h
18.459 KB
7 Nov 2019 1.58 PM
root / root
0644
dtptngen.h
25.079 KB
7 Nov 2019 1.58 PM
root / root
0644
dtrule.h
8.624 KB
7 Nov 2019 1.58 PM
root / root
0644
edits.h
20.673 KB
7 Nov 2019 1.58 PM
root / root
0644
enumset.h
2.08 KB
7 Nov 2019 1.58 PM
root / root
0644
errorcode.h
4.779 KB
7 Nov 2019 1.58 PM
root / root
0644
fieldpos.h
8.631 KB
7 Nov 2019 1.58 PM
root / root
0644
filteredbrk.h
5.238 KB
7 Nov 2019 1.58 PM
root / root
0644
fmtable.h
24.361 KB
7 Nov 2019 1.58 PM
root / root
0644
format.h
12.442 KB
7 Nov 2019 1.58 PM
root / root
0644
formattedvalue.h
9.729 KB
7 Nov 2019 1.58 PM
root / root
0644
fpositer.h
2.976 KB
7 Nov 2019 1.58 PM
root / root
0644
gender.h
3.269 KB
7 Nov 2019 1.58 PM
root / root
0644
gregocal.h
31.573 KB
7 Nov 2019 1.58 PM
root / root
0644
icudataver.h
1.026 KB
7 Nov 2019 1.58 PM
root / root
0644
icuplug.h
11.881 KB
7 Nov 2019 1.58 PM
root / root
0644
idna.h
12.635 KB
7 Nov 2019 1.58 PM
root / root
0644
listformatter.h
9.418 KB
7 Nov 2019 1.58 PM
root / root
0644
localebuilder.h
10.539 KB
7 Nov 2019 1.58 PM
root / root
0644
localpointer.h
19.687 KB
7 Nov 2019 1.58 PM
root / root
0644
locdspnm.h
7.062 KB
7 Nov 2019 1.58 PM
root / root
0644
locid.h
44.937 KB
7 Nov 2019 1.58 PM
root / root
0644
measfmt.h
11.436 KB
7 Nov 2019 1.58 PM
root / root
0644
measunit.h
88.167 KB
7 Nov 2019 1.58 PM
root / root
0644
measure.h
4.259 KB
7 Nov 2019 1.58 PM
root / root
0644
messagepattern.h
33.652 KB
7 Nov 2019 1.58 PM
root / root
0644
msgfmt.h
44.042 KB
7 Nov 2019 1.58 PM
root / root
0644
normalizer2.h
33.974 KB
7 Nov 2019 1.58 PM
root / root
0644
normlzr.h
30.738 KB
7 Nov 2019 1.58 PM
root / root
0644
nounit.h
2.63 KB
7 Nov 2019 1.58 PM
root / root
0644
numberformatter.h
84.623 KB
7 Nov 2019 1.58 PM
root / root
0644
numberrangeformatter.h
29.935 KB
7 Nov 2019 1.58 PM
root / root
0644
numfmt.h
49.346 KB
7 Nov 2019 1.58 PM
root / root
0644
numsys.h
7.132 KB
7 Nov 2019 1.58 PM
root / root
0644
parseerr.h
3.081 KB
7 Nov 2019 1.58 PM
root / root
0644
parsepos.h
5.498 KB
7 Nov 2019 1.58 PM
root / root
0644
platform.h
27.104 KB
7 Nov 2019 1.58 PM
root / root
0644
plurfmt.h
25.182 KB
7 Nov 2019 1.58 PM
root / root
0644
plurrule.h
18.334 KB
7 Nov 2019 1.58 PM
root / root
0644
ptypes.h
3.493 KB
7 Nov 2019 1.58 PM
root / root
0644
putil.h
6.335 KB
7 Nov 2019 1.58 PM
root / root
0644
rbbi.h
26.419 KB
7 Nov 2019 1.58 PM
root / root
0644
rbnf.h
49.789 KB
7 Nov 2019 1.58 PM
root / root
0644
rbtz.h
15.467 KB
7 Nov 2019 1.58 PM
root / root
0644
regex.h
84.297 KB
7 Nov 2019 1.58 PM
root / root
0644
region.h
9.123 KB
7 Nov 2019 1.58 PM
root / root
0644
reldatefmt.h
22.373 KB
7 Nov 2019 1.58 PM
root / root
0644
rep.h
9.498 KB
7 Nov 2019 1.58 PM
root / root
0644
resbund.h
18.008 KB
7 Nov 2019 1.58 PM
root / root
0644
schriter.h
6.26 KB
7 Nov 2019 1.58 PM
root / root
0644
scientificnumberformatter.h
6.322 KB
7 Nov 2019 1.58 PM
root / root
0644
search.h
22.209 KB
7 Nov 2019 1.58 PM
root / root
0644
selfmt.h
14.237 KB
7 Nov 2019 1.58 PM
root / root
0644
simpleformatter.h
12.525 KB
7 Nov 2019 1.58 PM
root / root
0644
simpletz.h
45.302 KB
7 Nov 2019 1.58 PM
root / root
0644
smpdtfmt.h
70.896 KB
7 Nov 2019 1.58 PM
root / root
0644
sortkey.h
11.116 KB
7 Nov 2019 1.58 PM
root / root
0644
std_string.h
0.991 KB
7 Nov 2019 1.58 PM
root / root
0644
strenum.h
10.038 KB
7 Nov 2019 1.58 PM
root / root
0644
stringoptions.h
5.787 KB
7 Nov 2019 1.58 PM
root / root
0644
stringpiece.h
6.455 KB
7 Nov 2019 1.58 PM
root / root
0644
stringtriebuilder.h
15.27 KB
7 Nov 2019 1.58 PM
root / root
0644
stsearch.h
21.29 KB
7 Nov 2019 1.58 PM
root / root
0644
symtable.h
4.211 KB
7 Nov 2019 1.58 PM
root / root
0644
tblcoll.h
36.398 KB
7 Nov 2019 1.58 PM
root / root
0644
timezone.h
41.2 KB
7 Nov 2019 1.58 PM
root / root
0644
tmunit.h
3.292 KB
7 Nov 2019 1.58 PM
root / root
0644
tmutamt.h
4.803 KB
7 Nov 2019 1.58 PM
root / root
0644
tmutfmt.h
7.79 KB
7 Nov 2019 1.58 PM
root / root
0644
translit.h
65.761 KB
7 Nov 2019 1.58 PM
root / root
0644
tzfmt.h
42.818 KB
7 Nov 2019 1.58 PM
root / root
0644
tznames.h
16.787 KB
7 Nov 2019 1.58 PM
root / root
0644
tzrule.h
35.322 KB
7 Nov 2019 1.58 PM
root / root
0644
tztrans.h
6.068 KB
7 Nov 2019 1.58 PM
root / root
0644
ubidi.h
89.562 KB
7 Nov 2019 1.58 PM
root / root
0644
ubiditransform.h
12.646 KB
7 Nov 2019 1.58 PM
root / root
0644
ubrk.h
23.972 KB
7 Nov 2019 1.58 PM
root / root
0644
ucal.h
55.543 KB
7 Nov 2019 1.58 PM
root / root
0644
ucasemap.h
15.182 KB
7 Nov 2019 1.58 PM
root / root
0644
ucat.h
5.355 KB
7 Nov 2019 1.58 PM
root / root
0644
uchar.h
140.659 KB
7 Nov 2019 1.58 PM
root / root
0644
ucharstrie.h
21.063 KB
7 Nov 2019 1.58 PM
root / root
0644
ucharstriebuilder.h
7.145 KB
7 Nov 2019 1.58 PM
root / root
0644
uchriter.h
13.142 KB
7 Nov 2019 1.58 PM
root / root
0644
uclean.h
11.205 KB
7 Nov 2019 1.58 PM
root / root
0644
ucnv.h
83.091 KB
7 Nov 2019 1.58 PM
root / root
0644
ucnv_cb.h
6.59 KB
7 Nov 2019 1.58 PM
root / root
0644
ucnv_err.h
20.988 KB
7 Nov 2019 1.58 PM
root / root
0644
ucnvsel.h
6.136 KB
7 Nov 2019 1.58 PM
root / root
0644
ucol.h
61.391 KB
7 Nov 2019 1.58 PM
root / root
0644
ucoleitr.h
9.457 KB
7 Nov 2019 1.58 PM
root / root
0644
uconfig.h
12.049 KB
7 Nov 2019 1.58 PM
root / root
0644
ucpmap.h
5.575 KB
7 Nov 2019 1.58 PM
root / root
0644
ucptrie.h
22.289 KB
7 Nov 2019 1.58 PM
root / root
0644
ucsdet.h
14.666 KB
7 Nov 2019 1.58 PM
root / root
0644
ucurr.h
16.148 KB
7 Nov 2019 1.58 PM
root / root
0644
udat.h
60.808 KB
7 Nov 2019 1.58 PM
root / root
0644
udata.h
15.532 KB
7 Nov 2019 1.58 PM
root / root
0644
udateintervalformat.h
10.031 KB
7 Nov 2019 1.58 PM
root / root
0644
udatpg.h
25.941 KB
7 Nov 2019 1.58 PM
root / root
0644
udisplaycontext.h
5.888 KB
7 Nov 2019 1.58 PM
root / root
0644
uenum.h
7.783 KB
7 Nov 2019 1.58 PM
root / root
0644
ufieldpositer.h
4.356 KB
7 Nov 2019 1.58 PM
root / root
0644
uformattable.h
10.936 KB
7 Nov 2019 1.58 PM
root / root
0644
uformattedvalue.h
12.139 KB
7 Nov 2019 1.58 PM
root / root
0644
ugender.h
2.004 KB
7 Nov 2019 1.58 PM
root / root
0644
uidna.h
33.368 KB
7 Nov 2019 1.58 PM
root / root
0644
uiter.h
22.772 KB
7 Nov 2019 1.58 PM
root / root
0644
uldnames.h
10.451 KB
7 Nov 2019 1.58 PM
root / root
0644
ulistformatter.h
8.831 KB
7 Nov 2019 1.58 PM
root / root
0644
uloc.h
50.753 KB
7 Nov 2019 1.58 PM
root / root
0644
ulocdata.h
11.263 KB
7 Nov 2019 1.58 PM
root / root
0644
umachine.h
13.192 KB
7 Nov 2019 1.58 PM
root / root
0644
umisc.h
1.333 KB
7 Nov 2019 1.58 PM
root / root
0644
umsg.h
24.23 KB
7 Nov 2019 1.58 PM
root / root
0644
umutablecptrie.h
8.278 KB
7 Nov 2019 1.58 PM
root / root
0644
unifilt.h
3.629 KB
7 Nov 2019 1.58 PM
root / root
0644
unifunct.h
3.983 KB
7 Nov 2019 1.58 PM
root / root
0644
unimatch.h
6.039 KB
7 Nov 2019 1.58 PM
root / root
0644
unirepl.h
3.323 KB
7 Nov 2019 1.58 PM
root / root
0644
uniset.h
64.883 KB
7 Nov 2019 1.58 PM
root / root
0644
unistr.h
170.388 KB
7 Nov 2019 1.58 PM
root / root
0644
unorm.h
20.447 KB
7 Nov 2019 1.58 PM
root / root
0644
unorm2.h
24.662 KB
7 Nov 2019 1.58 PM
root / root
0644
unum.h
53.547 KB
7 Nov 2019 1.58 PM
root / root
0644
unumberformatter.h
25.19 KB
7 Nov 2019 1.58 PM
root / root
0644
unumsys.h
7.214 KB
7 Nov 2019 1.58 PM
root / root
0644
uobject.h
10.846 KB
7 Nov 2019 1.58 PM
root / root
0644
upluralrules.h
7.879 KB
7 Nov 2019 1.58 PM
root / root
0644
uregex.h
72.055 KB
7 Nov 2019 1.58 PM
root / root
0644
uregion.h
9.837 KB
7 Nov 2019 1.58 PM
root / root
0644
ureldatefmt.h
17.256 KB
7 Nov 2019 1.58 PM
root / root
0644
urename.h
131.397 KB
7 Nov 2019 1.58 PM
root / root
0644
urep.h
5.378 KB
7 Nov 2019 1.58 PM
root / root
0644
ures.h
36.538 KB
7 Nov 2019 1.58 PM
root / root
0644
uscript.h
26.865 KB
7 Nov 2019 1.58 PM
root / root
0644
usearch.h
38.123 KB
7 Nov 2019 1.58 PM
root / root
0644
uset.h
39.998 KB
7 Nov 2019 1.58 PM
root / root
0644
usetiter.h
9.491 KB
7 Nov 2019 1.58 PM
root / root
0644
ushape.h
18 KB
7 Nov 2019 1.58 PM
root / root
0644
uspoof.h
66.028 KB
7 Nov 2019 1.58 PM
root / root
0644
usprep.h
8.136 KB
7 Nov 2019 1.58 PM
root / root
0644
ustdio.h
38.544 KB
7 Nov 2019 1.58 PM
root / root
0644
ustream.h
1.801 KB
7 Nov 2019 1.58 PM
root / root
0644
ustring.h
72.472 KB
7 Nov 2019 1.58 PM
root / root
0644
ustringtrie.h
3.148 KB
7 Nov 2019 1.58 PM
root / root
0644
utext.h
58.11 KB
7 Nov 2019 1.58 PM
root / root
0644
utf.h
7.857 KB
7 Nov 2019 1.58 PM
root / root
0644
utf16.h
22.33 KB
7 Nov 2019 1.58 PM
root / root
0644
utf32.h
0.745 KB
7 Nov 2019 1.58 PM
root / root
0644
utf8.h
29.963 KB
7 Nov 2019 1.58 PM
root / root
0644
utf_old.h
43.776 KB
7 Nov 2019 1.58 PM
root / root
0644
utmscale.h
13.782 KB
7 Nov 2019 1.58 PM
root / root
0644
utrace.h
13.886 KB
7 Nov 2019 1.58 PM
root / root
0644
utrans.h
25.544 KB
7 Nov 2019 1.58 PM
root / root
0644
utypes.h
30.379 KB
7 Nov 2019 1.58 PM
root / root
0644
uvernum.h
6.672 KB
7 Nov 2019 1.58 PM
root / root
0644
uversion.h
6.704 KB
7 Nov 2019 1.58 PM
root / root
0644
vtzone.h
20.167 KB
7 Nov 2019 1.58 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF