[BACK]Return to setlocalversion CVS log [TXT][DIR] Up to [Development] / linux-2.6-xfs-all / scripts

File: [Development] / linux-2.6-xfs-all / scripts / setlocalversion (download)

Revision 1.1, Fri Oct 28 16:02:11 2005 UTC (11 years, 11 months ago) by nathans.longdrop.melbourne.sgi.com
Branch: MAIN

Merge up to 2.6.14
Merge of 2.6.x-xfs-melb:linux:24258a by kenmcd.

#!/usr/bin/perl
# Copyright 2004 - Ryan Anderson <ryan@michonline.com>  GPL v2

use strict;
use warnings;
use Digest::MD5;
require 5.006;

if (@ARGV != 1) {
	print <<EOT;
Usage: setlocalversion <srctree>
EOT
	exit(1);
}

my ($srctree) = @ARGV;
chdir($srctree);

my @LOCALVERSIONS = ();

# We are going to use the following commands to try and determine if this
# repository is at a Version boundary (i.e, 2.6.10 vs 2.6.10 + some patches) We
# currently assume that all meaningful version boundaries are marked by a tag.
# We don't care what the tag is, just that something exists.

# Git/Cogito store the top-of-tree "commit" in .git/HEAD
# A list of known tags sits in .git/refs/tags/
#
# The simple trick here is to just compare the two of these, and if we get a
# match, return nothing, otherwise, return a subset of the SHA-1 hash in
# .git/HEAD

sub do_git_checks {
	open(H,"<.git/HEAD") or return;
	my $head = <H>;
	chomp $head;
	close(H);

	opendir(D,".git/refs/tags") or return;
	foreach my $tagfile (grep !/^\.{1,2}$/, readdir(D)) {
		open(F,"<.git/refs/tags/" . $tagfile) or return;
		my $tag = <F>;
		chomp $tag;
		close(F);
		return if ($tag eq $head);
	}
	closedir(D);

	push @LOCALVERSIONS, "g" . substr($head,0,8);
}

if ( -d ".git") {
	do_git_checks();
}

printf "-%s\n", join("-",@LOCALVERSIONS) if (scalar @LOCALVERSIONS > 0);