From: Mike Baker Date: Mon, 15 May 2006 23:04:02 +0000 (+0000) Subject: revert; perl version was entirely too slow X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=7db51089509c6fb62a4d9f8f3f64e961d4178883;p=openwrt%2Fstaging%2Fwigyori.git revert; perl version was entirely too slow SVN-Revision: 3783 --- diff --git a/openwrt/scripts/timestamp.pl b/openwrt/scripts/timestamp.pl index 9735dd61e4..dc47e24aae 100755 --- a/openwrt/scripts/timestamp.pl +++ b/openwrt/scripts/timestamp.pl @@ -1,35 +1,24 @@ #!/usr/bin/perl use strict; -use File::stat; - -sub crawl($$) { - my $path = shift; - my $options = shift; - my @results = $path; - opendir(DIR,$path); - foreach my $file (readdir(DIR)) { - if ($file !~m/^(\.(svn|\.?)|CVS$options)$/) { - push @results, crawl("$path/$file",$options); - } - } - closedir(DIR); - return @results; -} sub get_ts($$) { my $path = shift; my $options = shift; my $ts = 0; my $fn = ""; - my @search = crawl($path,$options); - while (@search) { - my $file = shift @search; - my $mtime = stat($file)->mtime; - if ($mtime > $ts) { - $ts = $mtime; + open FIND, "find $path -not -path \\*.svn\\* -and -not -path \\*CVS\\* $options 2>/dev/null |"; + while () { + chomp; + my $file = $_; + open FILE, "<$file"; + my @stat = stat FILE; + close FILE; + if ($stat[9] > $ts) { + $ts = $stat[9]; $fn = $file; } } + close FIND; return ($ts, $fn); } @@ -41,7 +30,7 @@ while (@ARGV > 0) { my $path = shift @ARGV; if ($path =~ /^-x/) { my $str = shift @ARGV; - $options{"-x"} .= "|".$str; + $options{"-x"} .= " -and -not -path \\*".$str."\\*" } elsif ($path =~ /^-/) { $options{$path} = 1; } else {