Browse Source

Merge branch 'jn/maint-gitweb-utf8-fix' into maint

* jn/maint-gitweb-utf8-fix:
  gitweb: Fix fallback mode of to_utf8 subroutine
  gitweb: Output valid utf8 in git_blame_common('data')
  gitweb: esc_html() site name for title in OPML
  gitweb: Call to_utf8() on input string in chop_and_escape_str()
maint
Junio C Hamano 13 years ago
parent
commit
b15840e5b8
  1. 12
      gitweb/gitweb.perl

12
gitweb/gitweb.perl

@ -1442,8 +1442,8 @@ sub validate_refname { @@ -1442,8 +1442,8 @@ sub validate_refname {
sub to_utf8 {
my $str = shift;
return undef unless defined $str;
if (utf8::valid($str)) {
utf8::decode($str);

if (utf8::is_utf8($str) || utf8::decode($str)) {
return $str;
} else {
return decode($fallback_encoding, $str, Encode::FB_DEFAULT);
@ -1695,6 +1695,7 @@ sub chop_and_escape_str { @@ -1695,6 +1695,7 @@ sub chop_and_escape_str {
my ($str) = @_;

my $chopped = chop_str(@_);
$str = to_utf8($str);
if ($chopped eq $str) {
return esc_html($chopped);
} else {
@ -6107,7 +6108,9 @@ sub git_blame_common { @@ -6107,7 +6108,9 @@ sub git_blame_common {
-type=>"text/plain", -charset => "utf-8",
-status=> "200 OK");
local $| = 1; # output autoflush
print while <$fd>;
while (my $line = <$fd>) {
print to_utf8($line);
}
close $fd
or print "ERROR $!\n";

@ -7699,11 +7702,12 @@ sub git_opml { @@ -7699,11 +7702,12 @@ sub git_opml {
-charset => 'utf-8',
-content_disposition => 'inline; filename="opml.xml"');

my $title = esc_html($site_name);
print <<XML;
<?xml version="1.0" encoding="utf-8"?>
<opml version="1.0">
<head>
<title>$site_name OPML Export</title>
<title>$title OPML Export</title>
</head>
<body>
<outline text="git RSS feeds">

Loading…
Cancel
Save