Merge git://git.bogomips.org/git-svn
* git://git.bogomips.org/git-svn: git-svn: proper detection of bare repositories git-svn: respect i18n.commitencoding config git-svn: don't escape tilde ('~') for http(s) URLs
This commit is contained in:
commit
a0d3ab9c27
42
git-svn.perl
42
git-svn.perl
@ -223,11 +223,13 @@ unless ($cmd && $cmd =~ /(?:clone|init|multi-init)$/) {
|
|||||||
"but it is not a directory\n";
|
"but it is not a directory\n";
|
||||||
}
|
}
|
||||||
my $git_dir = delete $ENV{GIT_DIR};
|
my $git_dir = delete $ENV{GIT_DIR};
|
||||||
chomp(my $cdup = command_oneline(qw/rev-parse --show-cdup/));
|
my $cdup = undef;
|
||||||
unless (length $cdup) {
|
git_cmd_try {
|
||||||
die "Already at toplevel, but $git_dir ",
|
$cdup = command_oneline(qw/rev-parse --show-cdup/);
|
||||||
"not found '$cdup'\n";
|
$git_dir = '.' unless ($cdup);
|
||||||
}
|
chomp $cdup if ($cdup);
|
||||||
|
$cdup = "." unless ($cdup && length $cdup);
|
||||||
|
} "Already at toplevel, but $git_dir not found\n";
|
||||||
chdir $cdup or die "Unable to chdir up to '$cdup'\n";
|
chdir $cdup or die "Unable to chdir up to '$cdup'\n";
|
||||||
unless (-d $git_dir) {
|
unless (-d $git_dir) {
|
||||||
die "$git_dir still not found after going to ",
|
die "$git_dir still not found after going to ",
|
||||||
@ -852,7 +854,7 @@ sub escape_uri_only {
|
|||||||
my ($uri) = @_;
|
my ($uri) = @_;
|
||||||
my @tmp;
|
my @tmp;
|
||||||
foreach (split m{/}, $uri) {
|
foreach (split m{/}, $uri) {
|
||||||
s/([^\w.%+-]|%(?![a-fA-F0-9]{2}))/sprintf("%%%02X",ord($1))/eg;
|
s/([^~\w.%+-]|%(?![a-fA-F0-9]{2}))/sprintf("%%%02X",ord($1))/eg;
|
||||||
push @tmp, $_;
|
push @tmp, $_;
|
||||||
}
|
}
|
||||||
join('/', @tmp);
|
join('/', @tmp);
|
||||||
@ -1136,9 +1138,19 @@ sub get_commit_entry {
|
|||||||
system($editor, $commit_editmsg);
|
system($editor, $commit_editmsg);
|
||||||
}
|
}
|
||||||
rename $commit_editmsg, $commit_msg or croak $!;
|
rename $commit_editmsg, $commit_msg or croak $!;
|
||||||
open $log_fh, '<', $commit_msg or croak $!;
|
{
|
||||||
{ local $/; chomp($log_entry{log} = <$log_fh>); }
|
# SVN requires messages to be UTF-8 when entering the repo
|
||||||
close $log_fh or croak $!;
|
local $/;
|
||||||
|
open $log_fh, '<', $commit_msg or croak $!;
|
||||||
|
binmode $log_fh;
|
||||||
|
chomp($log_entry{log} = <$log_fh>);
|
||||||
|
|
||||||
|
if (my $enc = Git::config('i18n.commitencoding')) {
|
||||||
|
require Encode;
|
||||||
|
Encode::from_to($log_entry{log}, $enc, 'UTF-8');
|
||||||
|
}
|
||||||
|
close $log_fh or croak $!;
|
||||||
|
}
|
||||||
unlink $commit_msg;
|
unlink $commit_msg;
|
||||||
\%log_entry;
|
\%log_entry;
|
||||||
}
|
}
|
||||||
@ -2273,6 +2285,14 @@ sub do_git_commit {
|
|||||||
}
|
}
|
||||||
defined(my $pid = open3(my $msg_fh, my $out_fh, '>&STDERR', @exec))
|
defined(my $pid = open3(my $msg_fh, my $out_fh, '>&STDERR', @exec))
|
||||||
or croak $!;
|
or croak $!;
|
||||||
|
binmode $msg_fh;
|
||||||
|
|
||||||
|
# we always get UTF-8 from SVN, but we may want our commits in
|
||||||
|
# a different encoding.
|
||||||
|
if (my $enc = Git::config('i18n.commitencoding')) {
|
||||||
|
require Encode;
|
||||||
|
Encode::from_to($log_entry->{log}, 'UTF-8', $enc);
|
||||||
|
}
|
||||||
print $msg_fh $log_entry->{log} or croak $!;
|
print $msg_fh $log_entry->{log} or croak $!;
|
||||||
restore_commit_header_env($old_env);
|
restore_commit_header_env($old_env);
|
||||||
unless ($self->no_metadata) {
|
unless ($self->no_metadata) {
|
||||||
@ -3537,7 +3557,7 @@ sub repo_path {
|
|||||||
sub url_path {
|
sub url_path {
|
||||||
my ($self, $path) = @_;
|
my ($self, $path) = @_;
|
||||||
if ($self->{url} =~ m#^https?://#) {
|
if ($self->{url} =~ m#^https?://#) {
|
||||||
$path =~ s/([^a-zA-Z0-9_.-])/uc sprintf("%%%02x",ord($1))/eg;
|
$path =~ s/([^~a-zA-Z0-9_.-])/uc sprintf("%%%02x",ord($1))/eg;
|
||||||
}
|
}
|
||||||
$self->{url} . '/' . $self->repo_path($path);
|
$self->{url} . '/' . $self->repo_path($path);
|
||||||
}
|
}
|
||||||
@ -3890,7 +3910,7 @@ sub escape_uri_only {
|
|||||||
my ($uri) = @_;
|
my ($uri) = @_;
|
||||||
my @tmp;
|
my @tmp;
|
||||||
foreach (split m{/}, $uri) {
|
foreach (split m{/}, $uri) {
|
||||||
s/([^\w.%+-]|%(?![a-fA-F0-9]{2}))/sprintf("%%%02X",ord($1))/eg;
|
s/([^~\w.%+-]|%(?![a-fA-F0-9]{2}))/sprintf("%%%02X",ord($1))/eg;
|
||||||
push @tmp, $_;
|
push @tmp, $_;
|
||||||
}
|
}
|
||||||
join('/', @tmp);
|
join('/', @tmp);
|
||||||
|
@ -265,4 +265,13 @@ test_expect_success 'able to set-tree to a subdirectory' "
|
|||||||
test -z \"\`git diff refs/heads/my-bar refs/remotes/bar\`\"
|
test -z \"\`git diff refs/heads/my-bar refs/remotes/bar\`\"
|
||||||
"
|
"
|
||||||
|
|
||||||
|
test_expect_success 'git-svn works in a bare repository' '
|
||||||
|
mkdir bare-repo &&
|
||||||
|
( cd bare-repo &&
|
||||||
|
git init --bare &&
|
||||||
|
GIT_DIR=. git svn init "$svnrepo" &&
|
||||||
|
git svn fetch ) &&
|
||||||
|
rm -rf bare-repo
|
||||||
|
'
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
80
t/t9129-git-svn-i18n-commitencoding.sh
Executable file
80
t/t9129-git-svn-i18n-commitencoding.sh
Executable file
@ -0,0 +1,80 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
#
|
||||||
|
# Copyright (c) 2008 Eric Wong
|
||||||
|
|
||||||
|
test_description='git svn honors i18n.commitEncoding in config'
|
||||||
|
|
||||||
|
. ./lib-git-svn.sh
|
||||||
|
|
||||||
|
compare_git_head_with () {
|
||||||
|
nr=`wc -l < "$1"`
|
||||||
|
a=7
|
||||||
|
b=$(($a + $nr - 1))
|
||||||
|
git cat-file commit HEAD | sed -ne "$a,${b}p" >current &&
|
||||||
|
test_cmp current "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
compare_svn_head_with () {
|
||||||
|
LC_ALL=en_US.UTF-8 svn log --limit 1 `git svn info --url` | \
|
||||||
|
sed -e 1,3d -e "/^-\+\$/d" >current &&
|
||||||
|
test_cmp current "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
for H in ISO-8859-1 EUCJP ISO-2022-JP
|
||||||
|
do
|
||||||
|
test_expect_success "$H setup" '
|
||||||
|
mkdir $H &&
|
||||||
|
svn import -m "$H test" $H "$svnrepo"/$H &&
|
||||||
|
git svn clone "$svnrepo"/$H $H
|
||||||
|
'
|
||||||
|
done
|
||||||
|
|
||||||
|
for H in ISO-8859-1 EUCJP ISO-2022-JP
|
||||||
|
do
|
||||||
|
test_expect_success "$H commit on git side" '
|
||||||
|
(
|
||||||
|
cd $H &&
|
||||||
|
git config i18n.commitencoding $H &&
|
||||||
|
git checkout -b t refs/remotes/git-svn &&
|
||||||
|
echo $H >F &&
|
||||||
|
git add F &&
|
||||||
|
git commit -a -F "$TEST_DIRECTORY"/t3900/$H.txt &&
|
||||||
|
E=$(git cat-file commit HEAD | sed -ne "s/^encoding //p") &&
|
||||||
|
test "z$E" = "z$H"
|
||||||
|
compare_git_head_with "$TEST_DIRECTORY"/t3900/$H.txt
|
||||||
|
)
|
||||||
|
'
|
||||||
|
done
|
||||||
|
|
||||||
|
for H in ISO-8859-1 EUCJP ISO-2022-JP
|
||||||
|
do
|
||||||
|
test_expect_success "$H dcommit to svn" '
|
||||||
|
(
|
||||||
|
cd $H &&
|
||||||
|
git svn dcommit &&
|
||||||
|
git cat-file commit HEAD | grep git-svn-id: &&
|
||||||
|
E=$(git cat-file commit HEAD | sed -ne "s/^encoding //p") &&
|
||||||
|
test "z$E" = "z$H" &&
|
||||||
|
compare_git_head_with "$TEST_DIRECTORY"/t3900/$H.txt
|
||||||
|
)
|
||||||
|
'
|
||||||
|
done
|
||||||
|
|
||||||
|
test_expect_success 'ISO-8859-1 should match UTF-8 in svn' '
|
||||||
|
(
|
||||||
|
cd ISO-8859-1 &&
|
||||||
|
compare_svn_head_with "$TEST_DIRECTORY"/t3900/1-UTF-8.txt
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
for H in EUCJP ISO-2022-JP
|
||||||
|
do
|
||||||
|
test_expect_success '$H should match UTF-8 in svn' '
|
||||||
|
(
|
||||||
|
cd $H &&
|
||||||
|
compare_svn_head_with "$TEST_DIRECTORY"/t3900/2-UTF-8.txt
|
||||||
|
)
|
||||||
|
'
|
||||||
|
done
|
||||||
|
|
||||||
|
test_done
|
Loading…
Reference in New Issue
Block a user