Re: git-filehistory (2nd try at detecting renames)

From: David Ho <davidkwho@gmail.com>
Date: 2005-10-21 06:52:13
The output is a bit more manageable with this, but still a bit slow.
I tried it on git-commit.sh

David

[davidho@penguin git-tutorial]$ cat git-filehistory.perl
#!/usr/bin/perl

use warnings;
use strict;

sub usage($);

# Sanity checks:
my $GIT_DIR = $ENV{'GIT_DIR'} || ".git";

unless ( -d $GIT_DIR && -d $GIT_DIR . "/objects" &&
        -d $GIT_DIR . "/objects/" && -d $GIT_DIR . "/refs") {
        usage("Git repository not found.");
}

usage("") if scalar @ARGV != 1;

my ($file) = @ARGV;

unless (-f $file) {
        usage("git filehistory: '$file' does not exist");
}

open(F,"-|","git-rev-parse",,"--default","HEAD","--revs-only",$file);
my $git_rev_args = <F>;
chomp ($git_rev_args);
close (F);

open(F,"-|","git-rev-list", $git_rev_args);
my @commits = <F>;
close (F);

my $nextname = $file;
my (@renamecommit, @renamecomment, @renameentry);
for (my $i=0; $i < scalar @commits; $i++)
{
        my $commit = $commits[$i];
        chomp ($commit);

        open(F,"-|","git-diff-tree","-r","-M", $commit)
                or die "Failed to open pipe from git-diff-tree: " . $!;
        my @lines = grep /R\d{3}.+$nextname/, <F>;
        close(F);
        if (scalar @lines >=1) {
                #The file is renamed!
                #my $rc = system
("git-diff-tree","-r","-M","-p","--pretty=medium",$commit);
                open (F,
"-|","git-diff-tree","-r","-M","--pretty=medium",$commit);
                        @renamecommit = <F>;
                        @renamecomment = grep /^[^:]/, @renamecommit;
                        @renameentry = grep /R\d{3}.+$nextname/, @renamecommit;
                        push @renamecomment, @renameentry;
                        foreach (@renamecomment) {
                                print;
                        }
                if ($lines[0] =~ /R\d{3}\t(.+)\t(.+)/) {
                        $nextname = $1;
                }
                close(F);
        }
        else {
                #Not renamed
                #my $rc = system
("git-diff-tree","-r","-m","-p","--pretty=medium",$commit, $nextname);
                my $rc = system
("git-diff-tree","-r","--pretty=medium",$commit, $nextname);
                die "git-diff-tree failed" if $rc;
        }
}

sub usage($) {
        my $s = shift;
        print $s, "\n" if (length $s != 0);
        print <<EOT;
$0 <file>
This script traces renames to find the origin of the file
EOT
        exit(1);
}
-
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
Received on Fri Oct 21 06:52:35 2005

This archive was generated by hypermail 2.1.8 : 2005-10-21 06:53:09 EST