[857] | 1 | #ifndef DATE_DURATION_OPERATORS_HPP___
|
---|
| 2 | #define DATE_DURATION_OPERATORS_HPP___
|
---|
| 3 |
|
---|
| 4 | /* Copyright (c) 2004 CrystalClear Software, Inc.
|
---|
| 5 | * Subject to the Boost Software License, Version 1.0.
|
---|
| 6 | * (See accompanying file LICENSE-1.0 or
|
---|
| 7 | * http://www.boost.org/LICENSE-1.0)
|
---|
| 8 | * Author: Jeff Garland, Bart Garst
|
---|
| 9 | * $Date: 2004/08/16 21:59:53 $
|
---|
| 10 | */
|
---|
| 11 |
|
---|
| 12 | #include "boost/date_time/gregorian/greg_duration_types.hpp"
|
---|
| 13 | #include "boost/date_time/posix_time/ptime.hpp"
|
---|
| 14 |
|
---|
| 15 | namespace boost {
|
---|
| 16 | namespace posix_time {
|
---|
| 17 |
|
---|
| 18 | /*!@file date_duration_operators.hpp Operators for ptime and
|
---|
| 19 | * optional gregorian types. Operators use snap-to-end-of-month behavior.
|
---|
| 20 | * Further details on this behavior can be found in reference for
|
---|
| 21 | * date_time/date_duration_types.hpp and documentation for
|
---|
| 22 | * month and year iterators.
|
---|
| 23 | */
|
---|
| 24 |
|
---|
| 25 |
|
---|
| 26 | /*! Adds a months object and a ptime. Result will be same
|
---|
| 27 | * day-of-month as ptime unless original day was the last day of month.
|
---|
| 28 | * see date_time::months_duration for more details */
|
---|
| 29 | inline
|
---|
| 30 | ptime
|
---|
| 31 | operator+(const ptime& t, const boost::gregorian::months& m)
|
---|
| 32 | {
|
---|
| 33 | return t + m.get_offset(t.date());
|
---|
| 34 | }
|
---|
| 35 |
|
---|
| 36 | /*! Adds a months object to a ptime. Result will be same
|
---|
| 37 | * day-of-month as ptime unless original day was the last day of month.
|
---|
| 38 | * see date_time::months_duration for more details */
|
---|
| 39 | inline
|
---|
| 40 | ptime
|
---|
| 41 | operator+=(ptime& t, const boost::gregorian::months& m)
|
---|
| 42 | {
|
---|
| 43 | // get_neg_offset returns a negative duration, so we add
|
---|
| 44 | return t += m.get_offset(t.date());
|
---|
| 45 | }
|
---|
| 46 |
|
---|
| 47 | /*! Subtracts a months object and a ptime. Result will be same
|
---|
| 48 | * day-of-month as ptime unless original day was the last day of month.
|
---|
| 49 | * see date_time::months_duration for more details */
|
---|
| 50 | inline
|
---|
| 51 | ptime
|
---|
| 52 | operator-(const ptime& t, const boost::gregorian::months& m)
|
---|
| 53 | {
|
---|
| 54 | // get_neg_offset returns a negative duration, so we add
|
---|
| 55 | return t + m.get_neg_offset(t.date());
|
---|
| 56 | }
|
---|
| 57 |
|
---|
| 58 | /*! Subtracts a months object from a ptime. Result will be same
|
---|
| 59 | * day-of-month as ptime unless original day was the last day of month.
|
---|
| 60 | * see date_time::months_duration for more details */
|
---|
| 61 | inline
|
---|
| 62 | ptime
|
---|
| 63 | operator-=(ptime& t, const boost::gregorian::months& m)
|
---|
| 64 | {
|
---|
| 65 | return t += m.get_neg_offset(t.date());
|
---|
| 66 | }
|
---|
| 67 |
|
---|
| 68 | // ptime & years
|
---|
| 69 |
|
---|
| 70 | /*! Adds a years object and a ptime. Result will be same
|
---|
| 71 | * month and day-of-month as ptime unless original day was the
|
---|
| 72 | * last day of month. see date_time::years_duration for more details */
|
---|
| 73 | inline
|
---|
| 74 | ptime
|
---|
| 75 | operator+(const ptime& t, const boost::gregorian::years& y)
|
---|
| 76 | {
|
---|
| 77 | return t + y.get_offset(t.date());
|
---|
| 78 | }
|
---|
| 79 |
|
---|
| 80 | /*! Adds a years object to a ptime. Result will be same
|
---|
| 81 | * month and day-of-month as ptime unless original day was the
|
---|
| 82 | * last day of month. see date_time::years_duration for more details */
|
---|
| 83 | inline
|
---|
| 84 | ptime
|
---|
| 85 | operator+=(ptime& t, const boost::gregorian::years& y)
|
---|
| 86 | {
|
---|
| 87 | return t += y.get_offset(t.date());
|
---|
| 88 | }
|
---|
| 89 |
|
---|
| 90 | /*! Subtracts a years object and a ptime. Result will be same
|
---|
| 91 | * month and day-of-month as ptime unless original day was the
|
---|
| 92 | * last day of month. see date_time::years_duration for more details */
|
---|
| 93 | inline
|
---|
| 94 | ptime
|
---|
| 95 | operator-(const ptime& t, const boost::gregorian::years& y)
|
---|
| 96 | {
|
---|
| 97 | // get_neg_offset returns a negative duration, so we add
|
---|
| 98 | return t + y.get_neg_offset(t.date());
|
---|
| 99 | }
|
---|
| 100 |
|
---|
| 101 | /*! Subtracts a years object from a ptime. Result will be same
|
---|
| 102 | * month and day-of-month as ptime unless original day was the
|
---|
| 103 | * last day of month. see date_time::years_duration for more details */
|
---|
| 104 | inline
|
---|
| 105 | ptime
|
---|
| 106 | operator-=(ptime& t, const boost::gregorian::years& y)
|
---|
| 107 | {
|
---|
| 108 | // get_neg_offset returns a negative duration, so we add
|
---|
| 109 | return t += y.get_neg_offset(t.date());
|
---|
| 110 | }
|
---|
| 111 |
|
---|
| 112 | }} // namespaces
|
---|
| 113 |
|
---|
| 114 | #endif // DATE_DURATION_OPERATORS_HPP___
|
---|