1 // Copyright (C) 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 /*
4  *******************************************************************************
5  * Copyright (C) 2009-2016, International Business Machines Corporation,       *
6  * Google, and others. All Rights Reserved.                                    *
7  *******************************************************************************
8  */
9 
10 #ifndef __TMUNIT_H__
11 #define __TMUNIT_H__
12 
13 
14 /**
15  * \file
16  * \brief C++ API: time unit object
17  */
18 
19 
20 #include "unicode/measunit.h"
21 
22 #if !UCONFIG_NO_FORMATTING
23 
24 U_NAMESPACE_BEGIN
25 
26 /**
27  * Measurement unit for time units.
28  * @see TimeUnitAmount
29  * @see TimeUnit
30  * @stable ICU 4.2
31  */
32 class U_I18N_API TimeUnit: public MeasureUnit {
33 public:
34     /**
35      * Constants for all the time units we supported.
36      * @stable ICU 4.2
37      */
38     enum UTimeUnitFields {
39         UTIMEUNIT_YEAR,
40         UTIMEUNIT_MONTH,
41         UTIMEUNIT_DAY,
42         UTIMEUNIT_WEEK,
43         UTIMEUNIT_HOUR,
44         UTIMEUNIT_MINUTE,
45         UTIMEUNIT_SECOND,
46 #ifndef U_HIDE_DEPRECATED_API
47         /**
48          * One more than the highest normal UTimeUnitFields value.
49          * @deprecated ICU 58 The numeric value may change over time, see ICU ticket #12420.
50          */
51         UTIMEUNIT_FIELD_COUNT
52 #endif  // U_HIDE_DEPRECATED_API
53     };
54 
55     /**
56      * Create Instance.
57      * @param timeUnitField  time unit field based on which the instance
58      *                       is created.
59      * @param status         input-output error code.
60      *                       If the timeUnitField is invalid,
61      *                       then this will be set to U_ILLEGAL_ARGUMENT_ERROR.
62      * @return               a TimeUnit instance
63      * @stable ICU 4.2
64      */
65     static TimeUnit* U_EXPORT2 createInstance(UTimeUnitFields timeUnitField,
66                                               UErrorCode& status);
67 
68 
69     /**
70      * Override clone.
71      * @stable ICU 4.2
72      */
73     virtual UObject* clone() const;
74 
75     /**
76      * Copy operator.
77      * @stable ICU 4.2
78      */
79     TimeUnit(const TimeUnit& other);
80 
81     /**
82      * Assignment operator.
83      * @stable ICU 4.2
84      */
85     TimeUnit& operator=(const TimeUnit& other);
86 
87     /**
88      * Returns a unique class ID for this object POLYMORPHICALLY.
89      * This method implements a simple form of RTTI used by ICU.
90      * @return The class ID for this object. All objects of a given
91      * class have the same class ID.  Objects of other classes have
92      * different class IDs.
93      * @stable ICU 4.2
94      */
95     virtual UClassID getDynamicClassID() const;
96 
97     /**
98      * Returns the class ID for this class. This is used to compare to
99      * the return value of getDynamicClassID().
100      * @return The class ID for all objects of this class.
101      * @stable ICU 4.2
102      */
103     static UClassID U_EXPORT2 getStaticClassID();
104 
105 
106     /**
107      * Get time unit field.
108      * @return time unit field.
109      * @stable ICU 4.2
110      */
111     UTimeUnitFields getTimeUnitField() const;
112 
113     /**
114      * Destructor.
115      * @stable ICU 4.2
116      */
117     virtual ~TimeUnit();
118 
119 private:
120     UTimeUnitFields fTimeUnitField;
121 
122     /**
123      * Constructor
124      * @internal (private)
125      */
126     TimeUnit(UTimeUnitFields timeUnitField);
127 
128 };
129 
130 
131 U_NAMESPACE_END
132 
133 #endif /* #if !UCONFIG_NO_FORMATTING */
134 
135 #endif // __TMUNIT_H__
136 //eof
137 //
138