ICU-65 Add support for 1:00u and 1:00s rule times
X-SVN-Rev: 279
This commit is contained in:
parent
e52c4359b4
commit
e5b179f2e6
@ -16,6 +16,8 @@
|
||||
* numerous feature enhancements and bug fixes.
|
||||
* 08/10/98 stephen JDK 1.2 sync.
|
||||
* 09/17/98 stephen Fixed getOffset() for last hour of year and DST
|
||||
* 12/02/99 aliu Added TimeMode and constructor and setStart/EndRule
|
||||
* methods that take TimeMode. Whitespace cleanup.
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
@ -29,7 +31,7 @@ char SimpleTimeZone::fgClassID = 0; // Value is irrelevant
|
||||
// since we don't handle leap years. Could handle assuming always
|
||||
// Gregorian, since we know they didn't have daylight time when
|
||||
// Gregorian calendar started.
|
||||
const int32_t SimpleTimeZone::staticMonthLength[] = {31,28,31,30,31,30,31,31,30,31,30,31};
|
||||
const int8_t SimpleTimeZone::staticMonthLength[] = {31,28,31,30,31,30,31,31,30,31,30,31};
|
||||
|
||||
// *****************************************************************************
|
||||
// class SimpleTimeZone
|
||||
@ -42,10 +44,12 @@ SimpleTimeZone::SimpleTimeZone(int32_t rawOffset, const UnicodeString& ID)
|
||||
startDay(0),
|
||||
startDayOfWeek(0),
|
||||
startTime(0),
|
||||
startTimeMode(WALL_TIME),
|
||||
endMonth(0),
|
||||
endDay(0),
|
||||
endDayOfWeek(0),
|
||||
endTime(0),
|
||||
endTimeMode(WALL_TIME),
|
||||
startYear(0),
|
||||
dstSavings(U_MILLIS_PER_HOUR),
|
||||
startMode(DOM_MODE),
|
||||
@ -62,24 +66,13 @@ SimpleTimeZone::SimpleTimeZone(int32_t rawOffset, const UnicodeString& ID,
|
||||
int8_t startDayOfWeek, int32_t startTime,
|
||||
int8_t endMonth, int8_t endDay,
|
||||
int8_t endDayOfWeek, int32_t endTime,
|
||||
UErrorCode& status)
|
||||
: startYear(0)
|
||||
{
|
||||
setID(ID);
|
||||
this->rawOffset = rawOffset;
|
||||
this->startMonth = startMonth;
|
||||
this->startDay = startDay;
|
||||
this->startDayOfWeek= startDayOfWeek;
|
||||
this->startTime = startTime;
|
||||
this->endMonth = endMonth;
|
||||
this->endDay = endDay;
|
||||
this->endDayOfWeek = endDayOfWeek;
|
||||
this->endTime = endTime;
|
||||
this->dstSavings = U_MILLIS_PER_HOUR;
|
||||
this->startMode = DOM_MODE;
|
||||
this->endMode = DOM_MODE;
|
||||
|
||||
decodeRules(status);
|
||||
UErrorCode& status) {
|
||||
construct(rawOffset, ID,
|
||||
startMonth, startDay, startDayOfWeek,
|
||||
startTime, WALL_TIME,
|
||||
endMonth, endDay, endDayOfWeek,
|
||||
endTime, WALL_TIME,
|
||||
U_MILLIS_PER_HOUR, status);
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
@ -89,26 +82,61 @@ SimpleTimeZone::SimpleTimeZone(int32_t rawOffset, const UnicodeString& ID,
|
||||
int8_t startDayOfWeek, int32_t startTime,
|
||||
int8_t endMonth, int8_t endDay,
|
||||
int8_t endDayOfWeek, int32_t endTime,
|
||||
int32_t dstSavings, UErrorCode& status)
|
||||
: startYear(0)
|
||||
{
|
||||
setID(ID);
|
||||
this->rawOffset = rawOffset;
|
||||
int32_t dstSavings, UErrorCode& status) {
|
||||
construct(rawOffset, ID,
|
||||
startMonth, startDay, startDayOfWeek,
|
||||
startTime, WALL_TIME,
|
||||
endMonth, endDay, endDayOfWeek,
|
||||
endTime, WALL_TIME,
|
||||
dstSavings, status);
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
|
||||
SimpleTimeZone::SimpleTimeZone(int32_t rawOffset, const UnicodeString& ID,
|
||||
int8_t startMonth, int8_t startDay,
|
||||
int8_t startDayOfWeek, int32_t startTime, TimeMode startTimeMode,
|
||||
int8_t endMonth, int8_t endDay,
|
||||
int8_t endDayOfWeek, int32_t endTime, TimeMode endTimeMode,
|
||||
int32_t dstSavings, UErrorCode& status) {
|
||||
construct(rawOffset, ID,
|
||||
startMonth, startDay, startDayOfWeek,
|
||||
startTime, startTimeMode,
|
||||
endMonth, endDay, endDayOfWeek,
|
||||
endTime, endTimeMode,
|
||||
dstSavings, status);
|
||||
}
|
||||
|
||||
/**
|
||||
* Internal construction method.
|
||||
*/
|
||||
void SimpleTimeZone::construct(int32_t rawOffset, const UnicodeString& ID,
|
||||
int8_t startMonth, int8_t startDay, int8_t startDayOfWeek,
|
||||
int32_t startTime, TimeMode startTimeMode,
|
||||
int8_t endMonth, int8_t endDay, int8_t endDayOfWeek,
|
||||
int32_t endTime, TimeMode endTimeMode,
|
||||
int32_t dstSavings, UErrorCode& status) {
|
||||
this->rawOffset = rawOffset;
|
||||
this->startMonth = startMonth;
|
||||
this->startDay = startDay;
|
||||
this->startDayOfWeek= startDayOfWeek;
|
||||
this->startTime = startTime;
|
||||
this->endMonth = endMonth;
|
||||
this->startDay = startDay;
|
||||
this->startDayOfWeek = startDayOfWeek;
|
||||
this->startTime = startTime;
|
||||
this->startTimeMode = startTimeMode;
|
||||
this->endMonth = endMonth;
|
||||
this->endDay = endDay;
|
||||
this->endDayOfWeek = endDayOfWeek;
|
||||
this->endTime = endTime;
|
||||
this->endDayOfWeek = endDayOfWeek;
|
||||
this->endTime = endTime;
|
||||
this->endTimeMode = endTimeMode;
|
||||
this->dstSavings = dstSavings;
|
||||
|
||||
setID(ID);
|
||||
this->startYear = 0;
|
||||
this->startMode = DOM_MODE;
|
||||
this->endMode = DOM_MODE;
|
||||
|
||||
decodeRules(status);
|
||||
|
||||
if(dstSavings <= 0) {
|
||||
if (dstSavings <= 0) {
|
||||
status = U_ILLEGAL_ARGUMENT_ERROR;
|
||||
}
|
||||
}
|
||||
@ -136,20 +164,22 @@ SimpleTimeZone::operator=(const SimpleTimeZone &right)
|
||||
if (this != &right)
|
||||
{
|
||||
TimeZone::operator=(right);
|
||||
rawOffset = right.rawOffset;
|
||||
startMonth = right.startMonth;
|
||||
startDay = right.startDay;
|
||||
startDayOfWeek = right.startDayOfWeek;
|
||||
startTime = right.startTime;
|
||||
startMode = right.startMode;
|
||||
endMonth = right.endMonth;
|
||||
endDay = right.endDay;
|
||||
endDayOfWeek = right.endDayOfWeek;
|
||||
endTime = right.endTime;
|
||||
endMode = right.endMode;
|
||||
startYear = right.startYear;
|
||||
dstSavings = right.dstSavings;
|
||||
useDaylight = right.useDaylight;
|
||||
rawOffset = right.rawOffset;
|
||||
startMonth = right.startMonth;
|
||||
startDay = right.startDay;
|
||||
startDayOfWeek = right.startDayOfWeek;
|
||||
startTime = right.startTime;
|
||||
startTimeMode = right.startTimeMode;
|
||||
startMode = right.startMode;
|
||||
endMonth = right.endMonth;
|
||||
endDay = right.endDay;
|
||||
endDayOfWeek = right.endDayOfWeek;
|
||||
endTime = right.endTime;
|
||||
endTimeMode = right.endTimeMode;
|
||||
endMode = right.endMode;
|
||||
startYear = right.startYear;
|
||||
dstSavings = right.dstSavings;
|
||||
useDaylight = right.useDaylight;
|
||||
}
|
||||
return *this;
|
||||
}
|
||||
@ -234,12 +264,13 @@ SimpleTimeZone::setStartYear(int32_t year)
|
||||
|
||||
void
|
||||
SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayOfWeek,
|
||||
int32_t time, UErrorCode& status)
|
||||
int32_t time, TimeMode mode, UErrorCode& status)
|
||||
{
|
||||
startMonth = month;
|
||||
startDay = dayOfWeekInMonth;
|
||||
startDayOfWeek = dayOfWeek;
|
||||
startTime = time;
|
||||
startMonth = (int8_t)month;
|
||||
startDay = (int8_t)dayOfWeekInMonth;
|
||||
startDayOfWeek = (int8_t)dayOfWeek;
|
||||
startTime = time;
|
||||
startTimeMode = mode;
|
||||
decodeStartRule(status);
|
||||
}
|
||||
|
||||
@ -247,21 +278,19 @@ SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfWeekInMonth, int32_t da
|
||||
|
||||
void
|
||||
SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfMonth,
|
||||
int32_t time, UErrorCode& status)
|
||||
int32_t time, TimeMode mode, UErrorCode& status)
|
||||
{
|
||||
setStartRule(month, dayOfMonth, 0, time, status);
|
||||
setStartRule(month, dayOfMonth, 0, time, mode, status);
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
|
||||
void
|
||||
SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, bool_t after, UErrorCode& status)
|
||||
int32_t time, TimeMode mode, bool_t after, UErrorCode& status)
|
||||
{
|
||||
if (after)
|
||||
setStartRule(month, dayOfMonth, -dayOfWeek, time, status);
|
||||
else
|
||||
setStartRule(month, -dayOfMonth, -dayOfWeek, time, status);
|
||||
setStartRule(month, after ? dayOfMonth : -dayOfMonth,
|
||||
-dayOfWeek, time, mode, status);
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
@ -286,12 +315,13 @@ SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWee
|
||||
|
||||
void
|
||||
SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayOfWeek,
|
||||
int32_t time, UErrorCode& status)
|
||||
int32_t time, TimeMode mode, UErrorCode& status)
|
||||
{
|
||||
endMonth = month;
|
||||
endDay = dayOfWeekInMonth;
|
||||
endDayOfWeek= dayOfWeek;
|
||||
endTime = time;
|
||||
endMonth = (int8_t)month;
|
||||
endDay = (int8_t)dayOfWeekInMonth;
|
||||
endDayOfWeek = (int8_t)dayOfWeek;
|
||||
endTime = time;
|
||||
endTimeMode = mode;
|
||||
decodeEndRule(status);
|
||||
}
|
||||
|
||||
@ -299,21 +329,19 @@ SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayO
|
||||
|
||||
void
|
||||
SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfMonth,
|
||||
int32_t time, UErrorCode& status)
|
||||
int32_t time, TimeMode mode, UErrorCode& status)
|
||||
{
|
||||
setEndRule(month, dayOfMonth, 0, time, status);
|
||||
setEndRule(month, dayOfMonth, 0, time, mode, status);
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
|
||||
void
|
||||
SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, bool_t after, UErrorCode& status)
|
||||
int32_t time, TimeMode mode, bool_t after, UErrorCode& status)
|
||||
{
|
||||
if (after)
|
||||
setEndRule(month, dayOfMonth, -dayOfWeek, time, status);
|
||||
else
|
||||
setEndRule(month, -dayOfMonth, -dayOfWeek, time, status);
|
||||
setEndRule(month, after ? dayOfMonth : -dayOfMonth,
|
||||
-dayOfWeek, time, mode, status);
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
@ -349,8 +377,33 @@ SimpleTimeZone::getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
|
||||
int32_t
|
||||
SimpleTimeZone::getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
uint8_t dayOfWeek, int32_t millis,
|
||||
int32_t monthLength, UErrorCode& status) const
|
||||
uint8_t dayOfWeek, int32_t millis,
|
||||
int32_t monthLength, UErrorCode& status) const {
|
||||
// Check the month before indexing into staticMonthLength. This
|
||||
// duplicates a test that occurs in the 9-argument getOffset(),
|
||||
// however, this is unavoidable. We don't mind because this method, in
|
||||
// fact, should not be called; internal code should always call the
|
||||
// 9-argument getOffset(), and outside code should use Calendar.get(int
|
||||
// field) with fields ZONE_OFFSET and DST_OFFSET. We can't get rid of
|
||||
// this method because it's public API. - liu 8/10/98
|
||||
if (month < Calendar::JANUARY
|
||||
|| month > Calendar::DECEMBER) {
|
||||
status = U_ILLEGAL_ARGUMENT_ERROR;
|
||||
return -1;
|
||||
}
|
||||
|
||||
// TODO FIX We don't handle leap years yet!
|
||||
int32_t prevMonthLength = (month >= 1) ? staticMonthLength[month - 1] : 31;
|
||||
|
||||
return getOffset(era, year, month, day, dayOfWeek, millis,
|
||||
monthLength, prevMonthLength, status);
|
||||
}
|
||||
|
||||
int32_t
|
||||
SimpleTimeZone::getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
uint8_t dayOfWeek, int32_t millis,
|
||||
int32_t monthLength, int32_t prevMonthLength,
|
||||
UErrorCode& status) const
|
||||
{
|
||||
if(U_FAILURE(status)) return 0;
|
||||
|
||||
@ -381,9 +434,11 @@ SimpleTimeZone::getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
|
||||
// Compare the date to the starting and ending rules.+1 = date>rule, -1
|
||||
// = date<rule, 0 = date==rule.
|
||||
int32_t startCompare = compareToRule(month, monthLength, day, dayOfWeek, millis,
|
||||
startMode, startMonth, startDayOfWeek,
|
||||
startDay, startTime);
|
||||
int32_t startCompare = compareToRule((int8_t)month, (int8_t)monthLength, (int8_t)prevMonthLength,
|
||||
(int8_t)day, (int8_t)dayOfWeek, millis,
|
||||
startTimeMode == UTC_TIME ? -rawOffset : 0,
|
||||
startMode, (int8_t)startMonth, (int8_t)startDayOfWeek,
|
||||
(int8_t)startDay, startTime);
|
||||
int32_t endCompare = 0;
|
||||
|
||||
/* We don't always have to compute endCompare. For many instances,
|
||||
@ -393,22 +448,12 @@ SimpleTimeZone::getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
* must have DST. This is reflected in the way the next if statement
|
||||
* (not the one immediately following) short circuits. */
|
||||
if(southern != (startCompare >= 0)) {
|
||||
/* For the ending rule comparison, we add the dstSavings to the millis
|
||||
* passed in to convert them from standard to wall time. We then must
|
||||
* normalize the millis to the range 0..millisPerDay-1. */
|
||||
millis += dstSavings; // Assume dstSavings > 0
|
||||
while(millis >= U_MILLIS_PER_DAY) {
|
||||
millis -= U_MILLIS_PER_DAY;
|
||||
++day;
|
||||
dayOfWeek = 1 + (dayOfWeek % 7); // Assume dayOfWeek is one-based
|
||||
if (day > monthLength) {
|
||||
day = 1;
|
||||
++month;
|
||||
}
|
||||
}
|
||||
endCompare = compareToRule(month, monthLength, day, dayOfWeek, millis,
|
||||
endMode, endMonth, endDayOfWeek,
|
||||
endDay, endTime);
|
||||
endCompare = compareToRule((int8_t)month, (int8_t)monthLength, (int8_t)prevMonthLength,
|
||||
(int8_t)day, (int8_t)dayOfWeek, millis,
|
||||
endTimeMode == WALL_TIME ? dstSavings :
|
||||
(endTimeMode == UTC_TIME ? -rawOffset : 0),
|
||||
endMode, (int8_t)endMonth, (int8_t)endDayOfWeek,
|
||||
(int8_t)endDay, endTime);
|
||||
}
|
||||
|
||||
// Check for both the northern and southern hemisphere cases. We
|
||||
@ -434,11 +479,37 @@ SimpleTimeZone::getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
* the rule date, or 0 if the date is equal to the rule date.
|
||||
*/
|
||||
int32_t
|
||||
SimpleTimeZone::compareToRule(int32_t month, int32_t monthLen, int32_t dayOfMonth,
|
||||
int32_t dayOfWeek, int32_t millis,
|
||||
EMode ruleMode, int32_t ruleMonth, int32_t ruleDayOfWeek,
|
||||
int32_t ruleDay, int32_t ruleMillis)
|
||||
SimpleTimeZone::compareToRule(int8_t month, int8_t monthLen, int8_t prevMonthLen,
|
||||
int8_t dayOfMonth,
|
||||
int8_t dayOfWeek, int32_t millis, int32_t millisDelta,
|
||||
EMode ruleMode, int8_t ruleMonth, int8_t ruleDayOfWeek,
|
||||
int8_t ruleDay, int32_t ruleMillis)
|
||||
{
|
||||
// Make adjustments for startTimeMode and endTimeMode
|
||||
millis += millisDelta;
|
||||
while (millis >= U_MILLIS_PER_DAY) {
|
||||
millis -= U_MILLIS_PER_DAY;
|
||||
++dayOfMonth;
|
||||
dayOfWeek = 1 + (dayOfWeek % 7); // dayOfWeek is one-based
|
||||
if (dayOfMonth > monthLen) {
|
||||
dayOfMonth = 1;
|
||||
/* When incrementing the month, it is desirible to overflow
|
||||
* from DECEMBER to DECEMBER+1, since we use the result to
|
||||
* compare against a real month. Wraparound of the value
|
||||
* leads to bug 4173604. */
|
||||
++month;
|
||||
}
|
||||
}
|
||||
while (millis < 0) {
|
||||
millis += U_MILLIS_PER_DAY;
|
||||
--dayOfMonth;
|
||||
dayOfWeek = 1 + ((dayOfWeek+5) % 7); // dayOfWeek is one-based
|
||||
if (dayOfMonth < 1) {
|
||||
dayOfMonth = prevMonthLen;
|
||||
--month;
|
||||
}
|
||||
}
|
||||
|
||||
// first compare months. If they're different, we don't have to worry about days
|
||||
// and times
|
||||
if (month < ruleMonth) return -1;
|
||||
@ -589,17 +660,19 @@ SimpleTimeZone::hasSameRules(const TimeZone& other) const
|
||||
(!useDaylight
|
||||
// Only check rules if using DST
|
||||
|| (dstSavings == that->dstSavings &&
|
||||
startMode == that->startMode &&
|
||||
startMode == that->startMode &&
|
||||
startMonth == that->startMonth &&
|
||||
startDay == that->startDay &&
|
||||
startDay == that->startDay &&
|
||||
startDayOfWeek == that->startDayOfWeek &&
|
||||
startTime == that->startTime &&
|
||||
endMode == that->endMode &&
|
||||
endMonth == that->endMonth &&
|
||||
startTime == that->startTime &&
|
||||
startTimeMode == that->startTimeMode &&
|
||||
endMode == that->endMode &&
|
||||
endMonth == that->endMonth &&
|
||||
endDay == that->endDay &&
|
||||
endDayOfWeek == that->endDayOfWeek &&
|
||||
endTime == that->endTime &&
|
||||
startYear == that->startYear));
|
||||
endDayOfWeek == that->endDayOfWeek &&
|
||||
endTime == that->endTime &&
|
||||
endTimeMode == that->endTimeMode &&
|
||||
startYear == that->startYear));
|
||||
}
|
||||
|
||||
// -------------------------------------
|
||||
@ -709,7 +782,8 @@ SimpleTimeZone::decodeStartRule(UErrorCode& status)
|
||||
status = U_ILLEGAL_ARGUMENT_ERROR;
|
||||
return;
|
||||
}
|
||||
if (startTime < 0 || startTime > U_MILLIS_PER_DAY) {
|
||||
if (startTime < 0 || startTime > U_MILLIS_PER_DAY ||
|
||||
startTimeMode < WALL_TIME || startTimeMode > UTC_TIME) {
|
||||
status = U_ILLEGAL_ARGUMENT_ERROR;
|
||||
return;
|
||||
}
|
||||
@ -760,7 +834,8 @@ SimpleTimeZone::decodeEndRule(UErrorCode& status)
|
||||
status = U_ILLEGAL_ARGUMENT_ERROR;
|
||||
return;
|
||||
}
|
||||
if (endTime < 0 || endTime > U_MILLIS_PER_DAY) {
|
||||
if (endTime < 0 || endTime > U_MILLIS_PER_DAY ||
|
||||
endTimeMode < WALL_TIME || endTimeMode > UTC_TIME) {
|
||||
status = U_ILLEGAL_ARGUMENT_ERROR;
|
||||
return;
|
||||
}
|
||||
|
@ -15,6 +15,8 @@
|
||||
* 09/02/98 stephen Added getOffset(monthLen)
|
||||
* Changed getOffset() to take UErrorCode
|
||||
* 07/09/99 stephen Removed millisPerHour (unused, for HP compiler)
|
||||
* 12/02/99 aliu Added TimeMode and constructor and setStart/EndRule
|
||||
* methods that take TimeMode. Added to docs.
|
||||
********************************************************************************
|
||||
*/
|
||||
|
||||
@ -37,12 +39,27 @@
|
||||
* @see Calendar
|
||||
* @see GregorianCalendar
|
||||
* @see TimeZone
|
||||
* @version 1.24 10/30/97
|
||||
* @author David Goldsmith, Mark Davis, Chen-Lieh Huang, Alan Liu
|
||||
*/
|
||||
class U_I18N_API SimpleTimeZone: public TimeZone {
|
||||
public:
|
||||
|
||||
/**
|
||||
* TimeMode is used, together with a millisecond offset after
|
||||
* midnight, to specify a rule transition time. Most rules
|
||||
* transition at a local wall time, that is, according to the
|
||||
* current time in effect, either standard, or DST. However, some
|
||||
* rules transition at local standard time, and some at a specific
|
||||
* UTC time. Although it might seem that all times could be
|
||||
* converted to wall time, thus eliminating the need for this
|
||||
* parameter, this is not the case.
|
||||
*/
|
||||
enum TimeMode {
|
||||
WALL_TIME = 0,
|
||||
STANDARD_TIME,
|
||||
UTC_TIME
|
||||
};
|
||||
|
||||
/**
|
||||
* Copy constructor
|
||||
*/
|
||||
@ -104,6 +121,8 @@ public:
|
||||
* for a complete explanation.
|
||||
* @param startTime The daylight savings starting time, expressed as the
|
||||
* number of milliseconds after midnight.
|
||||
* @param startTimeMode Whether the start time is local wall time, local
|
||||
* standard time, or UTC time. Default is local wall time.
|
||||
* @param endMonth The daylight savings ending month. Month is
|
||||
* 0-based. eg, 0 for January.
|
||||
* @param endDay The daylight savings ending day-of-week-in-month.
|
||||
@ -112,6 +131,10 @@ public:
|
||||
* for a complete explanation.
|
||||
* @param endTime The daylight savings ending time, expressed as the
|
||||
* number of milliseconds after midnight.
|
||||
* @param endTimeMode Whether the end time is local wall time, local
|
||||
* standard time, or UTC time. Default is local wall time.
|
||||
* @param dstSavings The number of milliseconds added to standard time
|
||||
* to get DST time. Default is one hour.
|
||||
* @param status An UErrorCode to receive the status.
|
||||
*/
|
||||
SimpleTimeZone(int32_t rawOffset, const UnicodeString& ID,
|
||||
@ -128,6 +151,13 @@ public:
|
||||
int8_t endDayOfWeek, int32_t endTime,
|
||||
int32_t dstSavings, UErrorCode& status);
|
||||
|
||||
SimpleTimeZone(int32_t rawOffset, const UnicodeString& ID,
|
||||
int8_t startMonth, int8_t startDayOfWeekInMonth,
|
||||
int8_t startDayOfWeek, int32_t startTime, TimeMode startTimeMode,
|
||||
int8_t endMonth, int8_t endDayOfWeekInMonth,
|
||||
int8_t endDayOfWeek, int32_t endTime, TimeMode endTimeMode,
|
||||
int32_t dstSavings, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Sets the daylight savings starting year, that is, the year this time zone began
|
||||
* observing its specified daylight savings time rules. The time zone is considered
|
||||
@ -174,10 +204,15 @@ public:
|
||||
* the member description for an example.
|
||||
* @param time the daylight savings starting time. Please see the member
|
||||
* description for an example.
|
||||
* @param mode whether the time is local wall time, local standard time,
|
||||
* or UTC time. Default is local wall time.
|
||||
* @param status An UErrorCode
|
||||
*/
|
||||
void setStartRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayOfWeek,
|
||||
int32_t time, UErrorCode& status);
|
||||
int32_t time, UErrorCode& status);
|
||||
|
||||
void setStartRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayOfWeek,
|
||||
int32_t time, TimeMode mode, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Sets the DST start rule to a fixed date within a month.
|
||||
@ -187,10 +222,15 @@ public:
|
||||
* @param time The time of that day (number of millis after midnight)
|
||||
* when DST takes effect in local wall time, which is
|
||||
* standard time in this case.
|
||||
* @param mode whether the time is local wall time, local standard time,
|
||||
* or UTC time. Default is local wall time.
|
||||
* @param status An UErrorCode
|
||||
*/
|
||||
void setStartRule(int32_t month, int32_t dayOfMonth, int32_t time,
|
||||
UErrorCode& status);
|
||||
UErrorCode& status);
|
||||
|
||||
void setStartRule(int32_t month, int32_t dayOfMonth, int32_t time,
|
||||
TimeMode mode, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Sets the DST start rule to a weekday before or after a give date within
|
||||
@ -202,13 +242,18 @@ public:
|
||||
* @param time The time of that day (number of millis after midnight)
|
||||
* when DST takes effect in local wall time, which is
|
||||
* standard time in this case.
|
||||
* @param mode whether the time is local wall time, local standard time,
|
||||
* or UTC time. Default is local wall time.
|
||||
* @param after If true, this rule selects the first dayOfWeek on
|
||||
* or after dayOfMonth. If false, this rule selects
|
||||
* the last dayOfWeek on or before dayOfMonth.
|
||||
* @param status An UErrorCode
|
||||
*/
|
||||
void setStartRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, bool_t after, UErrorCode& status);
|
||||
int32_t time, bool_t after, UErrorCode& status);
|
||||
|
||||
void setStartRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, TimeMode mode, bool_t after, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Sets the daylight savings ending rule. For example, in the U.S., Daylight
|
||||
@ -229,10 +274,15 @@ public:
|
||||
* for a complete explanation.
|
||||
* @param time the daylight savings ending time. Please see the member
|
||||
* description for an example.
|
||||
* @param mode whether the time is local wall time, local standard time,
|
||||
* or UTC time. Default is local wall time.
|
||||
* @param status An UErrorCode
|
||||
*/
|
||||
void setEndRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayOfWeek,
|
||||
int32_t time, UErrorCode& status);
|
||||
int32_t time, UErrorCode& status);
|
||||
|
||||
void setEndRule(int32_t month, int32_t dayOfWeekInMonth, int32_t dayOfWeek,
|
||||
int32_t time, TimeMode mode, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Sets the DST end rule to a fixed date within a month.
|
||||
@ -242,10 +292,15 @@ public:
|
||||
* @param time The time of that day (number of millis after midnight)
|
||||
* when DST ends in local wall time, which is daylight
|
||||
* time in this case.
|
||||
* @param mode whether the time is local wall time, local standard time,
|
||||
* or UTC time. Default is local wall time.
|
||||
* @param status An UErrorCode
|
||||
*/
|
||||
void setEndRule(int32_t month, int32_t dayOfMonth, int32_t time, UErrorCode& status);
|
||||
|
||||
void setEndRule(int32_t month, int32_t dayOfMonth, int32_t time,
|
||||
TimeMode mode, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Sets the DST end rule to a weekday before or after a give date within
|
||||
* a month, e.g., the first Monday on or after the 8th.
|
||||
@ -256,13 +311,18 @@ public:
|
||||
* @param time The time of that day (number of millis after midnight)
|
||||
* when DST ends in local wall time, which is daylight
|
||||
* time in this case.
|
||||
* @param mode whether the time is local wall time, local standard time,
|
||||
* or UTC time. Default is local wall time.
|
||||
* @param after If true, this rule selects the first dayOfWeek on
|
||||
* or after dayOfMonth. If false, this rule selects
|
||||
* the last dayOfWeek on or before dayOfMonth.
|
||||
* @param status An UErrorCode
|
||||
*/
|
||||
void setEndRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, bool_t after, UErrorCode& status);
|
||||
int32_t time, bool_t after, UErrorCode& status);
|
||||
|
||||
void setEndRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, TimeMode mode, bool_t after, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Returns the TimeZone's adjusted GMT offset (i.e., the number of milliseconds to add
|
||||
@ -299,12 +359,18 @@ public:
|
||||
* @param dayOfWeek the day-of-week of the given date.
|
||||
* @param milliseconds the millis in day in <em>standard</em> local time.
|
||||
* @param monthLength the length of the given month in days.
|
||||
* @param prevMonthLength length of the previous month in days.
|
||||
* @return the offset to add *to* GMT to get local time.
|
||||
*/
|
||||
virtual int32_t getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
uint8_t dayOfWeek, int32_t milliseconds,
|
||||
int32_t monthLength, UErrorCode& status) const;
|
||||
|
||||
virtual int32_t getOffset(uint8_t era, int32_t year, int32_t month, int32_t day,
|
||||
uint8_t dayOfWeek, int32_t milliseconds,
|
||||
int32_t monthLength, int32_t prevMonthLength,
|
||||
UErrorCode& status) const;
|
||||
|
||||
/**
|
||||
* Returns the TimeZone's raw GMT offset (i.e., the number of milliseconds to add
|
||||
* to GMT to get local time, before taking daylight savings time into account).
|
||||
@ -409,6 +475,16 @@ private:
|
||||
DOW_LE_DOM_MODE
|
||||
};
|
||||
|
||||
/**
|
||||
* Internal construction method.
|
||||
*/
|
||||
void construct(int32_t rawOffset, const UnicodeString& ID,
|
||||
int8_t startMonth, int8_t startDay, int8_t startDayOfWeek,
|
||||
int32_t startTime, TimeMode startTimeMode,
|
||||
int8_t endMonth, int8_t endDay, int8_t endDayOfWeek,
|
||||
int32_t endTime, TimeMode endTimeMode,
|
||||
int32_t dstSavings, UErrorCode& status);
|
||||
|
||||
/**
|
||||
* Compare a given date in the year to a rule. Return 1, 0, or -1, depending
|
||||
* on whether the date is after, equal to, or before the rule date. The
|
||||
@ -418,10 +494,11 @@ private:
|
||||
* @return 1 if the date is after the rule date, -1 if the date is before
|
||||
* the rule date, or 0 if the date is equal to the rule date.
|
||||
*/
|
||||
static int32_t compareToRule(int32_t month, int32_t monthLen, int32_t dayOfMonth,
|
||||
int32_t dayOfWeek, int32_t millis,
|
||||
EMode ruleMode, int32_t ruleMonth, int32_t ruleDayOfWeek,
|
||||
int32_t ruleDay, int32_t ruleMillis);
|
||||
static int32_t compareToRule(int8_t month, int8_t monthLen, int8_t prevMonthLen,
|
||||
int8_t dayOfMonth,
|
||||
int8_t dayOfWeek, int32_t millis, int32_t millisDelta,
|
||||
EMode ruleMode, int8_t ruleMonth, int8_t ruleDayOfWeek,
|
||||
int8_t ruleDay, int32_t ruleMillis);
|
||||
|
||||
/**
|
||||
* Given a set of encoded rules in startDay and startDayOfMonth, decode
|
||||
@ -444,14 +521,15 @@ private:
|
||||
|
||||
static char fgClassID;
|
||||
|
||||
int32_t startMonth, startDay, startDayOfWeek; // the month, day, DOW, and time DST starts
|
||||
int8_t startMonth, startDay, startDayOfWeek; // the month, day, DOW, and time DST starts
|
||||
int32_t startTime;
|
||||
int32_t endMonth, endDay, endDayOfWeek; // the month, day, DOW, and time DST ends
|
||||
TimeMode startTimeMode, endTimeMode; // Mode for startTime, endTime; see TimeMode
|
||||
int8_t endMonth, endDay, endDayOfWeek; // the month, day, DOW, and time DST ends
|
||||
int32_t endTime;
|
||||
int32_t startYear; // the year these DST rules took effect
|
||||
int32_t rawOffset; // the TimeZone's raw GMT offset
|
||||
bool_t useDaylight; // flag indicating whether this TimeZone uses DST
|
||||
static const int32_t staticMonthLength[12]; // lengths of the months
|
||||
static const int8_t staticMonthLength[12]; // lengths of the months
|
||||
EMode startMode, endMode; // flags indicating what kind of rules the DST rules are
|
||||
|
||||
/**
|
||||
@ -461,4 +539,38 @@ private:
|
||||
int32_t dstSavings;
|
||||
};
|
||||
|
||||
inline void SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfWeekInMonth,
|
||||
int32_t dayOfWeek,
|
||||
int32_t time, UErrorCode& status) {
|
||||
setStartRule(month, dayOfWeekInMonth, dayOfWeek, time, WALL_TIME, status);
|
||||
}
|
||||
|
||||
inline void SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfMonth,
|
||||
int32_t time,
|
||||
UErrorCode& status) {
|
||||
setStartRule(month, dayOfMonth, time, WALL_TIME, status);
|
||||
}
|
||||
|
||||
inline void SimpleTimeZone::setStartRule(int32_t month, int32_t dayOfMonth,
|
||||
int32_t dayOfWeek,
|
||||
int32_t time, bool_t after, UErrorCode& status) {
|
||||
setStartRule(month, dayOfMonth, dayOfWeek, time, WALL_TIME, after, status);
|
||||
}
|
||||
|
||||
inline void SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfWeekInMonth,
|
||||
int32_t dayOfWeek,
|
||||
int32_t time, UErrorCode& status) {
|
||||
setEndRule(month, dayOfWeekInMonth, dayOfWeek, time, WALL_TIME, status);
|
||||
}
|
||||
|
||||
inline void SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfMonth,
|
||||
int32_t time, UErrorCode& status) {
|
||||
setEndRule(month, dayOfMonth, time, WALL_TIME, status);
|
||||
}
|
||||
|
||||
inline void SimpleTimeZone::setEndRule(int32_t month, int32_t dayOfMonth, int32_t dayOfWeek,
|
||||
int32_t time, bool_t after, UErrorCode& status) {
|
||||
setEndRule(month, dayOfMonth, dayOfWeek, time, WALL_TIME, after, status);
|
||||
}
|
||||
|
||||
#endif // _SIMPLETZ
|
||||
|
Loading…
Reference in New Issue
Block a user