aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/icu/i18n/dangical.h
blob: 4a38ea0229f5de4744bdfa51cf1d5316deaf0d10 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// © 2016 and later: Unicode, Inc. and others.
// License & terms of use: http://www.unicode.org/copyright.html 
/* 
 ***************************************************************************** 
 * 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 DangiCalendar* 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