| #ifndef DATE_DURATION_OPERATORS_HPP___ |
| #define DATE_DURATION_OPERATORS_HPP___ |
| |
| /* Copyright (c) 2004 CrystalClear Software, Inc. |
| * Subject to the Boost Software License, Version 1.0. |
| * (See accompanying file LICENSE_1_0.txt or |
| * http://www.boost.org/LICENSE_1_0.txt) |
| * Author: Jeff Garland, Bart Garst |
| * $Date: 2008-02-27 15:00:24 -0500 (Wed, 27 Feb 2008) $ |
| */ |
| |
| #include "boost/date_time/gregorian/greg_duration_types.hpp" |
| #include "boost/date_time/posix_time/ptime.hpp" |
| |
| namespace boost { |
| namespace posix_time { |
| |
| /*!@file date_duration_operators.hpp Operators for ptime and |
| * optional gregorian types. Operators use snap-to-end-of-month behavior. |
| * Further details on this behavior can be found in reference for |
| * date_time/date_duration_types.hpp and documentation for |
| * month and year iterators. |
| */ |
| |
| |
| /*! Adds a months object and a ptime. Result will be same |
| * day-of-month as ptime unless original day was the last day of month. |
| * see date_time::months_duration for more details */ |
| inline |
| ptime |
| operator+(const ptime& t, const boost::gregorian::months& m) |
| { |
| return t + m.get_offset(t.date()); |
| } |
| |
| /*! Adds a months object to a ptime. Result will be same |
| * day-of-month as ptime unless original day was the last day of month. |
| * see date_time::months_duration for more details */ |
| inline |
| ptime |
| operator+=(ptime& t, const boost::gregorian::months& m) |
| { |
| // get_neg_offset returns a negative duration, so we add |
| return t += m.get_offset(t.date()); |
| } |
| |
| /*! Subtracts a months object and a ptime. Result will be same |
| * day-of-month as ptime unless original day was the last day of month. |
| * see date_time::months_duration for more details */ |
| inline |
| ptime |
| operator-(const ptime& t, const boost::gregorian::months& m) |
| { |
| // get_neg_offset returns a negative duration, so we add |
| return t + m.get_neg_offset(t.date()); |
| } |
| |
| /*! Subtracts a months object from a ptime. Result will be same |
| * day-of-month as ptime unless original day was the last day of month. |
| * see date_time::months_duration for more details */ |
| inline |
| ptime |
| operator-=(ptime& t, const boost::gregorian::months& m) |
| { |
| return t += m.get_neg_offset(t.date()); |
| } |
| |
| // ptime & years |
| |
| /*! Adds a years object and a ptime. Result will be same |
| * month and day-of-month as ptime unless original day was the |
| * last day of month. see date_time::years_duration for more details */ |
| inline |
| ptime |
| operator+(const ptime& t, const boost::gregorian::years& y) |
| { |
| return t + y.get_offset(t.date()); |
| } |
| |
| /*! Adds a years object to a ptime. Result will be same |
| * month and day-of-month as ptime unless original day was the |
| * last day of month. see date_time::years_duration for more details */ |
| inline |
| ptime |
| operator+=(ptime& t, const boost::gregorian::years& y) |
| { |
| return t += y.get_offset(t.date()); |
| } |
| |
| /*! Subtracts a years object and a ptime. Result will be same |
| * month and day-of-month as ptime unless original day was the |
| * last day of month. see date_time::years_duration for more details */ |
| inline |
| ptime |
| operator-(const ptime& t, const boost::gregorian::years& y) |
| { |
| // get_neg_offset returns a negative duration, so we add |
| return t + y.get_neg_offset(t.date()); |
| } |
| |
| /*! Subtracts a years object from a ptime. Result will be same |
| * month and day-of-month as ptime unless original day was the |
| * last day of month. see date_time::years_duration for more details */ |
| inline |
| ptime |
| operator-=(ptime& t, const boost::gregorian::years& y) |
| { |
| // get_neg_offset returns a negative duration, so we add |
| return t += y.get_neg_offset(t.date()); |
| } |
| |
| }} // namespaces |
| |
| #endif // DATE_DURATION_OPERATORS_HPP___ |