968eb3fc5d
* Implement IsMockTime to test for mock time * Add real timestamp to log output when mock time is enabled This makes debugging on Travis easier as it gives a hint about timing behavior.
35 lines
1.2 KiB
C++
35 lines
1.2 KiB
C++
// Copyright (c) 2009-2010 Satoshi Nakamoto
|
|
// Copyright (c) 2009-2015 The Bitcoin Core developers
|
|
// Distributed under the MIT software license, see the accompanying
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
#ifndef BITCOIN_UTILTIME_H
|
|
#define BITCOIN_UTILTIME_H
|
|
|
|
#include <stdint.h>
|
|
#include <string>
|
|
|
|
/**
|
|
* GetTimeMicros() and GetTimeMillis() both return the system time, but in
|
|
* different units. GetTime() returns the system time in seconds, but also
|
|
* supports mocktime, where the time can be specified by the user, eg for
|
|
* testing (eg with the setmocktime rpc, or -mocktime argument).
|
|
*
|
|
* TODO: Rework these functions to be type-safe (so that we don't inadvertently
|
|
* compare numbers with different units, or compare a mocktime to system time).
|
|
*/
|
|
|
|
int64_t GetTime();
|
|
int64_t GetTimeMillis();
|
|
int64_t GetTimeMicros();
|
|
int64_t GetSystemTimeInSeconds(); // Like GetTime(), but not mockable
|
|
int64_t GetLogTimeMicros();
|
|
void SetMockTime(int64_t nMockTimeIn);
|
|
bool IsMockTime();
|
|
void MilliSleep(int64_t n);
|
|
|
|
std::string DateTimeStrFormat(const char* pszFormat, int64_t nTime);
|
|
std::string DurationToDHMS(int64_t nDurationTime);
|
|
|
|
#endif // BITCOIN_UTILTIME_H
|