aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPetr Baudis <pasky@suse.cz>2005-11-01 21:26:03 +0100
committerJunio C Hamano <junkio@cox.net>2005-11-01 14:45:48 -0800
commite3a39000e295e4bd6faff97decc31e6cb4520bb1 (patch)
tree0c917819d52ffc69aa7fd2a16f65e6176bff1c6f
parent4f9dcf7e5cf6c82455925102d315daf3b833e6d6 (diff)
downloadgit-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--Makefile2
-rwxr-xr-xgit-findtags.perl94
2 files changed, 1 insertions, 95 deletions
diff --git a/Makefile b/Makefile
index 1163dda0f..67c10302b 100644
--- a/Makefile
+++ b/Makefile
@@ -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);
-}