From b13c859ff1280f3d9236db5ee3a4296b2b0a60a6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomasz=20Kami=C5=84ski?= Date: Fri, 24 Nov 2017 23:34:19 +0100 Subject: [PATCH] Restored deprecated to_clock_time function. Fixed the to_utc_time(const gps_time& t) function to correctly use clock_cast. Added test to deprecated functions. --- include/date/tz.h | 101 ++++++++++++++++++++++ test/clock_cast_test/deprecated.pass.cpp | 102 +++++++++++++++++++++++ 2 files changed, 203 insertions(+) create mode 100644 test/clock_cast_test/deprecated.pass.cpp diff --git a/include/date/tz.h b/include/date/tz.h index 0589a6f..b2cbc24 100644 --- a/include/date/tz.h +++ b/include/date/tz.h @@ -2417,6 +2417,107 @@ auto clock_cast(const std::chrono::time_point& st) return clock_cast_detail::cc_impl(st, &st); } +// Deprecated API + +template +inline +sys_time::type> +to_sys_time(const utc_time& t) +{ + return clock_cast(t); +} + +template +inline +sys_time::type> +to_sys_time(const tai_time& t) +{ + return clock_cast(t); +} + +template +inline +sys_time::type> +to_sys_time(const gps_time& t) +{ + return clock_cast(t); +} + + +template +inline +utc_time::type> +to_utc_time(const sys_time& t) +{ + return clock_cast(t); +} + +template +inline +utc_time::type> +to_utc_time(const tai_time& t) +{ + return clock_cast(t); +} + +template +inline +utc_time::type> +to_utc_time(const gps_time& t) +{ + return clock_cast(t); +} + + +template +inline +tai_time::type> +to_tai_time(const sys_time& t) +{ + return clock_cast(t); +} + +template +inline +tai_time::type> +to_tai_time(const utc_time& t) +{ + return clock_cast(t); +} + +template +inline +tai_time::type> +to_tai_time(const gps_time& t) +{ + return clock_cast(t); +} + + +template +inline +gps_time::type> +to_gps_time(const sys_time& t) +{ + return clock_cast(t); +} + +template +inline +gps_time::type> +to_gps_time(const utc_time& t) +{ + return clock_cast(t); +} + +template +inline +gps_time::type> +to_gps_time(const tai_time& t) +{ + return clock_cast(t); +} + #endif // !MISSING_LEAP_SECONDS } // namespace date diff --git a/test/clock_cast_test/deprecated.pass.cpp b/test/clock_cast_test/deprecated.pass.cpp new file mode 100644 index 0000000..b2f427b --- /dev/null +++ b/test/clock_cast_test/deprecated.pass.cpp @@ -0,0 +1,102 @@ +// The MIT License (MIT) +// +// Copyright (c) 2017 Tomasz KamiƄski +// +// 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, ARISING FROM, +// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +// SOFTWARE. + +#include "tz.h" +#include + +int +main() +{ + using namespace date; + using sys_clock = std::chrono::system_clock; + + // self + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + auto tt = tai_clock::from_utc(ut); + + assert(clock_cast(st) == st); + assert(clock_cast(ut) == ut); + assert(clock_cast(tt) == tt); + } + + // sys <-> utc + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + + assert(clock_cast(st) == ut); + assert(clock_cast(ut) == st); + } + + // tai <-> utc + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + auto tt = tai_clock::from_utc(ut); + + assert(clock_cast(ut) == tt); + assert(clock_cast(tt) == ut); + } + + // tai <-> sys + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + auto tt = tai_clock::from_utc(ut); + + assert(clock_cast(st) == tt); + assert(clock_cast(tt) == st); + } + + // gps <-> utc + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + auto gt = gps_clock::from_utc(ut); + + assert(clock_cast(ut) == gt); + assert(clock_cast(gt) == ut); + } + + // gps <-> sys + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + auto gt = gps_clock::from_utc(ut); + + assert(clock_cast(st) == gt); + assert(clock_cast(gt) == st); + } + + // tai <-> gps + { + sys_days st(1997_y/dec/12); + auto ut = utc_clock::from_sys(st); + auto tt = tai_clock::from_utc(ut); + auto gt = gps_clock::from_utc(ut); + + assert(clock_cast(tt) == gt); + assert(clock_cast(gt) == tt); + } +}