Bitcoin Core  27.99.0
P2P Digital Currency
time.cpp
Go to the documentation of this file.
1 // Copyright (c) 2009-2010 Satoshi Nakamoto
2 // Copyright (c) 2009-2022 The Bitcoin Core developers
3 // Distributed under the MIT software license, see the accompanying
4 // file COPYING or http://www.opensource.org/licenses/mit-license.php.
5 
6 #include <util/time.h>
7 
8 #include <compat/compat.h>
9 #include <tinyformat.h>
10 #include <util/check.h>
11 
12 #include <atomic>
13 #include <chrono>
14 #include <string>
15 #include <thread>
16 
17 void UninterruptibleSleep(const std::chrono::microseconds& n) { std::this_thread::sleep_for(n); }
18 
19 static std::atomic<int64_t> nMockTime(0);
20 
22 {
23  const std::chrono::seconds mocktime{nMockTime.load(std::memory_order_relaxed)};
24  const auto ret{
25  mocktime.count() ?
26  mocktime :
27  std::chrono::system_clock::now().time_since_epoch()};
28  assert(ret > 0s);
29  return time_point{ret};
30 };
31 
32 void SetMockTime(int64_t nMockTimeIn)
33 {
34  Assert(nMockTimeIn >= 0);
35  nMockTime.store(nMockTimeIn, std::memory_order_relaxed);
36 }
37 
38 void SetMockTime(std::chrono::seconds mock_time_in)
39 {
40  nMockTime.store(mock_time_in.count(), std::memory_order_relaxed);
41 }
42 
43 std::chrono::seconds GetMockTime()
44 {
45  return std::chrono::seconds(nMockTime.load(std::memory_order_relaxed));
46 }
47 
48 int64_t GetTime() { return GetTime<std::chrono::seconds>().count(); }
49 
50 std::string FormatISO8601DateTime(int64_t nTime)
51 {
52  const std::chrono::sys_seconds secs{std::chrono::seconds{nTime}};
53  const auto days{std::chrono::floor<std::chrono::days>(secs)};
54  const std::chrono::year_month_day ymd{days};
55  const std::chrono::hh_mm_ss hms{secs - days};
56  return strprintf("%04i-%02u-%02uT%02i:%02i:%02iZ", signed{ymd.year()}, unsigned{ymd.month()}, unsigned{ymd.day()}, hms.hours().count(), hms.minutes().count(), hms.seconds().count());
57 }
58 
59 std::string FormatISO8601Date(int64_t nTime)
60 {
61  const std::chrono::sys_seconds secs{std::chrono::seconds{nTime}};
62  const auto days{std::chrono::floor<std::chrono::days>(secs)};
63  const std::chrono::year_month_day ymd{days};
64  return strprintf("%04i-%02u-%02u", signed{ymd.year()}, unsigned{ymd.month()}, unsigned{ymd.day()});
65 }
66 
67 struct timeval MillisToTimeval(int64_t nTimeout)
68 {
69  struct timeval timeout;
70  timeout.tv_sec = nTimeout / 1000;
71  timeout.tv_usec = (nTimeout % 1000) * 1000;
72  return timeout;
73 }
74 
75 struct timeval MillisToTimeval(std::chrono::milliseconds ms)
76 {
78 }
int ret
#define Assert(val)
Identity function.
Definition: check.h:77
static time_point now() noexcept
Return current system time or mocked time, if set.
Definition: time.cpp:21
std::chrono::time_point< NodeClock > time_point
Definition: time.h:17
static int count
static std::atomic< int64_t > nMockTime(0)
For testing.
struct timeval MillisToTimeval(int64_t nTimeout)
Convert milliseconds to a struct timeval for e.g.
Definition: time.cpp:67
void UninterruptibleSleep(const std::chrono::microseconds &n)
Definition: time.cpp:17
std::chrono::seconds GetMockTime()
For testing.
Definition: time.cpp:43
int64_t GetTime()
Definition: time.cpp:48
std::string FormatISO8601Date(int64_t nTime)
Definition: time.cpp:59
void SetMockTime(int64_t nMockTimeIn)
DEPRECATED Use SetMockTime with chrono type.
Definition: time.cpp:32
std::string FormatISO8601DateTime(int64_t nTime)
ISO 8601 formatting is preferred.
Definition: time.cpp:50
constexpr int64_t count_milliseconds(std::chrono::milliseconds t)
Definition: time.h:55
#define strprintf
Format arguments and return the string or write to given std::ostream (see tinyformat::format doc for...
Definition: tinyformat.h:1162
assert(!tx.IsCoinBase())