/* * Copyright (c) 2017-2019 Cisco and/or its affiliates. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at: * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #pragma once #include #include #include #include #include namespace std { namespace chrono { namespace detail { template struct posix_duration_cast; // chrono -> timespec caster template struct posix_duration_cast, struct timespec> { static struct timespec cast(std::chrono::duration const &d) { struct timespec tv; std::chrono::seconds const sec = std::chrono::duration_cast(d); tv.tv_sec = sec.count(); tv.tv_nsec = std::chrono::duration_cast(d - sec).count(); return tv; } }; // timespec -> chrono caster template struct posix_duration_cast> { static std::chrono::duration cast(struct timespec const &tv) { return std::chrono::duration_cast>( std::chrono::seconds(tv.tv_sec) + std::chrono::nanoseconds(tv.tv_nsec)); } }; } // namespace detail // chrono -> timespec template auto duration_cast(std::chrono::duration const &d) -> typename std::enable_if::value, struct timespec>::type { return detail::posix_duration_cast, timespec>::cast(d); } // timespec -> chrono template Duration duration_cast(struct timespec const &tv) { return detail::posix_duration_cast::cast(tv); } } // namespace chrono } // namespace std namespace utils { template class DeadlineTimer { public: virtual ~DeadlineTimer() = default; template void asyncWait(WaitHandler &&callback) { static_cast(this)->asyncWaitImpl( std::forward(callback)); } void wait() { static_cast(this)->waitImpl(); } template void expiresFromNow(std::chrono::duration &&duration) { static_cast(this)->expiresFromNowImpl( std::forward>(duration)); } template , std::chrono::steady_clock::time_point>::value, TimePoint>::type> void expiresAt(TimePoint &&time_point) { static_cast(this)->expiresAtImpl( std::forward(time_point)); } void cancel() { static_cast(this)->cancelImpl(); } }; } // namespace utils