/* * Copyright 2015 Cloudius Systems */ #pragma once #include #include #include extern std::atomic clocks_offset; static inline std::chrono::seconds get_clocks_offset() { auto off = clocks_offset.load(std::memory_order_relaxed); return std::chrono::seconds(off); } // FIXME: wraps around in 2038 class gc_clock { public: using base = std::chrono::system_clock; using rep = int32_t; using period = std::ratio<1, 1>; // seconds using duration = std::chrono::duration; using time_point = std::chrono::time_point; static time_point now() { return time_point(std::chrono::duration_cast(base::now().time_since_epoch())) + get_clocks_offset(); } // Intended for tests. Allows testing time related event without need // for real time waits. }; using expiry_opt = std::experimental::optional; using ttl_opt = std::experimental::optional; // 20 years in seconds static constexpr gc_clock::duration max_ttl = gc_clock::duration{20 * 365 * 24 * 60 * 60}; template static inline void forward_jump_clocks(Duration delta) { auto d = std::chrono::duration_cast(delta).count(); clocks_offset.fetch_add(d, std::memory_order_relaxed); }