summaryrefslogtreecommitdiff
path: root/date.c
diff options
context:
space:
mode:
authorHaitao Li <lihaitao@gmail.com>2011-09-09 10:10:33 (GMT)
committerJunio C Hamano <gitster@pobox.com>2011-09-12 23:49:14 (GMT)
commitee646eb48f9a7fc6c225facf2b7449a8a65ef8f2 (patch)
tree2a0a2643908b0556fe7e53b5580104183b7170ff /date.c
parentf696543dad6c7ba27b0c4fab167a5687263a9ba0 (diff)
downloadgit-ee646eb48f9a7fc6c225facf2b7449a8a65ef8f2.zip
git-ee646eb48f9a7fc6c225facf2b7449a8a65ef8f2.tar.gz
git-ee646eb48f9a7fc6c225facf2b7449a8a65ef8f2.tar.bz2
date.c: Support iso8601 timezone formats
Timezone designators in the following formats are all valid according to ISO8601:2004, section 4.3.2: [+-]hh, [+-]hhmm, [+-]hh:mm but we have ignored the ones with colon so far. Signed-off-by: Haitao Li <lihaitao@gmail.com> Helped-by: Jeff King <peff@peff.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'date.c')
-rw-r--r--date.c34
1 files changed, 23 insertions, 11 deletions
diff --git a/date.c b/date.c
index 896fbb4..353e0a5 100644
--- a/date.c
+++ b/date.c
@@ -552,23 +552,35 @@ static int match_digit(const char *date, struct tm *tm, int *offset, int *tm_gmt
static int match_tz(const char *date, int *offp)
{
char *end;
- int offset = strtoul(date+1, &end, 10);
- int min, hour;
- int n = end - date - 1;
+ int hour = strtoul(date + 1, &end, 10);
+ int n = end - (date + 1);
+ int min = 0;
- min = offset % 100;
- hour = offset / 100;
+ if (n == 4) {
+ /* hhmm */
+ min = hour % 100;
+ hour = hour / 100;
+ } else if (n != 2) {
+ min = 99; /* random crap */
+ } else if (*end == ':') {
+ /* hh:mm? */
+ min = strtoul(end + 1, &end, 10);
+ if (end - (date + 1) != 5)
+ min = 99; /* random crap */
+ } /* otherwise we parsed "hh" */
/*
- * Don't accept any random crap.. At least 3 digits, and
- * a valid minute. We might want to check that the minutes
- * are divisible by 30 or something too.
+ * Don't accept any random crap. Even though some places have
+ * offset larger than 12 hours (e.g. Pacific/Kiritimati is at
+ * UTC+14), there is something wrong if hour part is much
+ * larger than that. We might also want to check that the
+ * minutes are divisible by 15 or something too. (Offset of
+ * Kathmandu, Nepal is UTC+5:45)
*/
- if (min < 60 && n > 2) {
- offset = hour*60+min;
+ if (min < 60 && hour < 24) {
+ int offset = hour * 60 + min;
if (*date == '-')
offset = -offset;
-
*offp = offset;
}
return end - date;