1 // © 2016 and later: Unicode, Inc. and others. 2 // License & terms of use: http://www.unicode.org/copyright.html 3 /* 4 ******************************************************************************* 5 * Copyright (C) 2008-2009, International Business Machines Corporation and 6 * others. All Rights Reserved. 7 ******************************************************************************* 8 * 9 * File DTINTRV.H 10 * 11 ******************************************************************************* 12 */ 13 14 #ifndef __DTINTRV_H__ 15 #define __DTINTRV_H__ 16 17 #include "unicode/utypes.h" 18 19 #if U_SHOW_CPLUSPLUS_API 20 21 #include "unicode/uobject.h" 22 23 /** 24 * \file 25 * \brief C++ API: Date Interval data type 26 */ 27 28 U_NAMESPACE_BEGIN 29 30 31 /** 32 * This class represents a date interval. 33 * It is a pair of UDate representing from UDate 1 to UDate 2. 34 * @stable ICU 4.0 35 **/ 36 class U_COMMON_API DateInterval : public UObject { 37 public: 38 39 /** 40 * Construct a DateInterval given a from date and a to date. 41 * @param fromDate The from date in date interval. 42 * @param toDate The to date in date interval. 43 * @stable ICU 4.0 44 */ 45 DateInterval(UDate fromDate, UDate toDate); 46 47 /** 48 * destructor 49 * @stable ICU 4.0 50 */ 51 virtual ~DateInterval(); 52 53 /** 54 * Get the from date. 55 * @return the from date in dateInterval. 56 * @stable ICU 4.0 57 */ 58 inline UDate getFromDate() const; 59 60 /** 61 * Get the to date. 62 * @return the to date in dateInterval. 63 * @stable ICU 4.0 64 */ 65 inline UDate getToDate() const; 66 67 68 /** 69 * Return the class ID for this class. This is useful only for comparing to 70 * a return value from getDynamicClassID(). For example: 71 * <pre> 72 * . Base* polymorphic_pointer = createPolymorphicObject(); 73 * . if (polymorphic_pointer->getDynamicClassID() == 74 * . derived::getStaticClassID()) ... 75 * </pre> 76 * @return The class ID for all objects of this class. 77 * @stable ICU 4.0 78 */ 79 static UClassID U_EXPORT2 getStaticClassID(void); 80 81 /** 82 * Returns a unique class ID POLYMORPHICALLY. Pure virtual override. This 83 * method is to implement a simple version of RTTI, since not all C++ 84 * compilers support genuine RTTI. Polymorphic operator==() and clone() 85 * methods call this method. 86 * 87 * @return The class ID for this object. All objects of a 88 * given class have the same class ID. Objects of 89 * other classes have different class IDs. 90 * @stable ICU 4.0 91 */ 92 virtual UClassID getDynamicClassID(void) const override; 93 94 95 /** 96 * Copy constructor. 97 * @stable ICU 4.0 98 */ 99 DateInterval(const DateInterval& other); 100 101 /** 102 * Default assignment operator 103 * @stable ICU 4.0 104 */ 105 DateInterval& operator=(const DateInterval&); 106 107 /** 108 * Equality operator. 109 * @return true if the two DateIntervals are the same 110 * @stable ICU 4.0 111 */ 112 virtual bool operator==(const DateInterval& other) const; 113 114 /** 115 * Non-equality operator 116 * @return true if the two DateIntervals are not the same 117 * @stable ICU 4.0 118 */ 119 inline bool operator!=(const DateInterval& other) const; 120 121 122 /** 123 * clone this object. 124 * The caller owns the result and should delete it when done. 125 * @return a cloned DateInterval 126 * @stable ICU 4.0 127 */ 128 virtual DateInterval* clone() const; 129 130 private: 131 /** 132 * Default constructor, not implemented. 133 */ 134 DateInterval() = delete; 135 136 UDate fromDate; 137 UDate toDate; 138 139 } ;// end class DateInterval 140 141 142 inline UDate getFromDate()143DateInterval::getFromDate() const { 144 return fromDate; 145 } 146 147 148 inline UDate getToDate()149DateInterval::getToDate() const { 150 return toDate; 151 } 152 153 154 inline bool 155 DateInterval::operator!=(const DateInterval& other) const { 156 return ( !operator==(other) ); 157 } 158 159 160 U_NAMESPACE_END 161 162 #endif /* U_SHOW_CPLUSPLUS_API */ 163 164 #endif 165