]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - make/calcdep.pl
Fall back to copying bind IP if getsockname() fails, as it apparently can on Windows
[user/henk/code/inspircd.git] / make / calcdep.pl
index 2a0ea5d92a7390112b8935810c2c481abf0bb1cd..55e0630fc80da3497470661fdd98a7dfde843282 100755 (executable)
@@ -3,7 +3,7 @@ use strict;
 use warnings;
 use POSIX qw(getcwd);
 
-sub find_output($);
+sub find_output;
 sub gendep($);
 sub dep_cpp($$);
 sub dep_dir($);
@@ -28,11 +28,27 @@ sub run() {
        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
 
+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
@@ -84,16 +100,61 @@ commands: $cmds
 
 modules: $mods
 
-.PHONY: inspircd commands modules
+.PHONY: all bad-target inspircd commands modules
+
+END
+}
+
+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, @srcs);
+       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;
+               if ($out =~ m#obj/([^/]+)/[^/]+.o$#) {
+                       mkdir "$ENV{BUILDPATH}/obj/$1";
+               }
+               dep_cpp $file, $out;
+               next if $file =~ m#^socketengines/# && $file ne "socketengines/$ENV{SOCKETENGINE}.cpp";
+               push @deps, $out;
+               push @srcs, $file;
+       }
+
+       my $core_mk = join ' ', @deps;
+       my $core_src = join ' ', @srcs;
+       print MAKE <<END;
+
+obj/ld-extra.cmd: $core_src
+       \@\$(SOURCEPATH)/make/unit-cc.pl -f\$(VERBOSE) \$\@ \$^ \$>
+
+bin/inspircd: obj/ld-extra.cmd $core_mk
+       \@\$(SOURCEPATH)/make/unit-cc.pl -l\$(VERBOSE) \$\@ \$^ \$>
+
+inspircd: bin/inspircd
+
+.PHONY: all bad-target inspircd
 
 END
 }
 
-sub find_output($) {
-       my $file = shift;
+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_.*)/#) {