aboutsummaryrefslogtreecommitdiffstats
path: root/CVSROOT/commit_prep.pl
diff options
context:
space:
mode:
Diffstat (limited to 'CVSROOT/commit_prep.pl')
-rwxr-xr-xCVSROOT/commit_prep.pl56
1 files changed, 34 insertions, 22 deletions
diff --git a/CVSROOT/commit_prep.pl b/CVSROOT/commit_prep.pl
index c37baf0237c5..27d6bed31c93 100755
--- a/CVSROOT/commit_prep.pl
+++ b/CVSROOT/commit_prep.pl
@@ -98,25 +98,13 @@ sub write_line {
close FILE;
}
-sub check_version {
+# Check to see whether a file is mentioned in the exclusion file.
+sub exclude_file {
my $filename = shift;
my $directory = shift;
- my $hastag = shift;
- my $lastversion = shift;
-
- my $found_rcsid; # True if our rcsid was found in the file.
- my $rcsid; # The rcsid that was in the file.
- my $rcsid_info; # The expanded values of the rcsid.
- my $rname; # The file pathname, parsed from the rcsid.
- my $version; # The file version, parsed from the rcsid.
- # not present - either removed or let cvs deal with it.
- return 0 unless -f $filename;
-
- # If an exclusion list exists use it to see whether this
- # file should be exempt from version checking.
- my $exclude = $cvsroot . "/CVSROOT/exclude";
- my $path = $directory . "/" . $filename;
+ my $exclude = "$cvsroot/CVSROOT/exclude";
+ my $path = "$directory/$filename";
if (open(EX, "<$exclude")) {
while (<EX>) {
chomp;
@@ -126,12 +114,31 @@ sub check_version {
if ($path =~ /$ex_entry/) {
close(EX);
- return(0);
+ return(1);
}
}
close(EX);
}
+ # File shouldn't be excluded.
+ return(0);
+}
+
+sub check_version {
+ my $filename = shift;
+ my $directory = shift;
+ my $hastag = shift;
+ my $lastversion = shift;
+
+ my $found_rcsid; # True if our rcsid was found in the file.
+ my $rcsid; # The rcsid that was in the file.
+ my $rcsid_info; # The expanded values of the rcsid.
+ my $rname; # The file pathname, parsed from the rcsid.
+ my $version; # The file version, parsed from the rcsid.
+
+ # not present - either removed or let cvs deal with it.
+ return 0 unless -f $filename;
+
# Search the file for our rcsid.
# NOTE: We stop after finding the first potential match.
open FILE, $filename or die "Cannot open $filename, stopped\n";
@@ -158,11 +165,6 @@ sub check_version {
$rcsid_info = $2 || "";
($rname, $version) = split /\s/, $rcsid_info;
- # Now that we're definitely sure that the file was supposed
- # to have rcsid's in it, unexpand them in the file that's
- # being checked in.
- fix_up_file($filename) if $cfg::UNEXPAND_RCSID;
-
# Ignore version mismatches (MFC spamming etc) on branches.
if ($hastag) {
return (0);
@@ -294,8 +296,18 @@ if ($check_id != 0) {
next if (index($arg, ".") == 0);
next if ($check_id == 2 && $arg ne "Makefile");
next if ($check_id == 3 && $hastag);
+
+ # Ignore the file if it's in the exclude list.
+ next if exclude_file($arg, $directory);
+
+ # Check to make sure that the file hasn't had
+ # it's revision string changed.
$failed += &check_version($arg, $directory, $hastag,
$cvsversion{$arg});
+
+ # Unexpand the rcsid if required.
+ fix_up_file($arg) if $cfg::UNEXPAND_RCSID and !$failed;
+
}
if ($failed) {
print "\n";