/* ***************************************************************************** * Copyright (C) 2013, International Business Machines Corporation * and others. All Rights Reserved. ***************************************************************************** * * File DANGICAL.H ***************************************************************************** */ #ifndef DANGICAL_H #define DANGICAL_H #include "unicode/utypes.h" #if !UCONFIG_NO_FORMATTING #include "unicode/calendar.h" #include "unicode/timezone.h" #include "chnsecal.h" U_NAMESPACE_BEGIN /** * <p><code>DangiCalendar</code> is a concrete subclass of {@link Calendar} * that implements a traditional Korean lunisolar calendar.</p> * * <p>DangiCalendar usually should be instantiated using * {@link com.ibm.icu.util.Calendar#getInstance(ULocale)} passing in a <code>ULocale</code> * with the tag <code>"@calendar=dangi"</code>.</p> * * @internal */ class DangiCalendar : public ChineseCalendar { public: //------------------------------------------------------------------------- // Constructors... //------------------------------------------------------------------------- /** * Constructs a DangiCalendar based on the current time in the default time zone * with the given locale. * * @param aLocale The given locale. * @param success Indicates the status of DangiCalendar object construction. * Returns U_ZERO_ERROR if constructed successfully. * @internal */ DangiCalendar(const Locale& aLocale, UErrorCode &success); /** * Copy Constructor * @internal */ DangiCalendar(const DangiCalendar& other); /** * Destructor. * @internal */ virtual ~DangiCalendar(); /** * Clone. * @internal */ virtual Calendar* clone() const; //---------------------------------------------------------------------- // Internal methods & astronomical calculations //---------------------------------------------------------------------- private: const TimeZone* getDangiCalZoneAstroCalc(void) const; // UObject stuff public: /** * @return The class ID for this object. All objects of a given class have the * same class ID. Objects of other classes have different class IDs. * @internal */ virtual UClassID getDynamicClassID(void) const; /** * Return the class ID for this class. This is useful only for comparing to a return * value from getDynamicClassID(). For example: * * Base* polymorphic_pointer = createPolymorphicObject(); * if (polymorphic_pointer->getDynamicClassID() == * Derived::getStaticClassID()) ... * * @return The class ID for all objects of this class. * @internal */ U_I18N_API static UClassID U_EXPORT2 getStaticClassID(void); /** * return the calendar type, "dangi". * * @return calendar type * @internal */ const char * getType() const; private: DangiCalendar(); // default constructor not implemented }; U_NAMESPACE_END #endif #endif