GNUnet debian-0.24.3-29-g453fda2cf
 
Loading...
Searching...
No Matches
time.c File Reference

functions for handling time and time arithmetic More...

#include "platform.h"
#include "gnunet_util_lib.h"
Include dependency graph for time.c:

Go to the source code of this file.

Macros

#define __STDC_NO_ATOMICS__   1
 
#define ATOMIC
 
#define LOG(kind, ...)   GNUNET_log_from (kind, "util-time", __VA_ARGS__)
 

Functions

void GNUNET_TIME_set_offset (long long offset)
 Set the timestamp offset for this instance.
 
long long GNUNET_TIME_get_offset ()
 Get the timestamp offset for this instance.
 
bool GNUNET_TIME_absolute_approx_eq (struct GNUNET_TIME_Absolute a1, struct GNUNET_TIME_Absolute a2, struct GNUNET_TIME_Relative t)
 Test if a1 and a2 are equal within a margin of error of t.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_absolute_to_timestamp (struct GNUNET_TIME_Absolute at)
 Round an absolute time to a timestamp.
 
struct GNUNET_TIME_TimestampNBO GNUNET_TIME_timestamp_hton (struct GNUNET_TIME_Timestamp t)
 Convert timestamp to network byte order.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_timestamp_ntoh (struct GNUNET_TIME_TimestampNBO tn)
 Convert timestamp from network byte order.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get ()
 Get the current time.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_timestamp_get ()
 Get timestamp representing the current time.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_zero_ ()
 Return relative time of 0ms.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get_zero_ ()
 Return absolute time of 0ms.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_unit_ ()
 Return relative time of 1 microsecond.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_millisecond_ ()
 Return relative time of 1ms.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_second_ ()
 Return relative time of 1s.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_minute_ ()
 Return relative time of 1 minute.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_hour_ ()
 Return relative time of 1 hour.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_get_forever_ ()
 Return "forever".
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get_forever_ ()
 Return "forever".
 
const char * GNUNET_TIME_timestamp2s (struct GNUNET_TIME_Timestamp ts)
 Convert ts to human-readable timestamp.
 
const char * GNUNET_TIME_absolute2s (struct GNUNET_TIME_Absolute t)
 Like asctime, except for GNUnet time.
 
const char * GNUNET_TIME_relative2s (struct GNUNET_TIME_Relative delta, bool do_round)
 Give relative time in human-readable fancy format.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_relative_to_absolute (struct GNUNET_TIME_Relative rel)
 Convert relative time to an absolute time in the future.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_relative_to_timestamp (struct GNUNET_TIME_Relative rel)
 Convert relative time to a timestamp in the future.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_min (struct GNUNET_TIME_Relative t1, struct GNUNET_TIME_Relative t2)
 Return the minimum of two relative time values.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_max (struct GNUNET_TIME_Relative t1, struct GNUNET_TIME_Relative t2)
 Return the maximum of two relative time values.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_min (struct GNUNET_TIME_Absolute t1, struct GNUNET_TIME_Absolute t2)
 Return the minimum of two absolute time values.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_max (struct GNUNET_TIME_Absolute t1, struct GNUNET_TIME_Absolute t2)
 Return the maximum of two absolute time values.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_timestamp_max (struct GNUNET_TIME_Timestamp t1, struct GNUNET_TIME_Timestamp t2)
 Return the maximum of two timestamps.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_timestamp_min (struct GNUNET_TIME_Timestamp t1, struct GNUNET_TIME_Timestamp t2)
 Return the minimum of two timestamps.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_round_down (struct GNUNET_TIME_Absolute at, struct GNUNET_TIME_Relative rt)
 Round down absolute time at to multiple of rt.
 
struct GNUNET_TIME_Relative GNUNET_TIME_absolute_get_remaining (struct GNUNET_TIME_Absolute future)
 Given a timestamp in the future, how much time remains until then?
 
struct GNUNET_TIME_Relative GNUNET_TIME_absolute_get_difference (struct GNUNET_TIME_Absolute start, struct GNUNET_TIME_Absolute end)
 Compute the time difference between the given start and end times.
 
struct GNUNET_TIME_Relative GNUNET_TIME_absolute_get_duration (struct GNUNET_TIME_Absolute whence)
 Get the duration of an operation as the difference of the current time and the given start time "hence".
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_add (struct GNUNET_TIME_Absolute start, struct GNUNET_TIME_Relative duration)
 Add a given relative duration to the given start time.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_subtract (struct GNUNET_TIME_Absolute start, struct GNUNET_TIME_Relative duration)
 Subtract a given relative duration from the given start time.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_multiply (struct GNUNET_TIME_Relative rel, unsigned long long factor)
 Multiply relative time by a given factor.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_multiply_double (struct GNUNET_TIME_Relative rel, double factor)
 Multiply relative time by a given factor.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_saturating_multiply (struct GNUNET_TIME_Relative rel, unsigned long long factor)
 Saturating multiply relative time by a given factor.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_divide (struct GNUNET_TIME_Relative rel, unsigned long long factor)
 Divide relative time by a given factor.
 
struct GNUNET_TIME_Relative GNUNET_TIME_calculate_eta (struct GNUNET_TIME_Absolute start, uint64_t finished, uint64_t total)
 Calculate the estimate time of arrival/completion for an operation.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_add (struct GNUNET_TIME_Relative a1, struct GNUNET_TIME_Relative a2)
 Add relative times together.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_subtract (struct GNUNET_TIME_Relative a1, struct GNUNET_TIME_Relative a2)
 Subtract relative timestamp from the other.
 
struct GNUNET_TIME_RelativeNBO GNUNET_TIME_relative_hton (struct GNUNET_TIME_Relative a)
 Convert relative time to network byte order.
 
struct GNUNET_TIME_Relative GNUNET_TIME_relative_ntoh (struct GNUNET_TIME_RelativeNBO a)
 Convert relative time from network byte order.
 
struct GNUNET_TIME_AbsoluteNBO GNUNET_TIME_absolute_hton (struct GNUNET_TIME_Absolute a)
 Convert absolute time to network byte order.
 
bool GNUNET_TIME_absolute_is_never (struct GNUNET_TIME_Absolute abs)
 Test if abs is never.
 
bool GNUNET_TIME_relative_is_forever (struct GNUNET_TIME_Relative rel)
 Test if rel is forever.
 
bool GNUNET_TIME_relative_is_zero (struct GNUNET_TIME_Relative rel)
 Test if rel is zero.
 
bool GNUNET_TIME_absolute_is_past (struct GNUNET_TIME_Absolute abs)
 Test if abs is truly in the past (excluding now).
 
bool GNUNET_TIME_absolute_is_future (struct GNUNET_TIME_Absolute abs)
 Test if abs is truly in the future (excluding now).
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_from_ms (uint64_t ms_after_epoch)
 Convert milliseconds after the UNIX epoch to absolute time.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_from_s (uint64_t s_after_epoch)
 Convert seconds after the UNIX epoch to absolute time.
 
struct GNUNET_TIME_Timestamp GNUNET_TIME_timestamp_from_s (uint64_t s_after_epoch)
 Convert seconds after the UNIX epoch to timestamp.
 
uint64_t GNUNET_TIME_timestamp_to_s (struct GNUNET_TIME_Timestamp ts)
 Convert timestamp to number of seconds after the UNIX epoch.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_ntoh (struct GNUNET_TIME_AbsoluteNBO a)
 Convert absolute time from network byte order.
 
unsigned int GNUNET_TIME_get_current_year ()
 Return the current year (e.g.
 
unsigned int GNUNET_TIME_time_to_year (struct GNUNET_TIME_Absolute at)
 Convert an expiration time to the respective year (rounds)
 
static time_t my_timegm (struct tm *tm)
 As suggested in the timegm() man page.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_year_to_time (unsigned int year)
 Convert a year to an expiration time of January 1st of that year.
 
struct GNUNET_TIME_Relative GNUNET_TIME_randomized_backoff (struct GNUNET_TIME_Relative rt, struct GNUNET_TIME_Relative threshold)
 Randomized exponential back-off, starting at 1 ms and going up by a factor of 2+r, where 0 <= r <= 0.5, up to a maximum of the given threshold.
 
bool GNUNET_TIME_absolute_is_zero (struct GNUNET_TIME_Absolute abs)
 Test if abs is truly zero.
 
struct GNUNET_TIME_Relative GNUNET_TIME_randomize (struct GNUNET_TIME_Relative r)
 Return a random time value between 0.5*r and 1.5*r.
 
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get_monotonic (const struct GNUNET_CONFIGURATION_Handle *cfg)
 Obtain the current time and make sure it is monotonically increasing.
 
void GNUNET_util_time_fini (void)
 
void __attribute__ ((destructor))
 Destructor.
 

Variables

static long long timestamp_offset
 Variable used to simulate clock skew.
 

Detailed Description

functions for handling time and time arithmetic

Author
Christian Grothoff

Definition in file time.c.

Macro Definition Documentation

◆ __STDC_NO_ATOMICS__

#define __STDC_NO_ATOMICS__   1

Definition at line 36 of file time.c.

◆ ATOMIC

#define ATOMIC

Definition at line 37 of file time.c.

◆ LOG

#define LOG (   kind,
  ... 
)    GNUNET_log_from (kind, "util-time", __VA_ARGS__)

Definition at line 41 of file time.c.

Function Documentation

◆ my_timegm()

static time_t my_timegm ( struct tm *  tm)
static

As suggested in the timegm() man page.

Definition at line 783 of file time.c.

784{
785 time_t ret;
786 char *tz;
787
788 tz = getenv ("TZ");
789 setenv ("TZ", "", 1);
790 tzset ();
791 ret = mktime (tm);
792 if (tz)
793 setenv ("TZ", tz, 1);
794 else
795 unsetenv ("TZ");
796 tzset ();
797 return ret;
798}
char * getenv()
static int ret
Final status code.
Definition gnunet-arm.c:93

References getenv(), and ret.

Referenced by GNUNET_TIME_year_to_time().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ GNUNET_util_time_fini()

void GNUNET_util_time_fini ( void  )

◆ __attribute__()

void __attribute__ ( (destructor)  )

Destructor.

Definition at line 992 of file time.c.

994{
996}
struct GNUNET_TIME_Absolute GNUNET_TIME_absolute_get_monotonic(const struct GNUNET_CONFIGURATION_Handle *cfg)
Obtain the current time and make sure it is monotonically increasing.
Definition time.c:864

References GNUNET_TIME_absolute_get_monotonic().

Here is the call graph for this function:

Variable Documentation

◆ timestamp_offset

long long timestamp_offset
static

Variable used to simulate clock skew.

Used for testing, never in production.

Definition at line 46 of file time.c.

Referenced by GNUNET_TIME_absolute_get(), GNUNET_TIME_get_offset(), and GNUNET_TIME_set_offset().