2009-12-08 04:19:24 +00:00
|
|
|
/*
|
|
|
|
*******************************************************************************
|
|
|
|
* Copyright (C) 2009, International Business Machines Corporation and *
|
|
|
|
* others. All Rights Reserved. *
|
|
|
|
*******************************************************************************
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* \file
|
|
|
|
* \brief C API: Time zone rule classes
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "unicode/utypes.h"
|
|
|
|
#include "unicode/utypes.h"
|
|
|
|
#include "unicode/uobject.h"
|
|
|
|
#include "unicode/zrule.h"
|
|
|
|
#include "unicode/tzrule.h"
|
|
|
|
#include "cmemory.h"
|
|
|
|
#include "unicode/ustring.h"
|
|
|
|
#include "unicode/parsepos.h"
|
|
|
|
|
|
|
|
U_NAMESPACE_USE
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
* ZRule API
|
|
|
|
*********************************************************************/
|
|
|
|
|
|
|
|
U_CAPI void U_EXPORT2
|
|
|
|
zrule_close(ZRule* rule) {
|
|
|
|
delete (TimeZoneRule*)rule;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
zrule_equals(const ZRule* rule1, const ZRule* rule2) {
|
|
|
|
return *(const TimeZoneRule*)rule1 == *(const TimeZoneRule*)rule2;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI void U_EXPORT2
|
|
|
|
zrule_getName(ZRule* rule, UChar* name, int32_t nameLength) {
|
|
|
|
UnicodeString s(nameLength==-1, name, nameLength);
|
|
|
|
s = ((TimeZoneRule*)rule)->TimeZoneRule::getName(s);
|
|
|
|
nameLength = s.length();
|
|
|
|
memcpy(name, s.getBuffer(), nameLength);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI int32_t U_EXPORT2
|
|
|
|
zrule_getRawOffset(ZRule* rule) {
|
|
|
|
return ((TimeZoneRule*)rule)->TimeZoneRule::getRawOffset();
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI int32_t U_EXPORT2
|
|
|
|
zrule_getDSTSavings(ZRule* rule) {
|
|
|
|
return ((TimeZoneRule*)rule)->TimeZoneRule::getDSTSavings();
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
zrule_isEquivalentTo(ZRule* rule1, ZRule* rule2) {
|
|
|
|
return ((TimeZoneRule*)rule1)->TimeZoneRule::isEquivalentTo(*(TimeZoneRule*)rule2);
|
|
|
|
}
|
|
|
|
|
|
|
|
/*********************************************************************
|
|
|
|
* IZRule API
|
|
|
|
*********************************************************************/
|
|
|
|
|
|
|
|
U_CAPI IZRule* U_EXPORT2
|
|
|
|
izrule_open(const UChar* name, int32_t nameLength, int32_t rawOffset, int32_t dstSavings) {
|
|
|
|
UnicodeString s(nameLength==-1, name, nameLength);
|
|
|
|
return (IZRule*) new InitialTimeZoneRule(name, rawOffset, dstSavings);
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI void U_EXPORT2
|
|
|
|
izrule_close(IZRule* rule) {
|
|
|
|
delete (InitialTimeZoneRule*)rule;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI IZRule* U_EXPORT2
|
|
|
|
izrule_clone(IZRule *rule) {
|
|
|
|
return (IZRule*) (((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::clone());
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
izrule_equals(const IZRule* rule1, const IZRule* rule2) {
|
|
|
|
return *(const InitialTimeZoneRule*)rule1 == *(const InitialTimeZoneRule*)rule2;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI void U_EXPORT2
|
|
|
|
izrule_getName(IZRule* rule, UChar* & name, int32_t & nameLength) {
|
|
|
|
// UnicodeString s(nameLength==-1, name, nameLength);
|
|
|
|
UnicodeString s;
|
|
|
|
((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getName(s);
|
|
|
|
nameLength = s.length();
|
2009-12-10 17:54:04 +00:00
|
|
|
name = (UChar*)uprv_malloc(nameLength);
|
2009-12-08 04:19:24 +00:00
|
|
|
memcpy(name, s.getBuffer(), nameLength);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI int32_t U_EXPORT2
|
|
|
|
izrule_getRawOffset(IZRule* rule) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getRawOffset();
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI int32_t U_EXPORT2
|
|
|
|
izrule_getDSTSavings(IZRule* rule) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getDSTSavings();
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
izrule_isEquivalentTo(IZRule* rule1, IZRule* rule2) {
|
|
|
|
return ((InitialTimeZoneRule*)rule1)->InitialTimeZoneRule::isEquivalentTo(*(InitialTimeZoneRule*)rule2);
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
izrule_getFirstStart(IZRule* rule, int32_t prevRawOffset, int32_t prevDSTSavings,
|
|
|
|
UDate& result) {
|
|
|
|
return ((const InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getFirstStart(prevRawOffset, prevDSTSavings, result);
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
izrule_getFinalStart(IZRule* rule, int32_t prevRawOffset, int32_t prevDSTSavings,
|
|
|
|
UDate& result) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getFinalStart(prevRawOffset, prevDSTSavings, result);
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
izrule_getNextStart(IZRule* rule, UDate base, int32_t prevRawOffset,
|
|
|
|
int32_t prevDSTSavings, UBool inclusive, UDate& result) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getNextStart(base, prevRawOffset, prevDSTSavings, inclusive, result);
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UBool U_EXPORT2
|
|
|
|
izrule_getPreviousStart(IZRule* rule, UDate base, int32_t prevRawOffset,
|
|
|
|
int32_t prevDSTSavings, UBool inclusive, UDate& result) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getPreviousStart(base, prevRawOffset, prevDSTSavings, inclusive, result);
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UClassID U_EXPORT2
|
|
|
|
izrule_getStaticClassID(IZRule* rule) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getStaticClassID();
|
|
|
|
}
|
|
|
|
|
|
|
|
U_CAPI UClassID U_EXPORT2
|
|
|
|
izrule_getDynamicClassID(IZRule* rule) {
|
|
|
|
return ((InitialTimeZoneRule*)rule)->InitialTimeZoneRule::getDynamicClassID();
|
|
|
|
}
|
|
|
|
|