diff options
author | ache <ache@FreeBSD.org> | 2014-10-05 07:29:50 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 2014-10-05 07:29:50 +0000 |
commit | 3620080f9b58fdd7c04c36685013edcdca6b3185 (patch) | |
tree | 5776b59d1c36f5815db9841906cfc39194f22ca7 /lib/libc | |
parent | 23cdb1b1dcdc5bfd6699088e03611d286421155d (diff) | |
download | FreeBSD-src-3620080f9b58fdd7c04c36685013edcdca6b3185.zip FreeBSD-src-3620080f9b58fdd7c04c36685013edcdca6b3185.tar.gz |
1) For %Z format, understand "UTC" name too.
2) Return NULL if timegm() fails, because it means we can convert
what we have in GMT to local time needed.
Diffstat (limited to 'lib/libc')
-rw-r--r-- | lib/libc/stdtime/strptime.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/lib/libc/stdtime/strptime.c b/lib/libc/stdtime/strptime.c index 8576bdb..55c9960 100644 --- a/lib/libc/stdtime/strptime.c +++ b/lib/libc/stdtime/strptime.c @@ -552,7 +552,8 @@ label: strncpy(zonestr, buf, cp - buf); zonestr[cp - buf] = '\0'; tzset(); - if (0 == strcmp(zonestr, "GMT")) { + if (0 == strcmp(zonestr, "GMT") || + 0 == strcmp(zonestr, "UTC")) { *GMTp = 1; } else if (0 == strcmp(zonestr, tzname[0])) { tm->tm_isdst = 0; @@ -674,6 +675,9 @@ strptime_l(const char * __restrict buf, const char * __restrict fmt, ret = _strptime(buf, fmt, tm, &gmt, loc); if (ret && gmt) { time_t t = timegm(tm); + + if (t == -1) + return (NULL); localtime_r(&t, tm); } |