neoGFX
Cross-platform C++ app/game engine
Loading...
Searching...
No Matches
chrono.hpp
Go to the documentation of this file.
1// chrono.hpp
2/*
3 * Copyright (c) 2015, 2020 Leigh Johnston.
4 *
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions are
9 * met:
10 *
11 * * Redistributions of source code must retain the above copyright
12 * notice, this list of conditions and the following disclaimer.
13 *
14 * * Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
17 *
18 * * Neither the name of Leigh Johnston nor the names of any
19 * other contributors to this software may be used to endorse or
20 * promote products derived from this software without specific prior
21 * written permission.
22 *
23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
24 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
25 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
26 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
27 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
29 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 */
35
36#pragma once
37
38#include <neolib/neolib.hpp>
40#include <neolib/ecs/i_ecs.hpp>
42
43namespace neolib::ecs
44{
45 namespace chrono
46 {
47 using namespace facebook::util;
48
49 inline constexpr double to_milliseconds(const flicks ns)
50 {
51 return static_cast<double>(std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::duration<double>(ns)).count());
52 }
53 }
54
56 typedef std::optional<time_interval> optional_time_interval;
57 typedef int64_t step_time_interval;
58 typedef std::optional<step_time_interval> optional_step_time_interval;
60 typedef std::optional<step_time> optional_step_time;
61
63 {
64 auto fs = chrono::to_flicks(aTime).count();
65 return fs - (fs % aStepInterval);
66 }
67
69 {
70 if (aTime)
71 return to_step_time(*aTime, aStepInterval);
72 else
73 return 0;
74 }
75
77 {
78 return chrono::to_seconds(chrono::flicks{ aStepTime });
79 }
80}
constexpr double to_seconds(const flicks ns)
Definition flicks.h:77
std::chrono::duration< std::chrono::nanoseconds::rep, std::ratio< 1, 705600000 > > flicks
Definition flicks.h:60
constexpr flicks to_flicks(const double s)
Definition flicks.h:83
constexpr double to_milliseconds(const flicks ns)
Definition chrono.hpp:49
std::optional< step_time > optional_step_time
Definition chrono.hpp:60
time_interval from_step_time(step_time_interval aStepTime)
Definition chrono.hpp:76
scalar time_interval
Definition chrono.hpp:55
std::optional< step_time_interval > optional_step_time_interval
Definition chrono.hpp:58
step_time_interval step_time
Definition chrono.hpp:59
int64_t step_time_interval
Definition chrono.hpp:57
std::optional< time_interval > optional_time_interval
Definition chrono.hpp:56
step_time_interval to_step_time(time_interval aTime, step_time_interval aStepInterval)
Definition chrono.hpp:62
double scalar
Definition numerical.hpp:63