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-2010, Google, International Business Machines Corporation and * 6 * others. All Rights Reserved. * 7 ******************************************************************************* 8 */ 9 10 #ifndef __TMUTAMT_H__ 11 #define __TMUTAMT_H__ 12 13 14 /** 15 * \file 16 * \brief C++ API: time unit amount object. 17 */ 18 19 #include "unicode/measure.h" 20 #include "unicode/tmunit.h" 21 22 #if !UCONFIG_NO_FORMATTING 23 24 U_NAMESPACE_BEGIN 25 26 27 /** 28 * Express a duration as a time unit and number. Patterned after Currency. 29 * @see TimeUnitAmount 30 * @see TimeUnitFormat 31 * @stable ICU 4.2 32 */ 33 class U_I18N_API TimeUnitAmount: public Measure { 34 public: 35 /** 36 * Construct TimeUnitAmount object with the given number and the 37 * given time unit. 38 * @param number a numeric object; number.isNumeric() must be TRUE 39 * @param timeUnitField the time unit field of a time unit 40 * @param status the input-output error code. 41 * If the number is not numeric or the timeUnitField 42 * is not valid, 43 * then this will be set to a failing value: 44 * U_ILLEGAL_ARGUMENT_ERROR. 45 * @stable ICU 4.2 46 */ 47 TimeUnitAmount(const Formattable& number, 48 TimeUnit::UTimeUnitFields timeUnitField, 49 UErrorCode& status); 50 51 /** 52 * Construct TimeUnitAmount object with the given numeric amount and the 53 * given time unit. 54 * @param amount a numeric amount. 55 * @param timeUnitField the time unit field on which a time unit amount 56 * object will be created. 57 * @param status the input-output error code. 58 * If the timeUnitField is not valid, 59 * then this will be set to a failing value: 60 * U_ILLEGAL_ARGUMENT_ERROR. 61 * @stable ICU 4.2 62 */ 63 TimeUnitAmount(double amount, TimeUnit::UTimeUnitFields timeUnitField, 64 UErrorCode& status); 65 66 67 /** 68 * Copy constructor 69 * @stable ICU 4.2 70 */ 71 TimeUnitAmount(const TimeUnitAmount& other); 72 73 74 /** 75 * Assignment operator 76 * @stable ICU 4.2 77 */ 78 TimeUnitAmount& operator=(const TimeUnitAmount& other); 79 80 81 /** 82 * Clone. 83 * @return a polymorphic clone of this object. The result will have the same class as returned by getDynamicClassID(). 84 * @stable ICU 4.2 85 */ 86 virtual UObject* clone() const; 87 88 89 /** 90 * Destructor 91 * @stable ICU 4.2 92 */ 93 virtual ~TimeUnitAmount(); 94 95 96 /** 97 * Equality operator. 98 * @param other the object to compare to. 99 * @return true if this object is equal to the given object. 100 * @stable ICU 4.2 101 */ 102 virtual UBool operator==(const UObject& other) const; 103 104 105 /** 106 * Not-equality operator. 107 * @param other the object to compare to. 108 * @return true if this object is not equal to the given object. 109 * @stable ICU 4.2 110 */ 111 UBool operator!=(const UObject& other) const; 112 113 114 /** 115 * Return the class ID for this class. This is useful only for comparing to 116 * a return value from getDynamicClassID(). For example: 117 * <pre> 118 * . Base* polymorphic_pointer = createPolymorphicObject(); 119 * . if (polymorphic_pointer->getDynamicClassID() == 120 * . erived::getStaticClassID()) ... 121 * </pre> 122 * @return The class ID for all objects of this class. 123 * @stable ICU 4.2 124 */ 125 static UClassID U_EXPORT2 getStaticClassID(void); 126 127 128 /** 129 * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This 130 * method is to implement a simple version of RTTI, since not all C++ 131 * compilers support genuine RTTI. Polymorphic operator==() and clone() 132 * methods call this method. 133 * 134 * @return The class ID for this object. All objects of a 135 * given class have the same class ID. Objects of 136 * other classes have different class IDs. 137 * @stable ICU 4.2 138 */ 139 virtual UClassID getDynamicClassID(void) const; 140 141 142 /** 143 * Get the time unit. 144 * @return time unit object. 145 * @stable ICU 4.2 146 */ 147 const TimeUnit& getTimeUnit() const; 148 149 /** 150 * Get the time unit field value. 151 * @return time unit field value. 152 * @stable ICU 4.2 153 */ 154 TimeUnit::UTimeUnitFields getTimeUnitField() const; 155 }; 156 157 158 159 inline UBool 160 TimeUnitAmount::operator!=(const UObject& other) const { 161 return !operator==(other); 162 } 163 164 U_NAMESPACE_END 165 166 #endif /* #if !UCONFIG_NO_FORMATTING */ 167 168 #endif // __TMUTAMT_H__ 169 //eof 170 // 171