aboutsummaryrefslogtreecommitdiffstats
path: root/CVSROOT
diff options
context:
space:
mode:
Diffstat (limited to 'CVSROOT')
-rwxr-xr-xCVSROOT/logcheck87
1 files changed, 39 insertions, 48 deletions
diff --git a/CVSROOT/logcheck b/CVSROOT/logcheck
index a583aab3f9bb..e5cbe71f4515 100755
--- a/CVSROOT/logcheck
+++ b/CVSROOT/logcheck
@@ -14,9 +14,7 @@
use strict;
my $filename = shift;
-unless ($filename) {
- die "Usage: logcheck filename\n";
-}
+die "Usage: logcheck filename\n" unless $filename;
my $tmpfile = $filename . "tmp";
open(IN, "< $filename") ||
@@ -25,62 +23,55 @@ open(IN, "< $filename") ||
open(OUT, "> $tmpfile") ||
die "logcheck: Cannot open for writing: $tmpfile: $!\n";
-# In-place edit the result of the user's edit on the file.
-my $blank = 0; # true if the last line was blank
-my $first = 0; # true if we have seen the first real text
-while(<IN>) {
- # Dont let CVS: lines upset things, strip them out.
- if (/^CVS:/) {
- next;
- }
- chomp; # strip trailing newline
- s/[\s]+$//; # strip trailing whitespace
+# Read the log file in, stripping 'CVS:' lines and removing trailing
+# white spaces.
+my @log_in = map { s/^(.*)\s*$/$1/; $1 } grep { !/^CVS:/ } <IN>;
- # collapse multiple blank lines, and trailing blank lines.
- if (/^$/) {
- # Blank line. Remember in case more text follows.
- $blank = 1;
+# Remove leading, trailing and duplicate blank lines.
+my $i = 0;
+while ($i < scalar(@log_in)) {
+ unless ($log_in[$i] or $log_in[$i + 1]) {
+ splice(@log_in, $i, 1);
next;
- } else {
- # Delete if they only have whitespace after them.
- if (/^Reviewed by:$/i ||
- /^Submitted by:$/i ||
- /^Obtained from:$/i ||
- /^Approved by:$/i ||
- /^PR:$/i) {
- next;
- }
+ }
+ ++$i;
+}
+shift @log_in unless $log_in[0];
- # Special handling for type checking the 'MFC after' field.
- if (/^MFC after:\s*(.*)$/) {
- # Ignore it if no value was filled in.
- next unless $1;
+# Filter out blank templated entries, and type check if necessary.
+foreach (@log_in) {
+ # Delete if they only have whitespace after them.
+ if (/^Reviewed by:$/i ||
+ /^Submitted by:$/i ||
+ /^Obtained from:$/i ||
+ /^Approved by:$/i ||
+ /^PR:$/i) {
+ next;
+ }
- unless ($1 =~ /[\d]+ (days?|weeks?)$/) {
- print "Parse error in 'MFC after:'\n";
- exit 1;
- }
- }
+ # Special handling for type checking the 'MFC after' field.
+ if (/^MFC after:\s*(.*)$/) {
+ # Ignore it if no value was filled in.
+ next unless $1;
- if ($blank && $first) {
- # Previous line(s) was blank, this isn't. Close the
- # collapsed section.
- print OUT "\n";
+ unless ($1 =~ /[\d]+ (days?|weeks?)$/) {
+ print "Parse error in 'MFC after:'\n";
+ exit 1;
}
- $blank = 0; # record non-blank
- $first = 1; # record first line
- print OUT "$_\n";
}
+
+ print OUT "$_\n";
}
-close(IN);
-close(OUT);
+close IN;
+close OUT;
-unlink($filename . "~"); # Nuke likely editor backups..
-unlink($filename . ".bak"); # Nuke likely editor backups..
+# Nuke likely editor backups.
+unlink "$filename.~";
+unlink "$filename.bak";
rename("$tmpfile", "$filename") ||
- die("logcheck: Could not rename $tmpfile to $filename: $!");
+ die "logcheck: Could not rename $tmpfile to $filename: $!";
-exit(0);
+exit 0;