2 *******************************************************************************
3 * Copyright (C) 2003 - 2013, International Business Machines Corporation and
4 * others. All Rights Reserved.
5 *******************************************************************************
8 #include "unicode/utypes.h"
10 #if !UCONFIG_NO_FORMATTING
19 UOBJECT_DEFINE_RTTI_IMPLEMENTATION(CopticCalendar)
21 static const int32_t COPTIC_JD_EPOCH_OFFSET = 1824665;
23 //-------------------------------------------------------------------------
25 //-------------------------------------------------------------------------
27 CopticCalendar::CopticCalendar(const Locale& aLocale, UErrorCode& success)
28 : CECalendar(aLocale, success)
32 CopticCalendar::CopticCalendar (const CopticCalendar& other)
37 CopticCalendar::~CopticCalendar()
42 CopticCalendar::clone() const
44 return new CopticCalendar(*this);
48 CopticCalendar::getType() const
53 //-------------------------------------------------------------------------
55 //-------------------------------------------------------------------------
58 CopticCalendar::handleGetExtendedYear()
61 if (newerField(UCAL_EXTENDED_YEAR, UCAL_YEAR) == UCAL_EXTENDED_YEAR) {
62 eyear = internalGet(UCAL_EXTENDED_YEAR, 1); // Default to year 1
64 // The year defaults to the epoch start, the era to CE
65 int32_t era = internalGet(UCAL_ERA, CE);
67 eyear = 1 - internalGet(UCAL_YEAR, 1); // Convert to extended year
69 eyear = internalGet(UCAL_YEAR, 1); // Default to year 1
76 CopticCalendar::handleComputeFields(int32_t julianDay, UErrorCode &/*status*/)
78 int32_t eyear, month, day, era, year;
79 jdToCE(julianDay, getJDEpochOffset(), eyear, month, day);
89 internalSet(UCAL_EXTENDED_YEAR, eyear);
90 internalSet(UCAL_ERA, era);
91 internalSet(UCAL_YEAR, year);
92 internalSet(UCAL_MONTH, month);
93 internalSet(UCAL_DATE, day);
94 internalSet(UCAL_DAY_OF_YEAR, (30 * month) + day);
98 * The system maintains a static default century start date and Year. They are
99 * initialized the first time they are used. Once the system default century date
100 * and year are set, they do not change.
102 static UDate gSystemDefaultCenturyStart = DBL_MIN;
103 static int32_t gSystemDefaultCenturyStartYear = -1;
104 static icu::UInitOnce gSystemDefaultCenturyInit = U_INITONCE_INITIALIZER;
107 static void U_CALLCONV initializeSystemDefaultCentury() {
108 UErrorCode status = U_ZERO_ERROR;
109 CopticCalendar calendar(Locale("@calendar=coptic"), status);
110 if (U_SUCCESS(status)) {
111 calendar.setTime(Calendar::getNow(), status);
112 calendar.add(UCAL_YEAR, -80, status);
113 gSystemDefaultCenturyStart = calendar.getTime(status);
114 gSystemDefaultCenturyStartYear = calendar.get(UCAL_YEAR, status);
116 // We have no recourse upon failure unless we want to propagate the failure
121 CopticCalendar::defaultCenturyStart() const
123 // lazy-evaluate systemDefaultCenturyStart
124 umtx_initOnce(gSystemDefaultCenturyInit, &initializeSystemDefaultCentury);
125 return gSystemDefaultCenturyStart;
129 CopticCalendar::defaultCenturyStartYear() const
131 // lazy-evaluate systemDefaultCenturyStart
132 umtx_initOnce(gSystemDefaultCenturyInit, &initializeSystemDefaultCentury);
133 return gSystemDefaultCenturyStartYear;
138 CopticCalendar::getJDEpochOffset() const
140 return COPTIC_JD_EPOCH_OFFSET;
145 // We do not want to introduce this API in ICU4C.
146 // It was accidentally introduced in ICU4J as a public API.
148 //-------------------------------------------------------------------------
149 // Calendar system Conversion methods...
150 //-------------------------------------------------------------------------
153 CopticCalendar::copticToJD(int32_t year, int32_t month, int32_t day)
155 return CECalendar::ceToJD(year, month, day, COPTIC_JD_EPOCH_OFFSET);
161 #endif /* #if !UCONFIG_NO_FORMATTING */