From eb910456e2f01255f277fe060fef6f7dd3018cf7 Mon Sep 17 00:00:00 2001 From: danieldg Date: Tue, 1 Sep 2009 22:44:44 +0000 Subject: Move file inclusion logic into calcdep, and complain about ambiguous #include directives there git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11587 e03df62e-2008-0410-955e-edbf42e46eb7 --- make/bsd-real.mk | 6 ++-- make/calcdep.pl | 90 ++++++++++++++++++++++++++++++++++++++++++-------------- make/gnu-real.mk | 17 ++++------- 3 files changed, 76 insertions(+), 37 deletions(-) (limited to 'make') diff --git a/make/bsd-real.mk b/make/bsd-real.mk index 6fdf2e57f..4ccc11be3 100644 --- a/make/bsd-real.mk +++ b/make/bsd-real.mk @@ -1,13 +1,11 @@ CORE_TARGS != perl -e 'print join " ", grep s/\.cpp/.o/, <*.cpp>, ' CMD_TARGS != perl -e 'print join " ", grep s/\.cpp/.so/, ' MOD_TARGS != perl -e 'print join " ", grep s/\.cpp/.so/, ' -MDIR_TARGS != perl -e 'print join " ", grep s!/?$$!.so!, ' +MDIR_TARGS != perl -e 'print join " ", grep s!/?$$!.so!, grep -d, ' CORE_TARGS += socketengines/$(SOCKETENGINE).o threadengines/threadengine_pthread.o -DFILES != perl -e 'print join " ", grep s!([^/]+)\.cpp!.$$1.d!, <*.cpp>, , , , ' -DFILES2 != perl -e 'print join " ", grep s!([^/]+)/?$$!.$$1.d!, ' -DFILES += $(DFILES2) socketengines/.$(SOCKETENGINE).d threadengines/.threadengine_pthread.d +DFILES != perl ../make/calcdep.pl -all all: inspircd commands modules 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>, , , , ); + push @files, "socketengines/$ENV{SOCKETENGINE}.cpp", "threadengines/threadengine_pthread.cpp"; + for my $file (@files) { + dep_cpp $file; + } + + my @dirs = grep -d, ; + for my $dir (@dirs) { + dep_dir $dir; + } + + s#([^/]+)\.cpp#.$1.d# for @files; + s#([^/]+)/?$#.$1.d# for @dirs; + print join ' ', @files, @dirs; } diff --git a/make/gnu-real.mk b/make/gnu-real.mk index 79fc2cd9e..e892295a6 100644 --- a/make/gnu-real.mk +++ b/make/gnu-real.mk @@ -1,16 +1,11 @@ -CORE_TARGS = $(patsubst %.cpp,%.o,$(wildcard *.cpp)) -MODE_TARGS = $(patsubst %.cpp,%.o,$(wildcard modes/*.cpp)) +CORE_TARGS = $(patsubst %.cpp,%.o,$(wildcard *.cpp) $(wildcard modes/*.cpp)) CMD_TARGS = $(patsubst %.cpp,%.so,$(wildcard commands/*.cpp)) MOD_TARGS = $(patsubst %.cpp,%.so,$(wildcard modules/*.cpp)) -CORE_TARGS += threadengines/threadengine_pthread.o -CORE_TARGS += socketengines/$(SOCKETENGINE).o -CORE_TARGS += $(MODE_TARGS) -MOD_TARGS += $(shell perl -e 'print join " ", grep s!([^/]+)/$$!$$1.so!, ') +CORE_TARGS += socketengines/$(SOCKETENGINE).o threadengines/threadengine_pthread.o +MOD_TARGS += $(shell perl -e 'print join " ", grep s!/?$$!.so!, grep -d, ') -DFILES = $(shell perl -e 'print join " ", grep s!([^/]+)\.cpp!.$$1.d!, <*.cpp>, , , , ') -DFILES += $(shell perl -e 'print join " ", grep s!([^/]+)/?$$!.$$1.d!, ') -DFILES += socketengines/.$(SOCKETENGINE).d threadengines/.threadengine_pthread.d +DFILES = $(shell ../make/calcdep.pl -all) all: inspircd commands modules @@ -22,10 +17,10 @@ inspircd: $(CORE_TARGS) $(RUNCC) -o $@ $(CORELDFLAGS) $(LDLIBS) $(CORE_TARGS) .%.d: %.cpp - @../make/calcdep.pl $< + @../make/calcdep.pl -file $< .%.d: % - @../make/calcdep.pl $< + @../make/calcdep.pl -file $< .PHONY: all alldep commands modules -- cgit v1.2.3