From 716ca530e1c4515d8683c9d5be3d56b301758b66 Mon Sep 17 00:00:00 2001 From: James <> Date: Wed, 4 Nov 2015 11:49:21 +0000 Subject: trunk-47381 --- scripts/timestamp.pl | 69 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 69 insertions(+) create mode 100755 scripts/timestamp.pl (limited to 'scripts/timestamp.pl') diff --git a/scripts/timestamp.pl b/scripts/timestamp.pl new file mode 100755 index 0000000..e24d814 --- /dev/null +++ b/scripts/timestamp.pl @@ -0,0 +1,69 @@ +#!/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. +# + +use strict; + +sub get_ts($$) { + my $path = shift; + my $options = shift; + my $ts = 0; + my $fn = ""; + $path .= "/" if( -d $path); + open FIND, "find $path -type f -and -not -path \\*/.svn\\* -and -not -path \\*CVS\\* $options 2>/dev/null |"; + while () { + chomp; + my $file = $_; + next if -l $file; + my $mt = (stat $file)[9]; + if ($mt > $ts) { + $ts = $mt; + $fn = $file; + } + } + close FIND; + return ($ts, $fn); +} + +(@ARGV > 0) or push @ARGV, "."; +my $ts = 0; +my $n = "."; +my %options; +while (@ARGV > 0) { + my $path = shift @ARGV; + if ($path =~ /^-x/) { + my $str = shift @ARGV; + $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{"findopts"}); + if ($tmp > $ts) { + if ($options{'-F'}) { + $n = $fname; + } else { + $n = $path; + } + $ts = $tmp; + } + } +} + +if ($options{"-n"}) { + exit ($n eq $options{"-n"} ? 0 : 1); +} elsif ($options{"-p"}) { + print "$n\n"; +} elsif ($options{"-t"}) { + print "$ts\n"; +} else { + print "$n\t$ts\n"; +} -- cgit v1.2.3