]> git.sesse.net Git - casparcg/blob - common/timer.h
Created abstraction for property tree get(), get_child() and get_value() to be able...
[casparcg] / common / timer.h
1 /*
2 * Copyright (c) 2011 Sveriges Television AB <info@casparcg.com>
3 *
4 * This file is part of CasparCG (www.casparcg.com).
5 *
6 * CasparCG is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation, either version 3 of the License, or
9 * (at your option) any later version.
10 *
11 * CasparCG is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with CasparCG. If not, see <http://www.gnu.org/licenses/>.
18 *
19 * Author: Helge Norberg, helge.norberg@svt.se
20 */
21
22 #pragma once
23
24 #include <boost/chrono/system_clocks.hpp>
25
26 namespace caspar {
27
28 // Replacement of boost::timer because it uses std::clock which has very low resolution in linux.
29 class timer
30 {
31         boost::int_least64_t _start_time;
32 public:
33         timer()
34         {
35                 _start_time = now();
36         }
37
38         void restart()
39         {
40                 _start_time = now();
41         }
42
43         double elapsed() const
44         {
45                 return static_cast<double>(now() - _start_time) / 1000.0;
46         }
47 private:
48         static boost::int_least64_t now()
49         {
50                 using namespace boost::chrono;
51
52                 return duration_cast<milliseconds>(high_resolution_clock::now().time_since_epoch()).count();
53         }
54 };
55
56 }