0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2024-11-26 08:42:34 +01:00
construct/include/ircd/timedate.h

135 lines
3.8 KiB
C
Raw Normal View History

2018-02-04 03:22:01 +01:00
// Matrix Construct
//
// Copyright (C) Matrix Construct Developers, Authors & Contributors
// Copyright (C) 2016-2019 Jason Volk <jason@zemos.net>
2018-02-04 03:22:01 +01:00
//
// Permission to use, copy, modify, and/or distribute this software for any
// purpose with or without fee is hereby granted, provided that the above
// copyright notice and this permission notice is present in all copies. The
// full license for this software is available in the LICENSE file.
#pragma once
#define HAVE_IRCD_TIMEDATE_H
namespace ircd
{
using high_resolution_point = time_point<high_resolution_clock>;
2017-09-20 06:39:53 +02:00
using steady_point = time_point<steady_clock>;
using system_point = time_point<system_clock>;
using microtime_t = std::pair<time_t, int32_t>;
IRCD_OVERLOAD(localtime)
2017-09-20 06:39:53 +02:00
// Standard time_point samples
2017-09-20 06:39:53 +02:00
template<class unit = seconds> unit now();
template<> steady_point now();
template<> system_point now();
// Standard time_point (system_clock only) directly into long integer.
2017-09-30 07:57:29 +02:00
template<class unit = seconds> time_t &time(time_t &ref);
2017-09-20 06:39:53 +02:00
template<class unit = seconds> time_t time();
2017-09-30 07:57:29 +02:00
template<class unit = seconds> time_t time(time_t *const &ptr);
// System vdso microtime suite
microtime_t microtime();
string_view microtime(const mutable_buffer &);
// System vdso formatted time suite
extern const char *const rfc7231_fmt;
string_view timef(const mutable_buffer &out, const struct tm &tm, const char *const &fmt = rfc7231_fmt);
string_view timef(const mutable_buffer &out, const time_t &epoch, const char *const &fmt = rfc7231_fmt);
string_view timef(const mutable_buffer &out, const time_t &epoch, localtime_t, const char *const &fmt = rfc7231_fmt);
string_view timef(const mutable_buffer &out, const system_point &epoch, const char *const &fmt = rfc7231_fmt);
string_view timef(const mutable_buffer &out, const system_point &epoch, localtime_t, const char *const &fmt = rfc7231_fmt);
string_view timef(const mutable_buffer &out, localtime_t, const char *const &fmt = rfc7231_fmt);
string_view timef(const mutable_buffer &out, const char *const &fmt = rfc7231_fmt);
template<size_t max = 128, class... args> std::string timestr(args&&...);
// Other tools
string_view smalldate(const mutable_buffer &buf, const time_t &ltime);
// Interface conveniences.
std::ostream &operator<<(std::ostream &, const microtime_t &);
std::ostream &operator<<(std::ostream &, const system_point &);
template<class rep, class period> std::ostream &operator<<(std::ostream &, const duration<rep, period> &);
}
template<class rep,
class period>
std::ostream &
ircd::operator<<(std::ostream &s,
const duration<rep, period> &duration)
{
s << duration.count();
return s;
}
/// timestr() is a passthru to timef() where you don't give the first argument
/// (the mutable_buffer). Instead of supplying a buffer an allocated
/// std::string is returned with the result. By default this string's buffer
/// is sufficiently large, but may be further tuned in the template parameter.
template<size_t max,
class... args>
std::string
ircd::timestr(args&&... a)
{
return string(max, [&](const mutable_buffer &buf)
{
return timef(buf, std::forward<args>(a)...);
});
}
2017-09-30 07:57:29 +02:00
template<class unit>
time_t
ircd::time(time_t *const &ptr)
{
time_t buf, &ret{ptr? *ptr : buf};
return time<unit>(ret);
}
2017-09-20 06:39:53 +02:00
template<class unit>
time_t
ircd::time()
{
2017-09-30 07:57:29 +02:00
time_t ret;
return time<unit>(ret);
}
template<class unit>
time_t &
ircd::time(time_t &ref)
{
ref = duration_cast<unit>(system_clock::now().time_since_epoch()).count();
return ref;
2017-09-20 06:39:53 +02:00
}
template<>
inline ircd::system_point
2017-09-20 06:39:53 +02:00
ircd::now()
{
return system_clock::now();
2017-09-20 06:39:53 +02:00
}
template<>
inline ircd::steady_point
2017-09-20 06:39:53 +02:00
ircd::now()
{
return steady_clock::now();
}
2017-09-20 06:39:53 +02:00
template<class unit>
unit
ircd::now()
{
const auto now
{
2017-09-20 06:39:53 +02:00
steady_clock::now()
};
const auto tse
{
now.time_since_epoch()
};
2017-09-20 06:39:53 +02:00
return std::chrono::duration_cast<unit>(tse);
}