diff options
author | Petr Baudis <pasky@suse.cz> | 2005-11-01 21:26:03 +0100 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2005-11-01 14:45:48 -0800 |
commit | e3a39000e295e4bd6faff97decc31e6cb4520bb1 (patch) | |
tree | 0c917819d52ffc69aa7fd2a16f65e6176bff1c6f | |
parent | 4f9dcf7e5cf6c82455925102d315daf3b833e6d6 (diff) | |
download | git-e3a39000e295e4bd6faff97decc31e6cb4520bb1.tar.gz git-e3a39000e295e4bd6faff97decc31e6cb4520bb1.tar.xz |
Remove git-findtags.perl
This script was superseded by git-name-rev, which is more versatile,
actually documented, faster, and everything else...
Signed-off-by: Petr Baudis <pasky@suse.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>
-rw-r--r-- | Makefile | 2 | ||||
-rwxr-xr-x | git-findtags.perl | 94 |
2 files changed, 1 insertions, 95 deletions
@@ -94,7 +94,7 @@ SCRIPT_SH = \ SCRIPT_PERL = \ git-archimport.perl git-cvsimport.perl git-relink.perl \ git-rename.perl git-shortlog.perl git-fmt-merge-msg.perl \ - git-findtags.perl git-svnimport.perl git-mv.perl + git-svnimport.perl git-mv.perl SCRIPT_PYTHON = \ git-merge-recursive.py diff --git a/git-findtags.perl b/git-findtags.perl deleted file mode 100755 index 745affe3a..000000000 --- a/git-findtags.perl +++ /dev/null @@ -1,94 +0,0 @@ -#!/usr/bin/perl -w -# -# Copyright (c) 2005 Martin Langhoff -# -# Walk the tags and find if they match a commit -# expects a SHA1 of a commit. Option -t enables -# searching trees too. -# - -use strict; -use File::Basename; -use File::Find; -use Getopt::Std; - -my $git_dir = $ENV{GIT_DIR} || '.git'; -$git_dir =~ s|/$||; # chomp trailing slash - -# options -our $opt_t; -getopts("t") || usage(); - -my @tagfiles = `find $git_dir/refs/tags -follow -type f`; # haystack -my $target = shift @ARGV; # needle -unless ($target) { - usage(); -} - -# drive the processing from the find hook -# slower, safer (?) than the find utility -find( { wanted => \&process, - no_chdir => 1, - follow => 1, - }, "$git_dir/refs/tags"); - - -sub process { - my ($dev,$ino,$mode,$nlink,$uid,$gid); - - # process only regular files - unless ((($dev,$ino,$mode,$nlink,$uid,$gid) = lstat($_)) && -f _) { - return 1; # ignored anyway - } - - my $tagfile = $_; - chomp $tagfile; - my $tagname = substr($tagfile, length($git_dir.'/refs/tags/')); - - my $tagid = quickread($tagfile); - chomp $tagid; - - # is it just a soft tag? - if ($tagid eq $target) { - print "$tagname\n"; - return 1; # done with this tag - } - - # grab the first 2 lines (the whole tag could be large) - my $tagobj = `git-cat-file tag $tagid | head -n2 `; - if ($tagobj =~ m/^type commit$/m) { # only deal with commits - - if ($tagobj =~ m/^object $target$/m) { # match on the commit - print "$tagname\n"; - - } elsif ( $opt_t && # follow the commit - $tagobj =~ m/^object (\S+)$/m) { # and try to match trees - my $commitid = $1; - my $commitobj = `git-cat-file commit $commitid | head -n1`; - chomp $commitobj; - $commitobj =~ m/^tree (\S+)$/; - my $treeid = $1; - if ($target eq $treeid) { - print "$tagname\n"; - } - } - } -} - -sub quickread { - my $file = shift; - local $/; # undef: slurp mode - open FILE, "<$file" - or die "Cannot open $file : $!"; - my $content = <FILE>; - close FILE; - return $content; -} - -sub usage { - print STDERR <<END; -Usage: ${\basename $0} # find tags for a commit or tree - [ -t ] <commit-or-tree-sha1> -END - exit(1); -} |