From 4111bb3ab5f406ee381a3807385af59fe33b28f3 Mon Sep 17 00:00:00 2001 From: J William Piggott Date: Sat, 14 Oct 2017 20:37:11 -0400 Subject: [PATCH] lib/timeutils: add common ISO timestamp masks * Start the ISO format flags at bit 0 instead of bit 1. * Remove unnecessary _8601 from ISO format flag names to avoid line wrapping and to ease readability. * ISO timestamps have date-time-timzone in common, so move the TIMEZONE flag to bit 2 causing all timestamp masks to have the first three bits set and the last four bits as timestamp 'options'. * Change the 'SPACE' flag to a 'T' flag, because it makes the code and comments more concise. * Add common ISO timestamp masks. * Implement the ISO timestamp masks in all applicable code using the strxxx_iso() functions. Signed-off-by: J William Piggott --- include/timeutils.h | 26 +++++++++++++++++--------- lib/timeutils.c | 32 +++++++++++++++----------------- login-utils/last.c | 2 +- login-utils/lslogins.c | 5 ++--- login-utils/utmpdump.c | 4 +--- misc-utils/uuidparse.c | 12 +++--------- sys-utils/dmesg.c | 4 +--- sys-utils/hwclock.c | 6 ++---- sys-utils/lsipc.c | 2 +- sys-utils/rfkill.c | 10 +++------- term-utils/script.c | 8 ++------ 11 files changed, 48 insertions(+), 63 deletions(-) diff --git a/include/timeutils.h b/include/timeutils.h index e8a26146242..230e6db5f90 100644 --- a/include/timeutils.h +++ b/include/timeutils.h @@ -55,18 +55,26 @@ typedef uint64_t nsec_t; int parse_timestamp(const char *t, usec_t *usec); int get_gmtoff(const struct tm *tp); -/* flags for strxxx_iso() functions */ +/* flags and masks for strxxx_iso() functions */ enum { - ISO_8601_DATE = (1 << 1), - ISO_8601_TIME = (1 << 2), - ISO_8601_DOTUSEC = (1 << 3), - ISO_8601_COMMAUSEC = (1 << 4), - ISO_8601_TIMEZONE = (1 << 5), - ISO_8601_SPACE = (1 << 6), - ISO_8601_GMTIME = (1 << 7) + ISO_DATE = (1 << 0), + ISO_TIME = (1 << 1), + ISO_TIMEZONE = (1 << 2), + ISO_DOTUSEC = (1 << 3), + ISO_COMMAUSEC = (1 << 4), + ISO_T = (1 << 5), + ISO_GMTIME = (1 << 6), + ISO_TIMESTAMP = ISO_DATE | ISO_TIME | ISO_TIMEZONE, + ISO_TIMESTAMP_T = ISO_TIMESTAMP | ISO_T, + ISO_TIMESTAMP_DOT = ISO_TIMESTAMP | ISO_DOTUSEC, + ISO_TIMESTAMP_DOT_T = ISO_TIMESTAMP_DOT | ISO_T, + ISO_TIMESTAMP_COMMA = ISO_TIMESTAMP | ISO_COMMAUSEC, + ISO_TIMESTAMP_COMMA_T = ISO_TIMESTAMP_COMMA | ISO_T, + ISO_TIMESTAMP_COMMA_G = ISO_TIMESTAMP_COMMA | ISO_GMTIME, + ISO_TIMESTAMP_COMMA_GT = ISO_TIMESTAMP_COMMA_G | ISO_T }; -#define ISO_8601_BUFSIZ 42 +#define ISO_BUFSIZ 42 int strtimeval_iso(struct timeval *tv, int flags, char *buf, size_t bufsz); int strtm_iso(struct tm *tm, int flags, char *buf, size_t bufsz); diff --git a/lib/timeutils.c b/lib/timeutils.c index adc255c33c7..fdaa2d4a95e 100644 --- a/lib/timeutils.c +++ b/lib/timeutils.c @@ -405,7 +405,7 @@ static int format_iso_time(struct tm *tm, suseconds_t usec, int flags, char *buf char *p = buf; int len; - if (flags & ISO_8601_DATE) { + if (flags & ISO_DATE) { len = snprintf(p, bufsz, "%4d-%.2d-%.2d", tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday); if (len < 0 || (size_t) len > bufsz) @@ -414,14 +414,14 @@ static int format_iso_time(struct tm *tm, suseconds_t usec, int flags, char *buf p += len; } - if ((flags & ISO_8601_DATE) && (flags & ISO_8601_TIME)) { + if ((flags & ISO_DATE) && (flags & ISO_TIME)) { if (bufsz < 1) return -1; - *p++ = (flags & ISO_8601_SPACE) ? ' ' : 'T'; + *p++ = (flags & ISO_T) ? 'T' : ' '; bufsz--; } - if (flags & ISO_8601_TIME) { + if (flags & ISO_TIME) { len = snprintf(p, bufsz, "%02d:%02d:%02d", tm->tm_hour, tm->tm_min, tm->tm_sec); if (len < 0 || (size_t) len > bufsz) @@ -430,14 +430,14 @@ static int format_iso_time(struct tm *tm, suseconds_t usec, int flags, char *buf p += len; } - if (flags & ISO_8601_DOTUSEC) { + if (flags & ISO_DOTUSEC) { len = snprintf(p, bufsz, ".%06ld", (long) usec); if (len < 0 || (size_t) len > bufsz) return -1; bufsz -= len; p += len; - } else if (flags & ISO_8601_COMMAUSEC) { + } else if (flags & ISO_COMMAUSEC) { len = snprintf(p, bufsz, ",%06ld", (long) usec); if (len < 0 || (size_t) len > bufsz) return -1; @@ -445,7 +445,7 @@ static int format_iso_time(struct tm *tm, suseconds_t usec, int flags, char *buf p += len; } - if (flags & ISO_8601_TIMEZONE) { + if (flags & ISO_TIMEZONE) { int tmin = get_gmtoff(tm) / 60; int zhour = tmin / 60; int zmin = abs(tmin % 60); @@ -461,7 +461,7 @@ int strtimeval_iso(struct timeval *tv, int flags, char *buf, size_t bufsz) { struct tm tm; - if (flags & ISO_8601_GMTIME) + if (flags & ISO_GMTIME) tm = *gmtime(&tv->tv_sec); else tm = *localtime(&tv->tv_sec); @@ -479,7 +479,7 @@ int strtime_iso(const time_t *t, int flags, char *buf, size_t bufsz) { struct tm tm; - if (flags & ISO_8601_GMTIME) + if (flags & ISO_GMTIME) tm = *gmtime(t); else tm = *localtime(t); @@ -548,7 +548,7 @@ time_t timegm(struct tm *tm) int main(int argc, char *argv[]) { struct timeval tv = { 0 }; - char buf[ISO_8601_BUFSIZ]; + char buf[ISO_BUFSIZ]; if (argc < 2) { fprintf(stderr, "usage: %s