]> git.netwichtig.de Git - user/henk/code/inspircd.git/commitdiff
Fix modules/extra symlinks when calculating dependencies
authordanieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7>
Sun, 27 Sep 2009 14:37:04 +0000 (14:37 +0000)
committerdanieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7>
Sun, 27 Sep 2009 14:37:04 +0000 (14:37 +0000)
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11769 e03df62e-2008-0410-955e-edbf42e46eb7

make/calcdep.pl

index 05199569c029177f9f74cdc00c207f01cafdec97..7d424f4e366ed18debbf548550d9f9b5333d8934 100755 (executable)
@@ -42,18 +42,29 @@ END
        }
        
        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;
        }
 
        opendir my $moddir, 'modules';
-       for my $dir (readdir $moddir) {
-               next unless $dir =~ /^m_/ && -d "modules/$dir";
-               if (dep_dir "modules/$dir") {
-                       mkdir "$build/obj/$dir";
-                       push @modlist, "modules/$dir.so";
+       for my $file (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;
                }
        }