summaryrefslogtreecommitdiff
path: root/make/calcdep.pl
diff options
context:
space:
mode:
Diffstat (limited to 'make/calcdep.pl')
-rwxr-xr-xmake/calcdep.pl90
1 files changed, 68 insertions, 22 deletions
diff --git a/make/calcdep.pl b/make/calcdep.pl
index 06610c416..484c98cbd 100755
--- a/make/calcdep.pl
+++ b/make/calcdep.pl
@@ -1,10 +1,7 @@
#!/usr/bin/perl
use strict;
use warnings;
-
-# This used to be a wrapper around cc -M; however, this is a very slow
-# operation and we don't conditionally include our own files often enough
-# to justify the full preprocesor invocation for all ~200 files.
+use Getopt::Long;
my %f2dep;
@@ -15,15 +12,22 @@ sub gendep {
return $f2dep{$f} if exists $f2dep{$f};
$f2dep{$f} = '';
my %dep;
- open my $in, '<', $f;
+ open my $in, '<', $f or die "Could not read $f";
while (<$in>) {
if (/^\s*#\s*include\s*"([^"]+)"/) {
my $inc = $1;
+ my $found = 0;
for my $loc ("$basedir/$inc", "../include/$inc") {
next unless -e $loc;
+ $found++;
$dep{$loc}++;
$dep{$_}++ for split / /, gendep $loc;
}
+ if ($found == 0 && $inc ne 'inspircd_win32wrapper.h') {
+ print STDERR "WARNING: could not find header $inc for $f\n";
+ } elsif ($found > 1 && $basedir ne '../include') {
+ print STDERR "WARNING: ambiguous include $inc in $f\n";
+ }
}
}
close $in;
@@ -31,32 +35,74 @@ sub gendep {
$f2dep{$f};
}
-for my $file (@ARGV) {
- if (-e $file && $file =~ /cpp$/) {
- gendep $file;
- my($path,$base) = $file =~ m#^((?:.*/)?)([^/]+)\.cpp#;
- my $cmd = "$path.$base.d";
- my $ext = $path eq 'modules/' || $path eq 'commands/' ? '.so' : '.o';
- my $out = "$path$base$ext";
+sub dep_cpp {
+ my $file = shift;
+ gendep $file;
+ my($path,$base) = $file =~ m#^((?:.*/)?)([^/]+)\.cpp# or die "Bad file $file";
+ my $cmd = "$path.$base.d";
+ my $ext = $path eq 'modules/' || $path eq 'commands/' ? '.so' : '.o';
+ my $out = "$path$base$ext";
- open OUT, '>', $cmd;
- print OUT "$out: $file $f2dep{$file}\n";
- print OUT "\t@../make/unit-cc.pl \$(VERBOSE) $file $out\n";
- print OUT "$cmd: $file $f2dep{$file}\n";
- print OUT "\t../make/calcdep.pl $file\n";
- } elsif (-d $file && $file =~ m#^(.*?)([^/]+)/?$#) {
+ open OUT, '>', $cmd;
+ print OUT "$out: $file $f2dep{$file}\n";
+ print OUT "\t@../make/unit-cc.pl \$(VERBOSE) $file $out\n";
+ print OUT "$cmd: $file $f2dep{$file}\n";
+ print OUT "\t../make/calcdep.pl -file $file\n";
+}
+
+sub dep_dir {
+ my $dir = shift;
+ if ($dir =~ m#^(.*?)([^/]+)/?$#) {
my($path,$base) = ($1,$2);
my $cmd = "$path.$base.d";
my $out = "$path$base.so";
- opendir DIR, $file;
- my $ofiles = join ' ', grep s#(.*)\.cpp$#$path$base/$1.o#, readdir DIR;
+ opendir DIR, $dir;
+ my $ofiles = join ' ', grep s/(.*)\.cpp$/$path$base\/$1.o/, readdir DIR;
closedir DIR;
open OUT, '>', $cmd;
print OUT "$out: $ofiles\n\t".'$(RUNCC) $(PICLDFLAGS) -o $@ '
.$ofiles."\n";
- print OUT "$cmd: $file\n\t".'@../make/calcdep.pl '."$path$base\n";
+ print OUT "$cmd: $dir\n\t".'@../make/calcdep.pl -file '."$path$base\n";
+ } else {
+ print STDERR "Cannot generate depencency for $dir\n";
+ exit 1;
+ }
+}
+
+my($all,$quiet, $file);
+GetOptions(
+ 'all' => \$all,
+ 'quiet' => \$quiet,
+ 'file=s' => \$file,
+);
+
+if (!$all && !defined $file) {
+ print "Use: $0 {-all|-file filename} [-quiet]\n";
+ exit 1;
+}
+
+if (defined $file) {
+ if (-f $file) {
+ dep_cpp $file;
+ } elsif (-d $file) {
+ dep_dir $file;
} else {
- print "Cannot generate depencency for $file\n";
+ print STDERR "Can't generate dependencies for $file\n";
exit 1;
}
+} else {
+ my @files = (<*.cpp>, <commands/*.cpp>, <modes/*.cpp>, <modules/*.cpp>, <modules/m_*/*.cpp>);
+ push @files, "socketengines/$ENV{SOCKETENGINE}.cpp", "threadengines/threadengine_pthread.cpp";
+ for my $file (@files) {
+ dep_cpp $file;
+ }
+
+ my @dirs = grep -d, <modules/m_*>;
+ for my $dir (@dirs) {
+ dep_dir $dir;
+ }
+
+ s#([^/]+)\.cpp#.$1.d# for @files;
+ s#([^/]+)/?$#.$1.d# for @dirs;
+ print join ' ', @files, @dirs;
}