# HG changeset patch # User Gerd Moellmann # Date 996066030 0 # Node ID 6bd3c93022e74c62da6a8151f84413659b3f6a91 # Parent f909f7fe9a651f01864a86f31715fe9773de04df (parse_changelog): Remove unused local variable. (main): Add new option --reverse. (print_log): Use it. (parse_changelog): Use it. diff -r f909f7fe9a65 -r 6bd3c93022e7 lib-src/grep-changelog --- a/lib-src/grep-changelog Wed Jul 25 12:52:23 2001 +0000 +++ b/lib-src/grep-changelog Wed Jul 25 13:00:30 2001 +0000 @@ -23,7 +23,7 @@ # Extract entries from ChangeLogs matching specified criteria. # Optionally format the resulting output to a form suitable for RCS # logs, like they are used in Emacs, for example. In this format, -# author lines leading spaces, and file names are removed. +# author lines, leading spaces, and file names are removed. require 5; use strict; @@ -31,7 +31,8 @@ # Parse command line options. use vars qw($author $regexp $exclude $from_date $to_date - $rcs_log $with_date $version $help); + $rcs_log $with_date $version $help $reverse + @entries); use Getopt::Long; my $result = GetOptions ("author=s" => \$author, @@ -41,6 +42,7 @@ "to-date=s" => \$to_date, "rcs-log" => \$rcs_log, "with-date" => \$with_date, + "reverse!" => \$reverse, "version" => \$version, "help" => \$help); @@ -67,6 +69,7 @@ --to-date=YYYY-MM-DD match entries not younger than given date --rcs-log format output suitable for RCS log entries. --with-date print short date line in RCS log + --reverse show entries in reverse (chronological) order --version print version info --help print this help @@ -142,6 +145,7 @@ sub print_log ($$) { my ($header, $entry) = @_; + my $output = ''; if ($rcs_log) { # Remove leading whitespace from entry. @@ -152,11 +156,17 @@ $entry =~ s/^\*.*://mg; if ($with_date) { $header =~ /(\d\d\d\d-\d\d-\d\d)/; - print "!changelog-date $1\n"; + $output = "!changelog-date $1\n"; } - print $entry; + $output .= $entry; } else { - print $header, $entry; + $output .= $header . $entry; + } + + if ($reverse) { + push @entries, $output; + } else { + print $output; } } @@ -166,7 +176,8 @@ my $log = shift; my $entry = undef; my $header = undef; - my $match; + + @entries = () if $reverse; # Open the ChangeLog. open (IN, "< $log") || die "Cannot open $log: $!"; @@ -206,24 +217,27 @@ if header_match_p ($header) && entry_match_p ($entry); close IN; + + if ($reverse) { + while (defined (my $entry = pop @entries)) { + print $entry; + } + } } # Main program. Process ChangeLogs. -if (@ARGV > 0) { - # If files were specified on the command line, parse those files. - while (defined(my $log = shift @ARGV)) { - parse_changelog ($log); - } -} else { - # Parse default files ChangeLog and ChangeLog.9...ChangeLog.1 in - # that order. - parse_changelog ("ChangeLog"); - for (my $i = 9; $i >= 1; --$i) { - my $log = "ChangeLog.$i"; - parse_changelog ($log) if -f $log; - } +# If files were specified on the command line, parse those files in the +# order supplied by the user; otherwise parse default files ChangeLog and +# ChangeLog.9...ChangeLog.1 according to $reverse. +unless (@ARGV > 0) { + @ARGV = ("ChangeLog", map {"ChangeLog.$_"} reverse 1..9); + @ARGV = reverse @ARGV if $reverse; +} + +while (defined (my $log = shift @ARGV)) { + parse_changelog ($log) if -f $log; }