ICU 74.1 74.1
gregocal.h
Go to the documentation of this file.
1// © 2016 and later: Unicode, Inc. and others.
2// License & terms of use: http://www.unicode.org/copyright.html
3/*
4* Copyright (C) 1997-2013, International Business Machines Corporation and others.
5* All Rights Reserved.
6********************************************************************************
7*
8* File GREGOCAL.H
9*
10* Modification History:
11*
12* Date Name Description
13* 04/22/97 aliu Overhauled header.
14* 07/28/98 stephen Sync with JDK 1.2
15* 09/04/98 stephen Re-sync with JDK 8/31 putback
16* 09/14/98 stephen Changed type of kOneDay, kOneWeek to double.
17* Fixed bug in roll()
18* 10/15/99 aliu Fixed j31, incorrect WEEK_OF_YEAR computation.
19* Added documentation of WEEK_OF_YEAR computation.
20* 10/15/99 aliu Fixed j32, cannot set date to Feb 29 2000 AD.
21* {JDK bug 4210209 4209272}
22* 11/07/2003 srl Update, clean up documentation.
23********************************************************************************
24*/
25
26#ifndef GREGOCAL_H
27#define GREGOCAL_H
28
29#include "unicode/utypes.h"
30
31#if U_SHOW_CPLUSPLUS_API
32
33#if !UCONFIG_NO_FORMATTING
34
35#include "unicode/calendar.h"
36
42U_NAMESPACE_BEGIN
43
154public:
155
160 enum EEras {
161 BC,
162 AD
163 };
164
174
185 GregorianCalendar(TimeZone* zoneToAdopt, UErrorCode& success);
186
196 GregorianCalendar(const TimeZone& zone, UErrorCode& success);
197
207 GregorianCalendar(const Locale& aLocale, UErrorCode& success);
208
220 GregorianCalendar(TimeZone* zoneToAdopt, const Locale& aLocale, UErrorCode& success);
221
232 GregorianCalendar(const TimeZone& zone, const Locale& aLocale, UErrorCode& success);
233
246 GregorianCalendar(int32_t year, int32_t month, int32_t date, UErrorCode& success);
247
262 GregorianCalendar(int32_t year, int32_t month, int32_t date, int32_t hour, int32_t minute, UErrorCode& success);
263
279 GregorianCalendar(int32_t year, int32_t month, int32_t date, int32_t hour, int32_t minute, int32_t second, UErrorCode& success);
280
286
293
300
306 virtual GregorianCalendar* clone() const override;
307
317 void setGregorianChange(UDate date, UErrorCode& success);
318
328
344 UBool isLeapYear(int32_t year) const;
345
353 virtual UBool isEquivalentTo(const Calendar& other) const override;
354
355#ifndef U_FORCE_HIDE_DEPRECATED_API
367 virtual void roll(EDateFields field, int32_t amount, UErrorCode& status) override;
368#endif // U_FORCE_HIDE_DEPRECATED_API
369
381 virtual void roll(UCalendarDateFields field, int32_t amount, UErrorCode& status) override;
382
383#ifndef U_HIDE_DEPRECATED_API
391 int32_t getActualMinimum(EDateFields field) const;
392
401 int32_t getActualMinimum(EDateFields field, UErrorCode& status) const;
402#endif /* U_HIDE_DEPRECATED_API */
403
412 int32_t getActualMinimum(UCalendarDateFields field, UErrorCode &status) const override;
413
424 virtual int32_t getActualMaximum(UCalendarDateFields field, UErrorCode& status) const override;
425
426public:
427
438 virtual UClassID getDynamicClassID(void) const override;
439
451 static UClassID U_EXPORT2 getStaticClassID(void);
452
463 virtual const char * getType() const override;
464
465 private:
466 GregorianCalendar() = delete; // default constructor not implemented
467
468 protected:
475 virtual int32_t internalGetEra() const;
476
490 virtual int32_t handleComputeMonthStart(int32_t eyear, int32_t month,
491 UBool useMonth) const override;
492
501 virtual int32_t handleComputeJulianDay(UCalendarDateFields bestField) override;
502
510 virtual int32_t handleGetMonthLength(int32_t extendedYear, int32_t month) const override;
511
519 virtual int32_t handleGetYearLength(int32_t eyear) const override;
520
527 virtual int32_t monthLength(int32_t month) const;
528
536 virtual int32_t monthLength(int32_t month, int32_t year) const;
537
538#ifndef U_HIDE_INTERNAL_API
544 int32_t yearLength(void) const;
545
546#endif /* U_HIDE_INTERNAL_API */
547
555 virtual UDate getEpochDay(UErrorCode& status);
556
578 virtual int32_t handleGetLimit(UCalendarDateFields field, ELimitType limitType) const override;
579
588 virtual int32_t handleGetExtendedYear() override;
589
598 virtual int32_t handleGetExtendedYearFromWeekFields(int32_t yearWoy, int32_t woy) override;
599
600
616 virtual void handleComputeFields(int32_t julianDay, UErrorCode &status) override;
617
618 private:
626 static double computeJulianDayOfYear(UBool isGregorian, int32_t year,
627 UBool& isLeap);
628
633 UBool validateFields(void) const;
634
638 UBool boundsCheck(int32_t value, UCalendarDateFields field) const;
639
649 int32_t aggregateStamp(int32_t stamp_a, int32_t stamp_b);
650
658 UDate fGregorianCutover;
659
663 int32_t fCutoverJulianDay;
664
670 UDate fNormalizedGregorianCutover;// = gregorianCutover;
671
676 int32_t fGregorianCutoverYear;// = 1582;
677
685 static double millisToJulianDay(UDate millis);
686
694 static UDate julianDayToMillis(double julian);
695
700 UBool fIsGregorian;
701
707 UBool fInvertGregorian;
708
709
710 public: // internal implementation
711
716 virtual UBool haveDefaultCentury() const override;
717
722 virtual UDate defaultCenturyStart() const override;
723
728 virtual int32_t defaultCenturyStartYear() const override;
729};
730
731U_NAMESPACE_END
732
733#endif /* #if !UCONFIG_NO_FORMATTING */
734
735#endif /* U_SHOW_CPLUSPLUS_API */
736
737#endif // _GREGOCAL
738//eof
739
C++ API: Calendar object.
Calendar is an abstract base class for converting between a UDate object and a set of integer fields ...
Definition: calendar.h:189
EDateFields
Field IDs for date and time.
Definition: calendar.h:198
ELimitType
Limit enums.
Definition: calendar.h:1615
Concrete class which provides the standard calendar used by most of the world.
Definition: gregocal.h:153
int32_t getActualMinimum(EDateFields field, UErrorCode &status) const
Return the minimum value that this field could have, given the current date.
virtual UBool haveDefaultCentury() const override
GregorianCalendar(UErrorCode &success)
Constructs a default GregorianCalendar using the current time in the default time zone with the defau...
virtual int32_t handleGetLimit(UCalendarDateFields field, ELimitType limitType) const override
Subclass API for defining limits of different types.
virtual int32_t handleGetExtendedYear() override
Return the extended year defined by the current fields.
virtual void handleComputeFields(int32_t julianDay, UErrorCode &status) override
Subclasses may override this method to compute several fields specific to each calendar system.
virtual int32_t monthLength(int32_t month) const
return the length of the given month.
EEras
Useful constants for GregorianCalendar and TimeZone.
Definition: gregocal.h:160
GregorianCalendar & operator=(const GregorianCalendar &right)
Default assignment operator.
virtual UClassID getDynamicClassID(void) const override
Override Calendar Returns a unique class ID POLYMORPHICALLY.
GregorianCalendar(TimeZone *zoneToAdopt, UErrorCode &success)
Constructs a GregorianCalendar based on the current time in the given time zone with the default loca...
GregorianCalendar(const Locale &aLocale, UErrorCode &success)
Constructs a GregorianCalendar based on the current time in the default time zone with the given loca...
GregorianCalendar(const TimeZone &zone, const Locale &aLocale, UErrorCode &success)
Constructs a GregorianCalendar based on the current time in the given time zone with the given locale...
virtual UDate defaultCenturyStart() const override
virtual int32_t handleGetMonthLength(int32_t extendedYear, int32_t month) const override
Return the number of days in the given month of the given extended year of this calendar system.
virtual int32_t monthLength(int32_t month, int32_t year) const
return the length of the month according to the given year.
GregorianCalendar(TimeZone *zoneToAdopt, const Locale &aLocale, UErrorCode &success)
Constructs a GregorianCalendar based on the current time in the given time zone with the given locale...
GregorianCalendar(int32_t year, int32_t month, int32_t date, int32_t hour, int32_t minute, int32_t second, UErrorCode &success)
Constructs a GregorianCalendar with the given AD date and time set for the default time zone with the...
virtual int32_t handleGetExtendedYearFromWeekFields(int32_t yearWoy, int32_t woy) override
Subclasses may override this to convert from week fields (YEAR_WOY and WEEK_OF_YEAR) to an extended y...
GregorianCalendar(const TimeZone &zone, UErrorCode &success)
Constructs a GregorianCalendar based on the current time in the given time zone with the default loca...
GregorianCalendar(const GregorianCalendar &source)
Copy constructor.
virtual int32_t handleComputeMonthStart(int32_t eyear, int32_t month, UBool useMonth) const override
Return the Julian day number of day before the first day of the given month in the given extended yea...
virtual int32_t internalGetEra() const
Return the ERA.
virtual int32_t handleGetYearLength(int32_t eyear) const override
Return the number of days in the given extended year of this calendar system.
int32_t getActualMinimum(EDateFields field) const
Return the minimum value that this field could have, given the current date.
UBool isLeapYear(int32_t year) const
Return true if the given year is a leap year.
virtual int32_t defaultCenturyStartYear() const override
virtual ~GregorianCalendar()
Destructor.
virtual int32_t handleComputeJulianDay(UCalendarDateFields bestField) override
Subclasses may override this.
static UClassID getStaticClassID(void)
Return the class ID for this class.
int32_t getActualMinimum(UCalendarDateFields field, UErrorCode &status) const override
Return the minimum value that this field could have, given the current date.
virtual const char * getType() const override
Returns the calendar type name string for this Calendar object.
GregorianCalendar(int32_t year, int32_t month, int32_t date, int32_t hour, int32_t minute, UErrorCode &success)
Constructs a GregorianCalendar with the given AD date and time set for the default time zone with the...
virtual int32_t getActualMaximum(UCalendarDateFields field, UErrorCode &status) const override
Return the maximum value that this field could have, given the current date.
virtual UDate getEpochDay(UErrorCode &status)
Return the day number with respect to the epoch.
virtual UBool isEquivalentTo(const Calendar &other) const override
Returns true if the given Calendar object is equivalent to this one.
virtual void roll(EDateFields field, int32_t amount, UErrorCode &status) override
(Overrides Calendar) Rolls up or down by the given amount in the specified field.
int32_t yearLength(void) const
return the length of the year field.
virtual void roll(UCalendarDateFields field, int32_t amount, UErrorCode &status) override
(Overrides Calendar) Rolls up or down by the given amount in the specified field.
GregorianCalendar(int32_t year, int32_t month, int32_t date, UErrorCode &success)
Constructs a GregorianCalendar with the given AD date set in the default time zone with the default l...
virtual GregorianCalendar * clone() const override
Create and return a polymorphic copy of this calendar.
UDate getGregorianChange(void) const
Gets the Gregorian Calendar change date.
void setGregorianChange(UDate date, UErrorCode &success)
Sets the GregorianCalendar change date.
A Locale object represents a specific geographical, political, or cultural region.
Definition: locid.h:195
TimeZone represents a time zone offset, and also figures out daylight savings.
Definition: timezone.h:133
UCalendarDateFields
Possible fields in a UCalendar.
Definition: ucal.h:202
int8_t UBool
The ICU boolean type, a signed-byte integer.
Definition: umachine.h:247
void * UClassID
UClassID is used to identify classes without using the compiler's RTTI.
Definition: uobject.h:96
Basic definitions for ICU, for both C and C++ APIs.
UErrorCode
Standard ICU4C error code type, a substitute for exceptions.
Definition: utypes.h:415
#define U_I18N_API
Set to export library symbols from inside the i18n library, and to import them from outside.
Definition: utypes.h:301
double UDate
Date and Time data type.
Definition: utypes.h:203