* [PATCH (BUGFIX)] gitweb: Fix parsing of negative fractional timezones in JavaScript
@ 2011-04-01 19:06 Jakub Narebski
2011-04-04 18:30 ` J.H.
0 siblings, 1 reply; 2+ messages in thread
From: Jakub Narebski @ 2011-04-01 19:06 UTC (permalink / raw)
To: git; +Cc: John 'Warthog9' Hawley, Kevin Cernekee
Extract converting numerical timezone in the form of '(+|-)HHMM' to
timezoneOffset function, and fix parsing of negative fractional
timezones.
This is used to format timestamps in 'blame_incremental' view; this
complements commit 2b1e172 (gitweb: Fix handling of fractional
timezones in parse_date, 2011-03-25).
Now
gitweb.cgi/git.git/blame_incremental/3fe5489:/contrib/gitview/gitview#l853
and
gitweb.cgi/git.git/blame/3fe5489:/contrib/gitview/gitview#l853
show the same correct time in author's local timezone in title
(on mouseover) [Aneesh Kumar K.V, 2006-02-24 00:59:42 +0530].
Signed-off-by: Jakub Narebski <jnareb@gmail.com>
---
This was send earlier as part 3/3 of
"[PATCH/RFC 0/3] gitweb: Split gitweb.js, improve JavaScript"
Message-Id: <1301089586-8534-1-git-send-email-jnareb@gmail.com>
http://thread.gmane.org/gmane.comp.version-control.git/170021/focus=170024
It is now send separately as standalone patch, and is not held hostage
to accepting series that splits gitweb JavaScript file.
gitweb/static/gitweb.js | 24 +++++++++++++++++++-----
1 files changed, 19 insertions(+), 5 deletions(-)
diff --git a/gitweb/static/gitweb.js b/gitweb/static/gitweb.js
index 9c66928..40ec084 100644
--- a/gitweb/static/gitweb.js
+++ b/gitweb/static/gitweb.js
@@ -399,7 +399,24 @@ function fixColorsAndGroups() {
* used to extract hours and minutes from timezone info, e.g '-0900'
* @constant
*/
-var tzRe = /^([+-][0-9][0-9])([0-9][0-9])$/;
+var tzRe = /^([+-])([0-9][0-9])([0-9][0-9])$/;
+
+/**
+ * convert numeric timezone +/-ZZZZ to offset from UTC in seconds
+ *
+ * @param {String} timezoneInfo: numeric timezone '(+|-)HHMM'
+ * @returns {Number} offset from UTC in seconds for timezone
+ *
+ * @globals tzRe
+ */
+function timezoneOffset(timezoneInfo) {
+ var match = tzRe.exec(timezoneInfo);
+ var tz_sign = (match[1] === '-' ? -1 : +1);
+ var tz_hour = parseInt(match[2],10);
+ var tz_min = parseInt(match[3],10);
+
+ return tz_sign*(((tz_hour*60) + tz_min)*60);
+}
/**
* return date in local time formatted in iso-8601 like format
@@ -408,14 +425,11 @@ var tzRe = /^([+-][0-9][0-9])([0-9][0-9])$/;
* @param {Number} epoch: seconds since '00:00:00 1970-01-01 UTC'
* @param {String} timezoneInfo: numeric timezone '(+|-)HHMM'
* @returns {String} date in local time in iso-8601 like format
- *
- * @globals tzRe
*/
function formatDateISOLocal(epoch, timezoneInfo) {
- var match = tzRe.exec(timezoneInfo);
// date corrected by timezone
var localDate = new Date(1000 * (epoch +
- (parseInt(match[1],10)*3600 + parseInt(match[2],10)*60)));
+ timezoneOffset(timezoneInfo)));
var localDateStr = // e.g. '2005-08-07'
localDate.getUTCFullYear() + '-' +
padLeft(localDate.getUTCMonth()+1, 2, '0') + '-' +
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH (BUGFIX)] gitweb: Fix parsing of negative fractional timezones in JavaScript
2011-04-01 19:06 [PATCH (BUGFIX)] gitweb: Fix parsing of negative fractional timezones in JavaScript Jakub Narebski
@ 2011-04-04 18:30 ` J.H.
0 siblings, 0 replies; 2+ messages in thread
From: J.H. @ 2011-04-04 18:30 UTC (permalink / raw)
To: Jakub Narebski; +Cc: git, Kevin Cernekee
Looks fine to me.
- John 'Warthog9' Hawley
On 04/01/2011 12:06 PM, Jakub Narebski wrote:
> Extract converting numerical timezone in the form of '(+|-)HHMM' to
> timezoneOffset function, and fix parsing of negative fractional
> timezones.
>
> This is used to format timestamps in 'blame_incremental' view; this
> complements commit 2b1e172 (gitweb: Fix handling of fractional
> timezones in parse_date, 2011-03-25).
>
> Now
>
> gitweb.cgi/git.git/blame_incremental/3fe5489:/contrib/gitview/gitview#l853
>
> and
>
> gitweb.cgi/git.git/blame/3fe5489:/contrib/gitview/gitview#l853
>
> show the same correct time in author's local timezone in title
> (on mouseover) [Aneesh Kumar K.V, 2006-02-24 00:59:42 +0530].
>
> Signed-off-by: Jakub Narebski <jnareb@gmail.com>
> ---
> This was send earlier as part 3/3 of
>
> "[PATCH/RFC 0/3] gitweb: Split gitweb.js, improve JavaScript"
> Message-Id: <1301089586-8534-1-git-send-email-jnareb@gmail.com>
> http://thread.gmane.org/gmane.comp.version-control.git/170021/focus=170024
>
> It is now send separately as standalone patch, and is not held hostage
> to accepting series that splits gitweb JavaScript file.
>
> gitweb/static/gitweb.js | 24 +++++++++++++++++++-----
> 1 files changed, 19 insertions(+), 5 deletions(-)
>
> diff --git a/gitweb/static/gitweb.js b/gitweb/static/gitweb.js
> index 9c66928..40ec084 100644
> --- a/gitweb/static/gitweb.js
> +++ b/gitweb/static/gitweb.js
> @@ -399,7 +399,24 @@ function fixColorsAndGroups() {
> * used to extract hours and minutes from timezone info, e.g '-0900'
> * @constant
> */
> -var tzRe = /^([+-][0-9][0-9])([0-9][0-9])$/;
> +var tzRe = /^([+-])([0-9][0-9])([0-9][0-9])$/;
> +
> +/**
> + * convert numeric timezone +/-ZZZZ to offset from UTC in seconds
> + *
> + * @param {String} timezoneInfo: numeric timezone '(+|-)HHMM'
> + * @returns {Number} offset from UTC in seconds for timezone
> + *
> + * @globals tzRe
> + */
> +function timezoneOffset(timezoneInfo) {
> + var match = tzRe.exec(timezoneInfo);
> + var tz_sign = (match[1] === '-' ? -1 : +1);
> + var tz_hour = parseInt(match[2],10);
> + var tz_min = parseInt(match[3],10);
> +
> + return tz_sign*(((tz_hour*60) + tz_min)*60);
> +}
>
> /**
> * return date in local time formatted in iso-8601 like format
> @@ -408,14 +425,11 @@ var tzRe = /^([+-][0-9][0-9])([0-9][0-9])$/;
> * @param {Number} epoch: seconds since '00:00:00 1970-01-01 UTC'
> * @param {String} timezoneInfo: numeric timezone '(+|-)HHMM'
> * @returns {String} date in local time in iso-8601 like format
> - *
> - * @globals tzRe
> */
> function formatDateISOLocal(epoch, timezoneInfo) {
> - var match = tzRe.exec(timezoneInfo);
> // date corrected by timezone
> var localDate = new Date(1000 * (epoch +
> - (parseInt(match[1],10)*3600 + parseInt(match[2],10)*60)));
> + timezoneOffset(timezoneInfo)));
> var localDateStr = // e.g. '2005-08-07'
> localDate.getUTCFullYear() + '-' +
> padLeft(localDate.getUTCMonth()+1, 2, '0') + '-' +
>
> --
> To unsubscribe from this list: send the line "unsubscribe git" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2011-04-04 18:30 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2011-04-01 19:06 [PATCH (BUGFIX)] gitweb: Fix parsing of negative fractional timezones in JavaScript Jakub Narebski
2011-04-04 18:30 ` J.H.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).