]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - make/calcdep.pl
GCC 4.5 warning fixups
[user/henk/code/inspircd.git] / make / calcdep.pl
index 1a65f836b27f58b07a9e10b10fbeb416776b5d5a..1a1963b3102c9ac5ff5c79c9179d47400d690238 100755 (executable)
@@ -1,9 +1,9 @@
 #!/usr/bin/perl
 use strict;
 use warnings;
-use Getopt::Long;
+use POSIX qw(getcwd);
 
-sub find_output($);
+sub find_output;
 sub gendep($);
 sub dep_cpp($$);
 sub dep_dir($);
@@ -18,65 +18,135 @@ sub run() {
        my $build = $ENV{BUILDPATH};
        mkdir $build;
        chdir $build or die "Could not open build directory: $!";
-       mkdir 'bin';
-       mkdir 'obj';
-       mkdir 'modules';
        symlink "$ENV{SOURCEPATH}/include", 'include';
-       $build = `pwd`;
-       chomp $build;
+       mkdir $_ for qw/bin modules obj/;
+# BSD make has a horribly annoying bug resulting in an extra chdir of the make process
+# Create symlinks to work around it
+       symlink "../$_", "obj/$_" for qw/bin modules obj/;
+
+       $build = getcwd();
        open MAKE, '>real.mk' or die "Could not write real.mk: $!";
        chdir "$ENV{SOURCEPATH}/src";
 
+       if ($ENV{PURE_STATIC}) {
+               run_static();
+       } else {
+               run_dynamic();
+       }
+       close MAKE;
+}
+
+sub run_dynamic() {
+       my $build = $ENV{BUILDPATH};
        print MAKE <<END;
-# DO NOT EDIT
-# Autogenerated by calcdep
+# DO NOT EDIT THIS FILE
+# It is autogenerated by make/calcdep.pl, and will be overwritten
+# every time you rerun make in the main directory
 VPATH = \$(SOURCEPATH)/src
 
-all: bin/inspircd modules
+bad-target:
+       \@echo "This Makefile must be run by a sub-make from the source"
+       \@echo "in order to set the correct environment variables"
+       \@exit 1
+
+all: inspircd commands modules
 
 END
-       my @core_deps;
-       for my $file (<*.cpp>, <modes/*.cpp>, "socketengines/$ENV{SOCKETENGINE}.cpp", "threadengines/threadengine_pthread.cpp") {
+       my(@core_deps, @cmdlist, @modlist);
+       for my $file (<*.cpp>, <modes/*.cpp>, <socketengines/*.cpp>, "threadengines/threadengine_pthread.cpp") {
                my $out = find_output $file;
                dep_cpp $file, $out;
+               next if $file =~ m#^socketengines/# && $file ne "socketengines/$ENV{SOCKETENGINE}.cpp";
                push @core_deps, $out;
        }
-       
-       my @modlist;
-       for my $file (<commands/*.cpp>, <modules/*.cpp>) {
+
+       for my $file (<commands/*.cpp>) {
                my $out = find_output $file;
                dep_cpp $file, $out;
-               push @modlist, $out;
+               push @cmdlist, $out;
        }
 
        opendir my $moddir, 'modules';
-       for my $dir (readdir $moddir) {
-               next unless $dir =~ /^m_/ && -d "modules/$dir";
-               mkdir "$build/obj/$dir";
-               dep_dir "modules/$dir";
-               push @modlist, "modules/$dir.so";
+       for my $file (sort readdir $moddir) {
+               next if $file =~ /^\./;
+               if (-e "modules/extra/$file" && !-l "modules/$file") {
+                       # Incorrect symlink?
+                       print "Replacing symlink for $file found in modules/extra\n";
+                       rename "modules/$file", "modules/$file~";
+                       symlink "extra/$file", "modules/$file";
+               }
+               if ($file =~ /^m_/ && -d "modules/$file" && dep_dir "modules/$file") {
+                       mkdir "$build/obj/$file";
+                       push @modlist, "modules/$file.so";
+               }
+               if ($file =~ /^m_.*\.cpp$/) {
+                       my $out = find_output "modules/$file";
+                       dep_cpp "modules/$file", $out;
+                       push @modlist, $out;
+               }
        }
        
        my $core_mk = join ' ', @core_deps;
+       my $cmds = join ' ', @cmdlist;
        my $mods = join ' ', @modlist;
        print MAKE <<END;
 
 bin/inspircd: $core_mk
-       \$(RUNCC) -o \$\@ \$(CORELDFLAGS) \$(LDLIBS) \$^
+       \$(RUNCC) -o \$\@ \$(CORELDFLAGS) \$(LDLIBS) \$^ \$>
 
 inspircd: bin/inspircd
+
+commands: $cmds
+
 modules: $mods
 
-.PHONY: inspircd modules
+.PHONY: all bad-target inspircd commands modules
 
 END
 }
 
-sub find_output($) {
-       my $file = shift;
+sub run_static() {
+       print MAKE <<END;
+# DO NOT EDIT THIS FILE
+# It is autogenerated by make/calcdep.pl, and will be overwritten
+# every time you rerun make in the main directory
+VPATH = \$(SOURCEPATH)/src
+
+bad-target:
+       \@echo "This Makefile must be run by a sub-make from the source"
+       \@echo "in order to set the correct environment variables"
+       \@exit 1
+
+all: inspircd
+
+END
+       my @deps;
+       for my $file (<*.cpp>, <modes/*.cpp>, <socketengines/*.cpp>, <commands/*.cpp>,
+                       <modules/*.cpp>, <modules/m_*/*.cpp>, "threadengines/threadengine_pthread.cpp") {
+               my $out = find_output $file, 1;
+               dep_cpp $file, $out;
+               next if $file =~ m#^socketengines/# && $file ne "socketengines/$ENV{SOCKETENGINE}.cpp";
+               push @deps, $out;
+       }
+
+       my $core_mk = join ' ', @deps;
+       print MAKE <<END;
+
+bin/inspircd: $core_mk
+       \$(RUNCC) -o \$\@ \$(CORELDFLAGS) \$(LDLIBS) \$^ \$>
+
+inspircd: bin/inspircd
+
+.PHONY: all bad-target inspircd
+
+END
+}
+
+sub find_output {
+       my($file, $static) = @_;
        my($path,$base) = $file =~ m#^((?:.*/)?)([^/]+)\.cpp# or die "Bad file $file";
        if ($path eq 'modules/' || $path eq 'commands/') {
-               return "modules/$base.so";
+               return $static ? "obj/$base.o" : "modules/$base.so";
        } elsif ($path eq '' || $path eq 'modes/' || $path =~ /^[a-z]+engines\/$/) {
                return "obj/$base.o";
        } elsif ($path =~ m#modules/(m_.*)/#) {
@@ -127,21 +197,26 @@ sub dep_cpp($$) {
        gendep $file;
 
        print MAKE "$out: $file $f2dep{$file}\n";
-       print MAKE "\t@\$(SOURCEPATH)/make/unit-cc.pl \$(VERBOSE) \$< \$\@\n";
+       print MAKE "\t@\$(SOURCEPATH)/make/unit-cc.pl \$(VERBOSE) \$\@ \$< \$>\n";
 }
 
 sub dep_dir($) {
        my($dir) = @_;
        my @ofiles;
        opendir DIR, $dir;
-       for my $file (readdir DIR) {
+       for my $file (sort readdir DIR) {
                next unless $file =~ /(.*)\.cpp$/;
                my $ofile = find_output "$dir/$file";
                dep_cpp "$dir/$file", $ofile;
                push @ofiles, $ofile;
        }
        closedir DIR;
-       my $ofiles = join ' ', @ofiles;
-       print MAKE "$dir.so: $ofiles\n\t\$(RUNCC) \$(PICLDFLAGS) -o \$\@ \$^\n";
+       if (@ofiles) {
+               my $ofiles = join ' ', @ofiles;
+               print MAKE "$dir.so: $ofiles\n\t\$(RUNCC) \$(PICLDFLAGS) -o \$\@ \$^ \$>\n";
+               return 1;
+       } else {
+               return 0;
+       }
 }