From 658a3b94955d876675caca033fb799f5169a389c Mon Sep 17 00:00:00 2001 From: Howard Hinnant Date: Mon, 17 Aug 2020 21:32:29 -0400 Subject: [PATCH] Fix crasher for early local times and USE_OS_TZDB=1 --- src/tz.cpp | 27 +++++++++++++++++++-------- 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/src/tz.cpp b/src/tz.cpp index f455f22..b5f0244 100644 --- a/src/tz.cpp +++ b/src/tz.cpp @@ -2125,14 +2125,25 @@ time_zone::load_sys_info(std::vector::const_iterator i) cons { using namespace std::chrono; assert(!transitions_.empty()); - assert(i != transitions_.begin()); sys_info r; - r.begin = i[-1].timepoint; - r.end = i != transitions_.end() ? i->timepoint : - sys_seconds(sys_days(year::max()/max_day)); - r.offset = i[-1].info->offset; - r.save = i[-1].info->is_dst ? minutes{1} : minutes{0}; - r.abbrev = i[-1].info->abbrev; + if (i != transitions_.begin()) + { + r.begin = i[-1].timepoint; + r.end = i != transitions_.end() ? i->timepoint : + sys_seconds(sys_days(year::max()/max_day)); + r.offset = i[-1].info->offset; + r.save = i[-1].info->is_dst ? minutes{1} : minutes{0}; + r.abbrev = i[-1].info->abbrev; + } + else + { + r.begin = sys_days(year::min()/min_day); + r.end = i+1 != transitions_.end() ? i[1].timepoint : + sys_seconds(sys_days(year::max()/max_day)); + r.offset = i[0].info->offset; + r.save = i[0].info->is_dst ? minutes{1} : minutes{0}; + r.abbrev = i[0].info->abbrev; + } return r; } @@ -2167,7 +2178,7 @@ time_zone::get_info_impl(local_seconds tp) const { i.second = load_sys_info(--tr); tps = sys_seconds{(tp - i.second.offset).time_since_epoch()}; - if (tps < i.second.end) + if (tps < i.second.end && i.first.end != i.second.end) { i.result = local_info::ambiguous; std::swap(i.first, i.second);