 |
libfilezilla
|
Go to the documentation of this file. 1 #ifndef LIBFILEZILLA_TIME_HEADER
2 #define LIBFILEZILLA_TIME_HEADER
12 #include "private/windows.hpp"
21 class FZ_PUBLIC_SYMBOL duration;
66 datetime(
zone z,
int year,
int month,
int day,
int hour = -1,
int minute = -1,
int second = -1,
int millisecond = -1);
90 explicit operator bool()
const {
97 accuracy get_accuracy()
const {
return a_; }
109 bool operator!=(
datetime const& op)
const {
return !(*
this == op); }
110 bool operator<(
datetime const& op)
const;
111 bool operator<=(
datetime const& op)
const;
112 bool operator>(
datetime const& op)
const {
return op < *
this; }
140 datetime& operator-=(duration
const& op);
141 datetime operator-(duration
const& op)
const { datetime t(*
this); t -= op;
return t; }
153 bool set(
zone z,
int year,
int month,
int day,
int hour = -1,
int minute = -1,
int second = -1,
int millisecond = -1);
164 bool set(std::string_view
const& str,
zone z);
165 bool set(std::wstring_view
const& str,
zone z);
168 bool set(FILETIME
const& ft,
accuracy a);
174 #if defined(FZ_UNIX) || defined(FZ_MAC)
189 bool imbue_time(
int hour,
int minute,
int second = -1,
int millisecond = -1);
198 std::wstring format(std::wstring
const& format,
zone z)
const;
206 static bool verify_format(std::wstring
const& fmt);
221 FILETIME get_filetime()
const;
249 bool set_rfc822(std::wstring_view
const& str);
252 int FZ_PRIVATE_SYMBOL compare_slow(
datetime const& op)
const;
254 bool FZ_PRIVATE_SYMBOL clamped();
256 enum invalid_t : int64_t {
257 invalid = std::numeric_limits<int64_t>::min()
280 int64_t get_days()
const {
return ms_ / 1000 / 3600 / 24; }
281 int64_t get_hours()
const {
return ms_ / 1000 / 3600; }
282 int64_t get_minutes()
const {
return ms_ / 1000 / 60; }
283 int64_t get_seconds()
const {
return ms_ / 1000; }
284 int64_t get_milliseconds()
const {
return ms_; }
287 static duration from_days(int64_t m) {
288 return duration(m * 1000 * 60 * 60 * 24);
290 static duration from_hours(int64_t m) {
291 return duration(m * 1000 * 60 * 60);
293 static duration from_minutes(int64_t m) {
296 static duration from_seconds(int64_t m) {
299 static duration from_milliseconds(int64_t m) {
318 explicit operator bool()
const {
327 bool operator<(
duration const& op)
const {
return ms_ < op.ms_; }
328 bool operator<=(
duration const& op)
const {
return ms_ <= op.ms_; }
329 bool operator>(
duration const& op)
const {
return ms_ > op.ms_; }
330 bool operator>=(
duration const& op)
const {
return ms_ >= op.ms_; }
335 explicit FZ_PRIVATE_SYMBOL
duration(int64_t ms) : ms_(ms) {}
345 inline duration operator+(duration
const& a, duration
const& b)
347 return duration(a) += b;
388 typedef std::chrono::steady_clock clock_type;
389 static_assert(std::chrono::steady_clock::is_steady,
"Nonconforming stdlib, your steady_clock isn't steady");
397 explicit operator bool()
const {
398 return t_ != clock_type::time_point();
401 monotonic_clock& operator+=(duration
const& d)
403 t_ += std::chrono::milliseconds(d.get_milliseconds());
407 monotonic_clock& operator-=(duration
const& d)
409 t_ -= std::chrono::milliseconds(d.get_milliseconds());
414 explicit FZ_PRIVATE_SYMBOL monotonic_clock(clock_type::time_point
const& t)
418 clock_type::time_point t_;
420 friend duration operator-(monotonic_clock
const& a, monotonic_clock
const& b);
421 friend bool operator==(monotonic_clock
const& a, monotonic_clock
const& b);
422 friend bool operator<(monotonic_clock
const& a, monotonic_clock
const& b);
423 friend bool operator<=(monotonic_clock
const& a, monotonic_clock
const& b);
424 friend bool operator>(monotonic_clock
const& a, monotonic_clock
const& b);
425 friend bool operator>=(monotonic_clock
const& a, monotonic_clock
const& b);
434 return duration::from_milliseconds(std::chrono::duration_cast<std::chrono::milliseconds>(a.t_ - b.t_).count());
438 inline bool operator==(monotonic_clock
const& a, monotonic_clock
const& b)
444 inline bool operator<(monotonic_clock
const& a, monotonic_clock
const& b)
450 inline bool operator<=(monotonic_clock
const& a, monotonic_clock
const& b)
456 inline bool operator>(monotonic_clock
const& a, monotonic_clock
const& b)
462 inline bool operator>=(monotonic_clock
const& a, monotonic_clock
const& b)
bool operator==(symmetric_key const &lhs, symmetric_key const &rhs)
Side-channel safe comparison.
A monotonic clock (aka steady clock) is independent from walltime.
Definition: time.hpp:369
static bool verify_format(std::string const &fmt)
zone
When importing or exporting a timestamp, zone is used to explicitly specify whether the conversion is...
Definition: time.hpp:58
time_t get_time_t() const
Get timestamp as time_t, seconds since 1970-01-01 00:00:00.
int get_milliseconds() const
Get millisecond part of timestamp.
Definition: time.hpp:209
The duration class represents a time interval in milliseconds.
Definition: time.hpp:272
friend duration operator-(datetime const &a, datetime const &b)
Gets the difference between two timestamps as duration.
std::string format(std::string const &format, zone z) const
tm get_tm(zone z) const
Get timestamp as struct tm.
bool set(tm &t, accuracy a, zone z)
bool imbue_time(int hour, int minute, int second=-1, int millisecond=-1)
Adds time to timestamps that only have a day-accuracy.
bool set(std::string_view const &str, zone z)
Set from string, looks for YYYYmmDD[[[[HH]MM]SS]sss].
datetime()=default
A default-constructed timestamp is empty()
bool earlier_than(datetime const &op) const
Equivalent to compare(op) < 0.
Definition: time.hpp:127
bool set(SYSTEMTIME const &ft, accuracy a, zone z)
Windows-only: Set timestamp from SYSTEMTIME.
bool set_rfc822(std::string_view const &str)
static datetime now()
Returns the current date/time.
bool later_than(datetime const &op) const
Equivalent to compare(op) > 0.
Definition: time.hpp:130
static monotonic_clock now()
Gets the current point in time time.
Definition: time.hpp:393
monotonic_clock()=default
Constructs empty clock.
std::string get_rfc822() const
void clear()
Resulting timestamp is empty()
datetime(std::string_view const &s, zone z)
Construct from string, looks for YYYYmmDD[[[[HH]MM]SS]sss].
Sets some global macros and further includes string.hpp.
int compare(datetime const &op) const
Accuracy-aware comparison against another timestamp.
accuracy
The datetime's accuracy.
Definition: time.hpp:46
Represents a point of time in wallclock, tracking the timestamps accuracy/precision.
Definition: time.hpp:41
The namespace used by libfilezilla.
Definition: apply.hpp:17
bool set(zone z, int year, int month, int day, int hour=-1, int minute=-1, int second=-1, int millisecond=-1)
Sets the timestamp.