X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=bin%2Fkeep-latest;h=dedef69666bd6bc565d658ac42bc5df63878b2d9;hb=bf263c8438b11ee7acb1308cf96bfca49ff2781f;hp=788dcc5eb4185cc35d87c1e4e726ea721fcaf272;hpb=e2c9e71b82bc84d98e55e2a6794b5397cf1bbc5f;p=wannabuild.git diff --git a/bin/keep-latest b/bin/keep-latest index 788dcc5..dedef69 100755 --- a/bin/keep-latest +++ b/bin/keep-latest @@ -27,29 +27,48 @@ my %data; my $arch = shift @ARGV; -local($/) = ""; # read in paragraph mode -while (<>) { - my( $version, $name, $architecture ); - $architecture="none"; # better to keep an entry too much than to delete an entry - /^Package:\s*(\S+)$/mi and $name = $1; - /^Version:\s*(\S+)$/mi and $version = $1; - /^Architecture:\s*(\S+)$/mi and $architecture = $1; - if (!defined $name or !defined $version) { - warn "Stanza without Package or Version\n"; +#Read in all data files: +for my $file (@ARGV) { + if (! -f $file) { next; } - if ($arch ne "source" && defined $architecture && $architecture ne "all" && $architecture ne $arch) { - next; + my $fh; + if ($file =~ /.gz$/) { + open($fh, '-|', 'gzip', '-d', '-c', $file) + or die("Can't open pipe from gzip: $!"); + } else { + open($fh, '<', $file) + or die("Can't open $file: $!"); } - my $key = $name; - if ((!exists $version{$key}) or version_less($version{$key},$version)) { - $version{$key} = $version; - $data{$key} = $_; + local($/) = ""; # read in paragraph mode + while (<$fh>) { + my( $version, $name, $architecture ); + $architecture="none"; # better to keep an entry too much than to delete an entry + /^Package:\s*(\S+)$/mi and $name = $1; + /^Version:\s*(\S+)$/mi and $version = $1; + /^Architecture:\s*(\S+)$/mi and $architecture = $1; + if (!defined $name or !defined $version) { + warn "Stanza without Package or Version\n"; + next; + } + if ($arch ne "source" && defined $architecture && $architecture ne "all" && $architecture ne $arch) { + next; + } + my $key = $name; + + if ((!exists $version{$key}) or version_less($version{$key},$version)) { + $version{$key} = $version; + $data{$key} = $_; + } } + + close($fh); } + +#Now output the shortened list: foreach (values %data) { - chomp; $_ .= "\n\n"; + chomp; chomp; $_ .= "\n\n"; print; }