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 */