Throw exception if zoned_time is constructed with nullptr

This commit is contained in:
Howard Hinnant 2020-06-14 19:30:23 -04:00
parent cac99da8dc
commit d544e5af25

View File

@ -703,6 +703,11 @@ public:
private: private:
template <class D, class T> friend class zoned_time; template <class D, class T> friend class zoned_time;
template <class TimeZonePtr2>
static
TimeZonePtr2&&
check(TimeZonePtr2&& p);
}; };
using zoned_seconds = zoned_time<std::chrono::seconds>; using zoned_seconds = zoned_time<std::chrono::seconds>;
@ -1344,13 +1349,25 @@ to_raw_pointer(Pointer p) noexcept
} // namespace detail } // namespace detail
template <class Duration, class TimeZonePtr>
template <class TimeZonePtr2>
inline
TimeZonePtr2&&
zoned_time<Duration, TimeZonePtr>::check(TimeZonePtr2&& p)
{
if (detail::to_raw_pointer(p) == nullptr)
throw std::runtime_error(
"zoned_time constructed with a time zone pointer == nullptr");
return std::forward<TimeZonePtr2>(p);
}
template <class Duration, class TimeZonePtr> template <class Duration, class TimeZonePtr>
#if !defined(_MSC_VER) || (_MSC_VER > 1916) #if !defined(_MSC_VER) || (_MSC_VER > 1916)
template <class T, class> template <class T, class>
#endif #endif
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time() zoned_time<Duration, TimeZonePtr>::zoned_time()
: zone_(zoned_traits<TimeZonePtr>::default_zone()) : zone_(check(zoned_traits<TimeZonePtr>::default_zone()))
{} {}
template <class Duration, class TimeZonePtr> template <class Duration, class TimeZonePtr>
@ -1359,15 +1376,15 @@ template <class T, class>
#endif #endif
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time(const sys_time<Duration>& st) zoned_time<Duration, TimeZonePtr>::zoned_time(const sys_time<Duration>& st)
: zone_(zoned_traits<TimeZonePtr>::default_zone()) : zone_(check(zoned_traits<TimeZonePtr>::default_zone()))
, tp_(st) , tp_(st)
{} {}
template <class Duration, class TimeZonePtr> template <class Duration, class TimeZonePtr>
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z) zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z)
: zone_(std::move(z)) : zone_(check(std::move(z)))
{assert(detail::to_raw_pointer(zone_) != nullptr);} {}
#if HAS_STRING_VIEW #if HAS_STRING_VIEW
@ -1402,7 +1419,7 @@ zoned_time<Duration, TimeZonePtr>::zoned_time(const zoned_time<Duration2, TimeZo
template <class Duration, class TimeZonePtr> template <class Duration, class TimeZonePtr>
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, const sys_time<Duration>& st) zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, const sys_time<Duration>& st)
: zone_(std::move(z)) : zone_(check(std::move(z)))
, tp_(st) , tp_(st)
{} {}
@ -1412,7 +1429,7 @@ template <class T, class>
#endif #endif
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, const local_time<Duration>& t) zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, const local_time<Duration>& t)
: zone_(std::move(z)) : zone_(check(std::move(z)))
, tp_(zone_->to_sys(t)) , tp_(zone_->to_sys(t))
{} {}
@ -1423,7 +1440,7 @@ template <class T, class>
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, const local_time<Duration>& t, zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, const local_time<Duration>& t,
choose c) choose c)
: zone_(std::move(z)) : zone_(check(std::move(z)))
, tp_(zone_->to_sys(t, c)) , tp_(zone_->to_sys(t, c))
{} {}
@ -1432,7 +1449,7 @@ template <class Duration2, class TimeZonePtr2, class>
inline inline
zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z, zoned_time<Duration, TimeZonePtr>::zoned_time(TimeZonePtr z,
const zoned_time<Duration2, TimeZonePtr2>& zt) const zoned_time<Duration2, TimeZonePtr2>& zt)
: zone_(std::move(z)) : zone_(check(std::move(z)))
, tp_(zt.tp_) , tp_(zt.tp_)
{} {}