2015-12-24 17:10:02 -05:00
|
|
|
// Copyright (c) 2014-2016 Thomas Fussell
|
2015-12-24 15:51:11 -05:00
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
// of this software and associated documentation files (the "Software"), to deal
|
|
|
|
// in the Software without restriction, including without limitation the rights
|
|
|
|
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
// copies of the Software, and to permit persons to whom the Software is
|
|
|
|
// furnished to do so, subject to the following conditions:
|
|
|
|
//
|
|
|
|
// The above copyright notice and this permission notice shall be included in
|
|
|
|
// all copies or substantial portions of the Software.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, WRISING FROM,
|
|
|
|
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
// THE SOFTWARE
|
|
|
|
//
|
|
|
|
// @license: http://www.opensource.org/licenses/mit-license.php
|
|
|
|
// @author: see AUTHORS file
|
2015-11-19 22:54:54 -05:00
|
|
|
#include <cmath>
|
|
|
|
#include <ctime>
|
|
|
|
|
|
|
|
#include <xlnt/utils/timedelta.hpp>
|
|
|
|
|
|
|
|
namespace xlnt {
|
|
|
|
|
2015-11-22 12:41:27 -05:00
|
|
|
timedelta::timedelta() : timedelta(0, 0, 0, 0, 0)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
timedelta::timedelta(int days_, int hours_, int minutes_, int seconds_, int microseconds_)
|
|
|
|
: days(days_),
|
|
|
|
hours(hours_),
|
|
|
|
minutes(minutes_),
|
|
|
|
seconds(seconds_),
|
|
|
|
microseconds(microseconds_)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2015-11-22 13:02:37 -05:00
|
|
|
long double timedelta::to_number() const
|
2015-11-19 22:54:54 -05:00
|
|
|
{
|
2015-11-22 12:41:27 -05:00
|
|
|
std::uint64_t total_microseconds = static_cast<std::uint64_t>(microseconds);
|
|
|
|
total_microseconds += static_cast<std::uint64_t>(seconds * 1e6);
|
|
|
|
total_microseconds += static_cast<std::uint64_t>(minutes * 1e6 * 60);
|
|
|
|
auto microseconds_per_hour = static_cast<std::uint64_t>(1e6) * 60 * 60;
|
|
|
|
total_microseconds += static_cast<std::uint64_t>(hours) * microseconds_per_hour;
|
|
|
|
auto number = total_microseconds / (24.0L * microseconds_per_hour);
|
|
|
|
auto hundred_billion = static_cast<std::uint64_t>(1e9) * 100;
|
|
|
|
number = std::floor(number * hundred_billion + 0.5L) / hundred_billion;
|
|
|
|
number += days;
|
|
|
|
|
|
|
|
return number;
|
2015-11-19 22:54:54 -05:00
|
|
|
}
|
|
|
|
|
2015-11-22 12:41:27 -05:00
|
|
|
timedelta timedelta::from_number(long double raw_time)
|
2015-11-19 22:54:54 -05:00
|
|
|
{
|
2015-11-22 12:41:27 -05:00
|
|
|
timedelta result;
|
|
|
|
|
2015-11-22 13:02:37 -05:00
|
|
|
long double integer_part;
|
|
|
|
long double fractional_part = std::modf(raw_time, &integer_part);
|
2015-11-22 12:41:27 -05:00
|
|
|
|
2015-11-22 13:02:37 -05:00
|
|
|
result.days = static_cast<int>(integer_part);
|
2015-11-22 12:41:27 -05:00
|
|
|
|
|
|
|
fractional_part *= 24;
|
|
|
|
result.hours = (int)fractional_part;
|
|
|
|
fractional_part = 60 * (fractional_part - result.hours);
|
|
|
|
result.minutes = (int)fractional_part;
|
|
|
|
fractional_part = 60 * (fractional_part - result.minutes);
|
|
|
|
result.seconds = (int)fractional_part;
|
|
|
|
fractional_part = 1000000 * (fractional_part - result.seconds);
|
|
|
|
result.microseconds = (int)fractional_part;
|
|
|
|
|
|
|
|
if (result.microseconds == 999999 && fractional_part - result.microseconds > 0.5)
|
|
|
|
{
|
|
|
|
result.microseconds = 0;
|
|
|
|
result.seconds += 1;
|
|
|
|
|
|
|
|
if (result.seconds == 60)
|
|
|
|
{
|
|
|
|
result.seconds = 0;
|
|
|
|
result.minutes += 1;
|
|
|
|
|
|
|
|
//TODO: too much nesting
|
|
|
|
if (result.minutes == 60)
|
|
|
|
{
|
|
|
|
result.minutes = 0;
|
|
|
|
result.hours += 1;
|
2016-07-16 19:40:20 -04:00
|
|
|
|
|
|
|
if (result.hours == 24)
|
|
|
|
{
|
|
|
|
result.hours = 0;
|
|
|
|
result.days += 1;
|
|
|
|
}
|
2015-11-22 12:41:27 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-11-19 22:54:54 -05:00
|
|
|
|
2015-11-22 12:41:27 -05:00
|
|
|
return result;
|
2015-11-19 22:54:54 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace xlnt
|