зеркало из https://github.com/microsoft/git.git
cvsserver: Show correct letters for modified, removed and added files
Earlier, cvsserver showed always an 'U', sometimes even without a space between the 'U' and the name. Now, the correct letter is shown, with a space. Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de> Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Родитель
f7197dff15
Коммит
0a7a9a12d6
|
@ -805,7 +805,14 @@ sub req_update
|
|||
$meta = $updater->getmeta($filename);
|
||||
}
|
||||
|
||||
next unless ( $meta->{revision} );
|
||||
if ( ! defined $meta )
|
||||
{
|
||||
$meta = {
|
||||
name => $filename,
|
||||
revision => 0,
|
||||
filehash => 'added'
|
||||
};
|
||||
}
|
||||
|
||||
my $oldmeta = $meta;
|
||||
|
||||
|
@ -835,7 +842,7 @@ sub req_update
|
|||
and not exists ( $state->{opt}{C} ) )
|
||||
{
|
||||
$log->info("Tell the client the file is modified");
|
||||
print "MT text U\n";
|
||||
print "MT text M \n";
|
||||
print "MT fname $filename\n";
|
||||
print "MT newline\n";
|
||||
next;
|
||||
|
@ -855,15 +862,36 @@ sub req_update
|
|||
}
|
||||
}
|
||||
elsif ( not defined ( $state->{entries}{$filename}{modified_hash} )
|
||||
or $state->{entries}{$filename}{modified_hash} eq $oldmeta->{filehash} )
|
||||
or $state->{entries}{$filename}{modified_hash} eq $oldmeta->{filehash}
|
||||
or $meta->{filehash} eq 'added' )
|
||||
{
|
||||
$log->info("Updating '$filename'");
|
||||
# normal update, just send the new revision (either U=Update, or A=Add, or R=Remove)
|
||||
print "MT +updated\n";
|
||||
print "MT text U\n";
|
||||
print "MT fname $filename\n";
|
||||
print "MT newline\n";
|
||||
print "MT -updated\n";
|
||||
# normal update, just send the new revision (either U=Update,
|
||||
# or A=Add, or R=Remove)
|
||||
if ( defined($wrev) && $wrev < 0 )
|
||||
{
|
||||
$log->info("Tell the client the file is scheduled for removal");
|
||||
print "MT text R \n";
|
||||
print "MT fname $filename\n";
|
||||
print "MT newline\n";
|
||||
next;
|
||||
}
|
||||
elsif ( !defined($wrev) || $wrev == 0 )
|
||||
{
|
||||
$log->info("Tell the client the file will be added");
|
||||
print "MT text A \n";
|
||||
print "MT fname $filename\n";
|
||||
print "MT newline\n";
|
||||
next;
|
||||
|
||||
}
|
||||
else {
|
||||
$log->info("Updating '$filename' $wrev");
|
||||
print "MT +updated\n";
|
||||
print "MT text U \n";
|
||||
print "MT fname $filename\n";
|
||||
print "MT newline\n";
|
||||
print "MT -updated\n";
|
||||
}
|
||||
|
||||
my ( $filepart, $dirpart ) = filenamesplit($filename,1);
|
||||
|
||||
|
@ -1709,6 +1737,17 @@ sub argsfromdir
|
|||
|
||||
return if ( scalar ( @{$state->{args}} ) > 1 );
|
||||
|
||||
my @gethead = @{$updater->gethead};
|
||||
|
||||
# push added files
|
||||
foreach my $file (keys %{$state->{entries}}) {
|
||||
if ( exists $state->{entries}{$file}{revision} &&
|
||||
$state->{entries}{$file}{revision} == 0 )
|
||||
{
|
||||
push @gethead, { name => $file, filehash => 'added' };
|
||||
}
|
||||
}
|
||||
|
||||
if ( scalar(@{$state->{args}}) == 1 )
|
||||
{
|
||||
my $arg = $state->{args}[0];
|
||||
|
@ -1716,7 +1755,7 @@ sub argsfromdir
|
|||
|
||||
$log->info("Only one arg specified, checking for directory expansion on '$arg'");
|
||||
|
||||
foreach my $file ( @{$updater->gethead} )
|
||||
foreach my $file ( @gethead )
|
||||
{
|
||||
next if ( $file->{filehash} eq "deleted" and not defined ( $state->{entries}{$file->{name}} ) );
|
||||
next unless ( $file->{name} =~ /^$arg\// or $file->{name} eq $arg );
|
||||
|
@ -1729,7 +1768,7 @@ sub argsfromdir
|
|||
|
||||
$state->{args} = [];
|
||||
|
||||
foreach my $file ( @{$updater->gethead} )
|
||||
foreach my $file ( @gethead )
|
||||
{
|
||||
next if ( $file->{filehash} eq "deleted" and not defined ( $state->{entries}{$file->{name}} ) );
|
||||
next unless ( $file->{name} =~ s/^$state->{prependdir}// );
|
||||
|
|
Загрузка…
Ссылка в новой задаче