X-Git-Url: https://git.distorted.org.uk/~mdw/mLib/blobdiff_plain/88bd7f658d494cd5aae62972e39294c2e01c2da3..76a7638e4b77ace1b96e1399f8a11e09fb3afede:/tv.c diff --git a/tv.c b/tv.c index eeeb8b0..618930c 100644 --- a/tv.c +++ b/tv.c @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: tv.c,v 1.4 1999/05/17 20:37:52 mdw Exp $ + * $Id: tv.c,v 1.6 2004/04/08 01:36:13 mdw Exp $ * * Manipulation of timeval structures * @@ -27,33 +27,11 @@ * MA 02111-1307, USA. */ -/*----- Revision history --------------------------------------------------* - * - * $Log: tv.c,v $ - * Revision 1.4 1999/05/17 20:37:52 mdw - * New function `tv_addl' to add a literal to a time value. Use magical - * `MILLION' constant in place of 1000000 for ease of reading. - * - * Revision 1.3 1999/05/06 19:51:36 mdw - * Reformatted the LGPL notice a little bit. - * - * Revision 1.2 1999/05/05 18:50:31 mdw - * Change licensing conditions to LGPL. - * - * Revision 1.1 1998/11/25 23:30:01 mdw - * New file. - * - */ - /*----- Header files ------------------------------------------------------*/ #include #include "tv.h" -/*----- A macro to make reading easier ------------------------------------*/ - -#define MILLION 1000000 - /*----- Main code ---------------------------------------------------------*/ /* --- @tv_add@ --- * @@ -69,12 +47,7 @@ void tv_add(struct timeval *dst, const struct timeval *a, const struct timeval *b) { - dst->tv_sec = a->tv_sec + b->tv_sec; - dst->tv_usec = a->tv_usec + b->tv_usec; - if (dst->tv_usec >= MILLION) { - dst->tv_usec -= MILLION; - dst->tv_sec++; - } + TV_ADD(dst, a, b); } /* --- @tv_addl@ --- * @@ -91,12 +64,7 @@ void tv_add(struct timeval *dst, void tv_addl(struct timeval *dst, const struct timeval *a, time_t sec, unsigned long usec) { - dst->tv_sec = a->tv_sec + sec; - dst->tv_usec = a->tv_usec + usec; - if (dst->tv_usec >= MILLION) { - dst->tv_usec -= MILLION; - dst->tv_sec++; - } + TV_ADDL(dst, a, sec, usec); } /* --- @tv_sub@ --- * @@ -112,13 +80,24 @@ void tv_addl(struct timeval *dst, const struct timeval *a, void tv_sub(struct timeval *dst, const struct timeval *a, const struct timeval *b) { - dst->tv_sec = a->tv_sec - b->tv_sec; - if (a->tv_usec >= b->tv_usec) - dst->tv_usec = a->tv_usec - b->tv_usec; - else { - dst->tv_usec = a->tv_usec + MILLION - b->tv_usec; - dst->tv_sec--; - } + TV_SUB(dst, a, b); +} + +/* --- @tv_subl@ --- * + * + * Arguments: @struct timeval *dst@ = destination block + * @const struct timeval *a@ = source blocks + * @time_t sec@, @unsigned long usec@ = time to subtract + * + * Returns: --- + * + * Use: Subtracts a literal time in seconds and microseconds. + */ + +void tv_subl(struct timeval *dst, const struct timeval *a, + time_t sec, unsigned long usec) +{ + TV_SUBL(dst, a, sec, usec); } /* --- @tv_cmp@ --- * @@ -132,6 +111,8 @@ void tv_sub(struct timeval *dst, int tv_cmp(const struct timeval *a, const struct timeval *b) { + /* --- This is more awkward than the case the macro deals with --- */ + if (a->tv_sec > b->tv_sec) return (1); else if (a->tv_sec < b->tv_sec)