blob: 066d3e90baaee846ed287804b50a54d10b0376d2 [file] [log] [blame]
Alexander Afanasyev85b17b82014-11-10 16:22:05 -08001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2013-2014 Regents of the University of California.
4 *
5 * This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
6 *
7 * ndn-cxx library is free software: you can redistribute it and/or modify it under the
8 * terms of the GNU Lesser General Public License as published by the Free Software
9 * Foundation, either version 3 of the License, or (at your option) any later version.
10 *
11 * ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13 * PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14 *
15 * You should have received copies of the GNU General Public License and GNU Lesser
16 * General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17 * <http://www.gnu.org/licenses/>.
18 *
19 * See AUTHORS.md for complete list of ndn-cxx authors and contributors.
20 */
21
22#ifndef NDN_TIME_CUSTOM_CLOCK_HPP
23#define NDN_TIME_CUSTOM_CLOCK_HPP
24
25#include "time.hpp"
26
27namespace ndn {
28namespace time {
29
30/**
31 * \brief Class implementing custom system or steady clock behavior
32 *
33 * Instance of specialization of this class may be passed to setCustomClocks() free function
34 * in order to change global behavior of system or steady clock.
35 */
36template<typename BaseClock>
37class CustomClock
38{
39public:
40 virtual ~CustomClock()
41 {
42 }
43
44 virtual typename BaseClock::time_point
45 getNow() const = 0;
46
47 virtual std::string
48 getSince() const = 0;
49
50 virtual boost::posix_time::time_duration
51 toPosixDuration(const typename BaseClock::duration& duration) const = 0;
52};
53
54typedef CustomClock<system_clock> CustomSystemClock;
55typedef CustomClock<steady_clock> CustomSteadyClock;
56
57/**
58 * \brief Set custom system and steady clocks
59 *
60 * When \p steadyClock or \p systemClock set to nullptr, the default implementation
61 * of the corresponding clock will be used
62 */
63void
64setCustomClocks(shared_ptr<CustomSteadyClock> steadyClock = nullptr,
65 shared_ptr<CustomSystemClock> systemClock = nullptr);
66
67} // namespace time
68} // namespace ndn
69
70#endif // NDN_TIME_CUSTOM_CLOCK_HPP