X-Git-Url: https://git.openssl.org/?a=blobdiff_plain;f=util%2Fclean-depend.pl;h=f29192f246e63de52308117f3103d717b7c60078;hb=7281cbaaa73368b44b148948debd38b9b60271e0;hp=6c485d1e2fb12d9a83817e9e026e5fac8656199c;hpb=3009e9f9ef196829befec5b96730747bb24dd120;p=openssl.git diff --git a/util/clean-depend.pl b/util/clean-depend.pl index 6c485d1e2f..f29192f246 100755 --- a/util/clean-depend.pl +++ b/util/clean-depend.pl @@ -3,6 +3,11 @@ # Written by Ben Laurie 19 Jan 1999 use strict; +use Cwd; + +my $path = getcwd(); +$path =~ /([^\/]+)$/; +$path = $1; while() { print; @@ -11,24 +16,40 @@ while() { my %files; +# Fetch all the dependency output first my $thisfile=""; while() { my ($dummy, $file,$deps)=/^((.*):)? (.*)$/; - my $origfile=""; $thisfile=$file if defined $file; next if !defined $deps; - $origfile=$thisfile; - $origfile=~s/\.o$/.c/; my @deps=split ' ',$deps; - @deps=grep(!/^\//,@deps); @deps=grep(!/^\\$/,@deps); - @deps=grep(!/^$origfile$/,@deps); -# pull out the kludged kerberos header (if present). - @deps=grep(!/^[.\/]+\/krb5.h/,@deps); push @{$files{$thisfile}},@deps; } my $file; + +# Time to clean out possible system directories and normalise quirks +# from different makedepend methods +foreach $file (sort keys %files) { + # This gets around a quirk with gcc, which removes all directory + # information from the original file + my $tmpfile=$file; + $tmpfile=~s/\.o$/.c/; + (my $origfile)=grep(/(^|\/)${tmpfile}$/,@{$files{$file}}); + my $newfile=$origfile; + $newfile=~s/\.c$/.o/; + if ($newfile ne $file) { + $files{$newfile} = $files{$file}; + delete $files{$file}; + $file = $newfile; + } + + @{$files{$file}} = + grep(!/^\//, + grep(!/^$origfile$/, @{$files{$file}})); +} + foreach $file (sort keys %files) { my $len=0; my $dep; @@ -37,7 +58,13 @@ foreach $file (sort keys %files) { $file=~s/^\.\///; push @{$files{$file}},$origfile; my $prevdep=""; - foreach $dep (sort @{$files{$file}}) { + + # Remove leading ./ before sorting + my @deps = map { $_ =~ s/^\.\///; $_ } @{$files{$file}}; + # Remove ../thisdir/ + @deps = map { $_ =~ s|^../$path/||; $_ } @deps; + + foreach $dep (sort @deps) { $dep=~s/^\.\///; next if $prevdep eq $dep; # to exterminate duplicates... $prevdep = $dep;