Skip to content

Commit 2b1e172

Browse files
jnarebgitster
authored andcommitted
gitweb: Fix handling of fractional timezones in parse_date
Fractional timezones, like -0330 (NST used in Canada) or +0430 (Afghanistan, Iran DST), were not handled properly in parse_date; this means values such as 'minute_local' and 'iso-tz' were not generated correctly. This was caused by two mistakes: * sign of timezone was applied only to hour part of offset, and not as it should be also to minutes part (this affected only negative fractional timezones). * 'int $h + $m/60' is 'int($h + $m/60)' and not 'int($h) + $m/60', so fractional part was discarded altogether ($h is hours, $m is minutes, which is always less than 60). Note that positive fractional timezones +0430, +0530 and +1030 can be found as authortime in git.git repository itself. For example http://repo.or.cz/w/git.git/commit/88d50e7 had authortime of "Fri, 8 Jan 2010 18:48:07 +0000 (23:48 +0530)", which is not marked with 'atnight', when "git show 88d50e7" gives correct author date of "Sat Jan 9 00:18:07 2010 +0530". Signed-off-by: Jakub Narebski <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent b5f306f commit 2b1e172

File tree

1 file changed

+4
-2
lines changed

1 file changed

+4
-2
lines changed

gitweb/gitweb.perl

Lines changed: 4 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -2913,8 +2913,10 @@ sub parse_date {
29132913
$date{'iso-8601'} = sprintf "%04d-%02d-%02dT%02d:%02d:%02dZ",
29142914
1900+$year, 1+$mon, $mday, $hour ,$min, $sec;
29152915

2916-
$tz =~ m/^([+\-][0-9][0-9])([0-9][0-9])$/;
2917-
my $local = $epoch + ((int $1 + ($2/60)) * 3600);
2916+
my ($tz_sign, $tz_hour, $tz_min) =
2917+
($tz =~ m/^([-+])(\d\d)(\d\d)$/);
2918+
$tz_sign = ($tz_sign eq '-' ? -1 : +1);
2919+
my $local = $epoch + $tz_sign*((($tz_hour*60) + $tz_min)*60);
29182920
($sec, $min, $hour, $mday, $mon, $year, $wday, $yday) = gmtime($local);
29192921
$date{'hour_local'} = $hour;
29202922
$date{'minute_local'} = $min;

0 commit comments

Comments
 (0)