1 | #ifndef DATE_TIME_DATE_DURATION__ |
---|
2 | #define DATE_TIME_DATE_DURATION__ |
---|
3 | |
---|
4 | /* Copyright (c) 2002,2003 CrystalClear Software, Inc. |
---|
5 | * Use, modification and distribution is subject to the |
---|
6 | * Boost Software License, Version 1.0. (See accompanying |
---|
7 | * file LICENSE-1.0 or http://www.boost.org/LICENSE-1.0) |
---|
8 | * Author: Jeff Garland, Bart Garst |
---|
9 | * $Date: 2003/12/03 01:56:13 $ |
---|
10 | */ |
---|
11 | |
---|
12 | |
---|
13 | #include <boost/operators.hpp> |
---|
14 | |
---|
15 | namespace boost { |
---|
16 | namespace date_time { |
---|
17 | |
---|
18 | |
---|
19 | //! Duration type with date level resolution |
---|
20 | template<class duration_rep_traits> |
---|
21 | class date_duration : private |
---|
22 | boost::less_than_comparable<date_duration< duration_rep_traits> |
---|
23 | , boost::equality_comparable< date_duration< duration_rep_traits> |
---|
24 | , boost::addable< date_duration< duration_rep_traits> |
---|
25 | , boost::subtractable< date_duration< duration_rep_traits> |
---|
26 | > > > > |
---|
27 | { |
---|
28 | public: |
---|
29 | typedef typename duration_rep_traits::int_type duration_rep_type; |
---|
30 | typedef typename duration_rep_traits::impl_type duration_rep; |
---|
31 | |
---|
32 | //! Construct from a day count |
---|
33 | explicit date_duration(duration_rep day_count) : days_(day_count) {}; |
---|
34 | |
---|
35 | /*! construct from special_values - only works when |
---|
36 | * instantiated with duration_traits_adapted */ |
---|
37 | date_duration(special_values sv) : |
---|
38 | days_(duration_rep::from_special(sv)) |
---|
39 | {} |
---|
40 | |
---|
41 | // copy constructor required for addable<> & subtractable<> |
---|
42 | //! Construct from another date_duration (Copy Constructor) |
---|
43 | date_duration(const date_duration<duration_rep_traits>& other) : |
---|
44 | days_(other.days_) |
---|
45 | {} |
---|
46 | |
---|
47 | //! returns days_ as it's instantiated type - used for streaming |
---|
48 | duration_rep get_rep()const |
---|
49 | { |
---|
50 | return days_; |
---|
51 | } |
---|
52 | bool is_special()const |
---|
53 | { |
---|
54 | return days_.is_special(); |
---|
55 | } |
---|
56 | //! returns days as value, not object. |
---|
57 | duration_rep_type days() const |
---|
58 | { |
---|
59 | return duration_rep_traits::as_number(days_); |
---|
60 | } |
---|
61 | //! Returns the smallest duration -- used by to calculate 'end' |
---|
62 | static date_duration unit() |
---|
63 | { |
---|
64 | return date_duration<duration_rep_traits>(1); |
---|
65 | } |
---|
66 | //! Equality |
---|
67 | bool operator==(const date_duration& rhs) const |
---|
68 | { |
---|
69 | return days_ == rhs.days_; |
---|
70 | } |
---|
71 | //! Less |
---|
72 | bool operator<(const date_duration& rhs) const |
---|
73 | { |
---|
74 | return days_ < rhs.days_; |
---|
75 | } |
---|
76 | |
---|
77 | /* For shortcut operators (+=, -=, etc) simply using |
---|
78 | * "days_ += days_" may not work. If instantiated with |
---|
79 | * an int_adapter, shortcut operators are not present, |
---|
80 | * so this will not compile */ |
---|
81 | |
---|
82 | //! Subtract another duration -- result is signed |
---|
83 | date_duration operator-=(const date_duration& rhs) |
---|
84 | { |
---|
85 | //days_ -= rhs.days_; |
---|
86 | days_ = days_ - rhs.days_; |
---|
87 | return *this; |
---|
88 | } |
---|
89 | //! Add a duration -- result is signed |
---|
90 | date_duration operator+=(const date_duration& rhs) |
---|
91 | { |
---|
92 | days_ = days_ + rhs.days_; |
---|
93 | return *this; |
---|
94 | } |
---|
95 | |
---|
96 | //! unary- Allows for dd = -date_duration(2); -> dd == -2 |
---|
97 | date_duration operator-()const |
---|
98 | { |
---|
99 | return date_duration<duration_rep_traits>(get_rep() * (-1)); |
---|
100 | } |
---|
101 | //! Division operations on a duration with an integer. |
---|
102 | date_duration<duration_rep_traits> operator/=(int divisor) |
---|
103 | { |
---|
104 | days_ = days_ / divisor; |
---|
105 | return *this; |
---|
106 | } |
---|
107 | date_duration<duration_rep_traits> operator/(int divisor) |
---|
108 | { |
---|
109 | return date_duration<duration_rep_traits>(days_ / divisor); |
---|
110 | } |
---|
111 | |
---|
112 | //! return sign information |
---|
113 | bool is_negative() const |
---|
114 | { |
---|
115 | return days_ < 0; |
---|
116 | } |
---|
117 | private: |
---|
118 | duration_rep days_; |
---|
119 | }; |
---|
120 | |
---|
121 | |
---|
122 | /*! Struct for instantiating date_duration with <b>NO</b> special values |
---|
123 | * functionality. Allows for transparent implementation of either |
---|
124 | * date_duration<long> or date_duration<int_adapter<long> > */ |
---|
125 | struct duration_traits_long |
---|
126 | { |
---|
127 | typedef long int_type; |
---|
128 | typedef long impl_type; |
---|
129 | static int_type as_number(impl_type i) { return i; }; |
---|
130 | }; |
---|
131 | |
---|
132 | /*! Struct for instantiating date_duration <b>WITH</b> special values |
---|
133 | * functionality. Allows for transparent implementation of either |
---|
134 | * date_duration<long> or date_duration<int_adapter<long> > */ |
---|
135 | struct duration_traits_adapted |
---|
136 | { |
---|
137 | typedef long int_type; |
---|
138 | typedef boost::date_time::int_adapter<long> impl_type; |
---|
139 | static int_type as_number(impl_type i) { return i.as_number(); }; |
---|
140 | }; |
---|
141 | |
---|
142 | |
---|
143 | } } //namspace date_time |
---|
144 | |
---|
145 | |
---|
146 | #endif |
---|
147 | |
---|