git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Invalid html output repo.or.cz (alt-git.git)
@ 2008-02-16 13:00 Martin Koegler
  2008-02-16 19:20 ` Junio C Hamano
  2008-02-16 19:52 ` Jakub Narebski
  0 siblings, 2 replies; 6+ messages in thread
From: Martin Koegler @ 2008-02-16 13:00 UTC (permalink / raw)
  To: Petr Baudis; +Cc: git

http://repo.or.cz/w/alt-git.git?a=shortlog

fails to load in my Seamonkey browser (Debian stable):

XML Parsing Error: not well-formed
Location: http://repo.or.cz/w/alt-git.git?a=shortlog
Line Number 561, Column 33:<td><i><span title="Uwe Kleine-K<span class="cntrl">\e</span>,Av<span class="cntrl">\e</span>(Bnig">Uwe Kleine ...</span></i></td>
--------------------------------^

mfg Martin Kögler

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Invalid html output repo.or.cz (alt-git.git)
  2008-02-16 13:00 Invalid html output repo.or.cz (alt-git.git) Martin Koegler
@ 2008-02-16 19:20 ` Junio C Hamano
  2008-02-16 19:52 ` Jakub Narebski
  1 sibling, 0 replies; 6+ messages in thread
From: Junio C Hamano @ 2008-02-16 19:20 UTC (permalink / raw)
  To: Martin Koegler; +Cc: Petr Baudis, git

mkoegler@auto.tuwien.ac.at (Martin Koegler) writes:

> http://repo.or.cz/w/alt-git.git?a=shortlog
>
> fails to load in my Seamonkey browser (Debian stable):

Sorry, that's caused by a bad commit author encoding.  gitweb
should ideally be tightened, though.

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Invalid html output repo.or.cz (alt-git.git)
  2008-02-16 13:00 Invalid html output repo.or.cz (alt-git.git) Martin Koegler
  2008-02-16 19:20 ` Junio C Hamano
@ 2008-02-16 19:52 ` Jakub Narebski
  2008-02-16 20:07   ` Junio C Hamano
  2008-02-16 21:12   ` Invalid html output repo.or.cz (alt-git.git) Robert Schiele
  1 sibling, 2 replies; 6+ messages in thread
From: Jakub Narebski @ 2008-02-16 19:52 UTC (permalink / raw)
  To: Martin Koegler; +Cc: Petr Baudis, git

Martin Koegler <mkoegler@auto.tuwien.ac.at> writes:

> http://repo.or.cz/w/alt-git.git?a=shortlog
> 
> fails to load in my Seamonkey browser (Debian stable):
> 
> XML Parsing Error: not well-formed
> Location: http://repo.or.cz/w/alt-git.git?a=shortlog
> Line Number 561, Column 33:<td><i><span title="Uwe Kleine-K<span class="cntrl">\e</span>,Av<span class="cntrl">\e</span>(Bnig">Uwe Kleine ...</span></i></td>
> --------------------------------^

It looks like gitweb uses esc_html instead of esc_param (or leaving it
to CGI module) title attribute of span (?) element in a shortlog.

I'd try to fix this bug.
-- 
Jakub Narebski
Poland
ShadeHawk on #git

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Invalid html output repo.or.cz (alt-git.git)
  2008-02-16 19:52 ` Jakub Narebski
@ 2008-02-16 20:07   ` Junio C Hamano
  2008-02-16 22:07     ` [PATCH] gitweb: Fix displaying unchopped argument in chop_and_escape_str Jakub Narebski
  2008-02-16 21:12   ` Invalid html output repo.or.cz (alt-git.git) Robert Schiele
  1 sibling, 1 reply; 6+ messages in thread
From: Junio C Hamano @ 2008-02-16 20:07 UTC (permalink / raw)
  To: Jakub Narebski; +Cc: Martin Koegler, Petr Baudis, git

Jakub Narebski <jnareb@gmail.com> writes:

> Martin Koegler <mkoegler@auto.tuwien.ac.at> writes:
>
>> http://repo.or.cz/w/alt-git.git?a=shortlog
>> 
>> fails to load in my Seamonkey browser (Debian stable):
>> 
>> XML Parsing Error: not well-formed
>> Location: http://repo.or.cz/w/alt-git.git?a=shortlog
>> Line Number 561, Column 33:<td><i><span title="Uwe Kleine-K<span class="cntrl">\e</span>,Av<span class="cntrl">\e</span>(Bnig">Uwe Kleine ...</span></i></td>
>> --------------------------------^
>
> It looks like gitweb uses esc_html instead of esc_param (or leaving it
> to CGI module) title attribute of span (?) element in a shortlog.
>
> I'd try to fix this bug.

Thanks.

^ permalink raw reply	[flat|nested] 6+ messages in thread

* Re: Invalid html output repo.or.cz (alt-git.git)
  2008-02-16 19:52 ` Jakub Narebski
  2008-02-16 20:07   ` Junio C Hamano
@ 2008-02-16 21:12   ` Robert Schiele
  1 sibling, 0 replies; 6+ messages in thread
From: Robert Schiele @ 2008-02-16 21:12 UTC (permalink / raw)
  To: Jakub Narebski; +Cc: Martin Koegler, Petr Baudis, git

[-- Attachment #1: Type: text/plain, Size: 866 bytes --]

On Sat, Feb 16, 2008 at 11:52:42AM -0800, Jakub Narebski wrote:
> Martin Koegler <mkoegler@auto.tuwien.ac.at> writes:
> 
> > http://repo.or.cz/w/alt-git.git?a=shortlog
> > 
> > fails to load in my Seamonkey browser (Debian stable):
> > 
> > XML Parsing Error: not well-formed
> > Location: http://repo.or.cz/w/alt-git.git?a=shortlog
> > Line Number 561, Column 33:<td><i><span title="Uwe Kleine-K<span class="cntrl">\e</span>,Av<span class="cntrl">\e</span>(Bnig">Uwe Kleine ...</span></i></td>
> > --------------------------------^
> 
> It looks like gitweb uses esc_html instead of esc_param (or leaving it

Huh?  Isn't that the wrong escaping?  esc_param is for URLs not for XML
attributes in general, isn't it?

Robert

-- 
Robert Schiele
Dipl.-Wirtsch.informatiker	mailto:rschiele@gmail.com

"Quidquid latine dictum sit, altum sonatur."

[-- Attachment #2: Type: application/pgp-signature, Size: 194 bytes --]

^ permalink raw reply	[flat|nested] 6+ messages in thread

* [PATCH] gitweb: Fix displaying unchopped argument in chop_and_escape_str
  2008-02-16 20:07   ` Junio C Hamano
@ 2008-02-16 22:07     ` Jakub Narebski
  0 siblings, 0 replies; 6+ messages in thread
From: Jakub Narebski @ 2008-02-16 22:07 UTC (permalink / raw)
  To: Junio C Hamano; +Cc: Martin Koegler, Petr Baudis, git

Do not use esc_html to escape [title] _attribute_ of a HTML element,
and quote unprintable characters.  Replace unprintable characters by
'?' and use CGI method to generate HTML element and do the escaping.

This caused bug noticed by Martin Koegler,
  Message-ID: <20080216130037.GA14571@auto.tuwien.ac.at>
that for bad commit encoding in author name, the title attribute (here
to show full, not shortened name) had embedded HTML code in it, result
of quoting unprintable characters the gitweb/HTML way. This of course
broke the HTML, causing page being not displayed in XML validating web
browsers.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
---

Junio C Hamano wrote:
> Jakub Narebski <jnareb@gmail.com> writes:
>> Martin Koegler <mkoegler@auto.tuwien.ac.at> writes:
>>
>>> http://repo.or.cz/w/alt-git.git?a=shortlog
>>> 
>>> fails to load in my Seamonkey browser (Debian stable):
>>> 
>>> XML Parsing Error: not well-formed
>>> Location: http://repo.or.cz/w/alt-git.git?a=shortlog
>>> Line Number 561, Column 33:<td><i><span title="Uwe Kleine-K<span class="cntrl">\e</span>,Av<span class="cntrl">\e</span>(Bnig">Uwe Kleine ...</span></i></td>
>>> --------------------------------^
>>
>> It looks like gitweb uses esc_html instead of esc_param (or leaving it
>> to CGI module) title attribute of span (?) element in a shortlog.
>>
>> I'd try to fix this bug.
> 
> Thanks.

And here it is. It fixes this bug; I hope there aren't any similar bugs,
but I have not checked this. 

Robert Schiele wrote:
> On Sat, Feb 16, 2008 at 11:52:42AM -0800, Jakub Narebski wrote:
>> 
>> It looks like gitweb uses esc_html instead of esc_param (or leaving it
> 
> Huh?  Isn't that the wrong escaping?  esc_param is for URLs not for XML
> attributes in general, isn't it?

True, esc_param is for escaping values of CGI parameters, not for
escaping (and quoting) attributes of HTML element.


P.S. I am sorely dissapointed by the fact that CGI version 3.10 doesn't
do escaping / quoting of unprintable (control) characters in attributes
(characters outside specified character set).

 gitweb/gitweb.perl |    4 ++--
 1 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/gitweb/gitweb.perl b/gitweb/gitweb.perl
index a89b478..acf155c 100755
--- a/gitweb/gitweb.perl
+++ b/gitweb/gitweb.perl
@@ -866,8 +866,8 @@ sub chop_and_escape_str {
 	if ($chopped eq $str) {
 		return esc_html($chopped);
 	} else {
-		return qq{<span title="} . esc_html($str) . qq{">} .
-			esc_html($chopped) . qq{</span>};
+		$str =~ s/([[:cntrl:]])/?/g;
+		return $cgi->span({-title=>$str}, esc_html($chopped));
 	}
 }
 
-- 
1.5.4

^ permalink raw reply related	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2008-02-16 22:08 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-02-16 13:00 Invalid html output repo.or.cz (alt-git.git) Martin Koegler
2008-02-16 19:20 ` Junio C Hamano
2008-02-16 19:52 ` Jakub Narebski
2008-02-16 20:07   ` Junio C Hamano
2008-02-16 22:07     ` [PATCH] gitweb: Fix displaying unchopped argument in chop_and_escape_str Jakub Narebski
2008-02-16 21:12   ` Invalid html output repo.or.cz (alt-git.git) Robert Schiele

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).