X-Git-Url: https://git.rohieb.name/openwrt.git/blobdiff_plain/7eceaccf8379b7558fd6b3fac52ec6d985033f0b..ff7d812c96ab25670f83cd899a2cdefaf2f41965:/scripts/timestamp.pl

diff --git a/scripts/timestamp.pl b/scripts/timestamp.pl
index 9735dd61e..3bf057151 100755
--- a/scripts/timestamp.pl
+++ b/scripts/timestamp.pl
@@ -1,35 +1,31 @@
-#!/usr/bin/perl
-use strict;
-use File::stat;
+#!/usr/bin/env perl
+# 
+# Copyright (C) 2006 OpenWrt.org
+#
+# This is free software, licensed under the GNU General Public License v2.
+# See /LICENSE for more information.
+#
 
-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; 
-}
+use strict;
 
 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;
+	$path .= "/" if( -d $path);
+	open FIND, "find $path -type f -and -not -path \\*.svn\\* -and -not -path \\*CVS\\* $options 2>/dev/null |";
+	while (<FIND>) {
+		chomp;
+		my $file = $_;
+		next if -l $file;
+		my $mt = (stat $file)[9];
+		if ($mt > $ts) {
+			$ts = $mt;
 			$fn = $file;
 		}
 	}
+	close FIND;
 	return ($ts, $fn);
 }
 
@@ -41,13 +37,18 @@ while (@ARGV > 0) {
 	my $path = shift @ARGV;
 	if ($path =~ /^-x/) {
 		my $str = shift @ARGV;
-		$options{"-x"} .= "|".$str;
+		$options{"findopts"} .= " -and -not -path '".$str."'"
+	} elsif ($path =~ /^-f/) {
+		$options{"findopts"} .= " -follow";
+	} elsif ($path =~ /^-n/) {
+		my $arg = $ARGV[0];
+		$options{$path} = $arg;
 	} elsif ($path =~ /^-/) {
 		$options{$path} = 1;
 	} else {
-		my ($tmp, $fname) = get_ts($path, $options{"-x"});
+		my ($tmp, $fname) = get_ts($path, $options{"findopts"});
 		if ($tmp > $ts) {
-			if ($options{'-f'}) {
+			if ($options{'-F'}) {
 				$n = $fname;
 			} else {
 				$n = $path;
@@ -57,7 +58,9 @@ while (@ARGV > 0) {
 	}
 }
 
-if ($options{"-p"}) {
+if ($options{"-n"}) {
+	exit ($n eq $options{"-n"} ? 0 : 1);
+} elsif ($options{"-p"}) {
 	print "$n\n";
 } elsif ($options{"-t"}) {
 	print "$ts\n";