mirror of https://github.com/nodejs/node.git
177 lines
5.4 KiB
C++
177 lines
5.4 KiB
C++
// © 2016 and later: Unicode, Inc. and others.
|
|
// License & terms of use: http://www.unicode.org/copyright.html
|
|
/*
|
|
*****************************************************************************************
|
|
* Copyright (C) 2010-2011, International Business Machines
|
|
* Corporation and others. All Rights Reserved.
|
|
*****************************************************************************************
|
|
*/
|
|
|
|
#include "unicode/utypes.h"
|
|
|
|
#if !UCONFIG_NO_FORMATTING
|
|
|
|
#include "unicode/udateintervalformat.h"
|
|
#include "unicode/dtitvfmt.h"
|
|
#include "unicode/dtintrv.h"
|
|
#include "unicode/localpointer.h"
|
|
#include "unicode/timezone.h"
|
|
#include "unicode/locid.h"
|
|
#include "unicode/unistr.h"
|
|
#include "unicode/udisplaycontext.h"
|
|
#include "formattedval_impl.h"
|
|
|
|
U_NAMESPACE_USE
|
|
|
|
|
|
// Magic number: FDIV in ASCII
|
|
UPRV_FORMATTED_VALUE_CAPI_AUTO_IMPL(
|
|
FormattedDateInterval,
|
|
UFormattedDateInterval,
|
|
UFormattedDateIntervalImpl,
|
|
UFormattedDateIntervalApiHelper,
|
|
udtitvfmt,
|
|
0x46444956)
|
|
|
|
|
|
U_CAPI UDateIntervalFormat* U_EXPORT2
|
|
udtitvfmt_open(const char* locale,
|
|
const char16_t* skeleton,
|
|
int32_t skeletonLength,
|
|
const char16_t* tzID,
|
|
int32_t tzIDLength,
|
|
UErrorCode* status)
|
|
{
|
|
if (U_FAILURE(*status)) {
|
|
return nullptr;
|
|
}
|
|
if ((skeleton == nullptr ? skeletonLength != 0 : skeletonLength < -1) ||
|
|
(tzID == nullptr ? tzIDLength != 0 : tzIDLength < -1)
|
|
) {
|
|
*status = U_ILLEGAL_ARGUMENT_ERROR;
|
|
return nullptr;
|
|
}
|
|
UnicodeString skel(skeletonLength == -1, skeleton, skeletonLength);
|
|
LocalPointer<DateIntervalFormat> formatter(
|
|
DateIntervalFormat::createInstance(skel, Locale(locale), *status));
|
|
if (U_FAILURE(*status)) {
|
|
return nullptr;
|
|
}
|
|
if (tzID != nullptr) {
|
|
TimeZone* zone = TimeZone::createTimeZone(UnicodeString(tzIDLength == -1, tzID, tzIDLength));
|
|
if(zone == nullptr) {
|
|
*status = U_MEMORY_ALLOCATION_ERROR;
|
|
return nullptr;
|
|
}
|
|
formatter->adoptTimeZone(zone);
|
|
}
|
|
return (UDateIntervalFormat*)formatter.orphan();
|
|
}
|
|
|
|
|
|
U_CAPI void U_EXPORT2
|
|
udtitvfmt_close(UDateIntervalFormat *formatter)
|
|
{
|
|
delete (DateIntervalFormat*)formatter;
|
|
}
|
|
|
|
|
|
U_CAPI int32_t U_EXPORT2
|
|
udtitvfmt_format(const UDateIntervalFormat* formatter,
|
|
UDate fromDate,
|
|
UDate toDate,
|
|
char16_t* result,
|
|
int32_t resultCapacity,
|
|
UFieldPosition* position,
|
|
UErrorCode* status)
|
|
{
|
|
if (U_FAILURE(*status)) {
|
|
return -1;
|
|
}
|
|
if (result == nullptr ? resultCapacity != 0 : resultCapacity < 0) {
|
|
*status = U_ILLEGAL_ARGUMENT_ERROR;
|
|
return 0;
|
|
}
|
|
UnicodeString res;
|
|
if (result != nullptr) {
|
|
// nullptr destination for pure preflighting: empty dummy string
|
|
// otherwise, alias the destination buffer (copied from udat_format)
|
|
res.setTo(result, 0, resultCapacity);
|
|
}
|
|
FieldPosition fp;
|
|
if (position != nullptr) {
|
|
fp.setField(position->field);
|
|
}
|
|
|
|
DateInterval interval = DateInterval(fromDate,toDate);
|
|
((const DateIntervalFormat*)formatter)->format( &interval, res, fp, *status );
|
|
if (U_FAILURE(*status)) {
|
|
return -1;
|
|
}
|
|
if (position != nullptr) {
|
|
position->beginIndex = fp.getBeginIndex();
|
|
position->endIndex = fp.getEndIndex();
|
|
}
|
|
|
|
return res.extract(result, resultCapacity, *status);
|
|
}
|
|
|
|
|
|
U_CAPI void U_EXPORT2
|
|
udtitvfmt_formatToResult(
|
|
const UDateIntervalFormat* formatter,
|
|
UDate fromDate,
|
|
UDate toDate,
|
|
UFormattedDateInterval* result,
|
|
UErrorCode* status) {
|
|
if (U_FAILURE(*status)) {
|
|
return;
|
|
}
|
|
auto* resultImpl = UFormattedDateIntervalApiHelper::validate(result, *status);
|
|
DateInterval interval = DateInterval(fromDate,toDate);
|
|
if (resultImpl != nullptr) {
|
|
resultImpl->fImpl = reinterpret_cast<const DateIntervalFormat*>(formatter)
|
|
->formatToValue(interval, *status);
|
|
}
|
|
}
|
|
|
|
U_CAPI void U_EXPORT2
|
|
udtitvfmt_formatCalendarToResult(
|
|
const UDateIntervalFormat* formatter,
|
|
UCalendar* fromCalendar,
|
|
UCalendar* toCalendar,
|
|
UFormattedDateInterval* result,
|
|
UErrorCode* status) {
|
|
if (U_FAILURE(*status)) {
|
|
return;
|
|
}
|
|
auto* resultImpl = UFormattedDateIntervalApiHelper::validate(result, *status);
|
|
if (resultImpl != nullptr) {
|
|
resultImpl->fImpl = reinterpret_cast<const DateIntervalFormat*>(formatter)
|
|
->formatToValue(*(Calendar *)fromCalendar, *(Calendar *)toCalendar, *status);
|
|
}
|
|
}
|
|
|
|
U_CAPI void U_EXPORT2
|
|
udtitvfmt_setContext(UDateIntervalFormat* formatter,
|
|
UDisplayContext value,
|
|
UErrorCode* status) {
|
|
if (U_FAILURE(*status)) {
|
|
return;
|
|
}
|
|
reinterpret_cast<DateIntervalFormat*>(formatter)->setContext( value, *status );
|
|
}
|
|
|
|
U_CAPI UDisplayContext U_EXPORT2
|
|
udtitvfmt_getContext(const UDateIntervalFormat* formatter,
|
|
UDisplayContextType type,
|
|
UErrorCode* status) {
|
|
if (U_FAILURE(*status)) {
|
|
return (UDisplayContext)0;
|
|
}
|
|
return reinterpret_cast<const DateIntervalFormat*>(formatter)->getContext( type, *status );
|
|
}
|
|
|
|
|
|
#endif /* #if !UCONFIG_NO_FORMATTING */
|