A wrapping integer used to support time durations (WARNING: only instantiate with a signed type)
More...
template<typename int_type_, int_type_ wrap_val>
class boost::date_time::wrapping_int< int_type_, wrap_val >
A wrapping integer used to support time durations (WARNING: only instantiate with a signed type)
In composite date and time types this type is used to wrap at the day boundary. Ex: A wrapping_int<short, 10> will roll over after nine, and roll under below zero. This gives a range of [0,9]
NOTE: it is strongly recommended that wrapping_int2 be used instead of wrapping_int as wrapping_int is to be depricated at some point soon.
Also Note that warnings will occur if instantiated with an unsigned type. Only a signed type should be used!
template<typename int_type_ , int_type_ wrap_val>
template<typename IntT >
Add, return number of wraps performed.
The sign of the returned value will indicate which direction the wraps went. Ex: add a negative number and wrapping under could occur, this would be indicated by a negative return value. If wrapping over took place, a positive value would be returned
template<typename int_type_ , int_type_ wrap_val>
template<typename IntT >
Subtract will return '+d' if wrapping under took place ('d' is the number of wraps)
The sign of the returned value will indicate which direction the wraps went (positive indicates wrap under, negative indicates wrap over). Ex: subtract a negative number and wrapping over could occur, this would be indicated by a negative return value. If wrapping under took place, a positive value would be returned.