[1/2] time: in strptime(), make %z accept Z as a time zone [BZ #17886]
Commit Message
From: Vincent Bernat <vincent@bernat.im>
In ISO 8601, the timezone can be 'Z' instead of using
digits. 2014-08-17T12:33:12+0000 is often expressed as
2014-08-17T12:33:12Z.
This fixes BZ #17886.
2015-09-16 Vincent Bernat <vincent@bernat.im>
[BZ #17886]
* time/strptime_l.c (__strptime_internal): Make %z accept Z as a
valid time zone.
---
time/strptime_l.c | 10 ++++++++--
time/tst-strptime2.c | 7 +++++++
2 files changed, 15 insertions(+), 2 deletions(-)
Comments
On 16 Sep 2015 10:47, Vincent Bernat wrote:
> --- a/time/tst-strptime2.c
> +++ b/time/tst-strptime2.c
the mkbuf function has a comment block that needs updating since it
discusses valid inputs for timezone offsets.
-mike
@@ -749,13 +749,19 @@ __strptime_internal (rp, fmt, tmp, statep LOCALE_PARAM)
rp++;
break;
case 'z':
- /* We recognize two formats: if two digits are given, these
+ /* We recognize three formats: if two digits are given, these
specify hours. If fours digits are used, minutes are
- also specified. */
+ also specified. 'Z' is equivalent to +0000. */
{
val = 0;
while (ISSPACE (*rp))
++rp;
+ if (*rp == 'Z')
+ {
+ ++rp;
+ tm->tm_gmtoff = 0;
+ break;
+ }
if (*rp != '+' && *rp != '-')
return NULL;
bool neg = *rp++ == '-';
@@ -155,6 +155,13 @@ do_test (void)
expect = LONG_MAX;
result |= compare (buf, expect, nresult);
+ /* Create and test input string with "Z" input (valid format).
+ Expect tm_gmtoff of 0. */
+
+ sprintf (buf, "%s Z", dummy_string);
+ expect = 0;
+ result |= compare (buf, expect, nresult);
+
/* Create and test input strings with sign and digits:
0 digits (invalid format),
1 digit (invalid format),