]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - tools/test-build
Merge branch 'insp20' into master.
[user/henk/code/inspircd.git] / tools / test-build
index 7f1bf68cdf487c5ae3303076b02ba8a13016c074..6472895698bb3bd5d396ad726276242987210a04 100755 (executable)
@@ -2,7 +2,7 @@
 #
 # InspIRCd -- Internet Relay Chat Daemon
 #
-#   Copyright (C) 2013 Peter Powell <petpow@saberuk.com>
+#   Copyright (C) 2013-2014 Peter Powell <petpow@saberuk.com>
 #
 # This file is part of InspIRCd.  InspIRCd is free software: you can
 # redistribute it and/or modify it under the terms of the GNU General Public
 
 
 BEGIN {
-       require 5.8.0;
+       require 5.10.0;
        unless (-f 'configure') {
-               print "Error: test-build must be run from the main source directory!\n";
+               print "Error: $0 must be run from the main source directory!\n";
                exit 1;
        }
 }
 
+use feature ':5.10';
 use strict;
 use warnings FATAL => qw(all);
 
+use FindBin qw($RealDir);
+
+use lib $RealDir;
+use make::common;
 use make::configure;
-use make::utilities;
 
-$ENV{D} = $ENV{V} = 1;
+$ENV{INSPIRCD_DEBUG} = $ENV{INSPIRCD_VERBOSE} = 1;
 
 system 'git', 'clean', '-dfx';
 
-foreach my $compiler ('g++', 'clang++', 'icpc') {
-       next if system "$compiler -v > /dev/null 2>&1";
+my @compilers = $#ARGV >= 0 ? @ARGV : qw(g++ clang++ icpc);
+foreach my $compiler (@compilers) {
+       if (system "$compiler -v > /dev/null 2>&1") {
+               say "Skipping $compiler as it is not installed on this system!";
+               next;
+       }
        $ENV{CXX} = $compiler;
-       my @socketengines = ( 'select' );
+       my @socketengines = qw(select);
        push @socketengines, 'epoll' if test_header $compiler, 'sys/epoll.h';
        push @socketengines, 'kqueue' if test_file $compiler, 'kqueue.cpp';
        push @socketengines, 'poll' if test_header $compiler, 'poll.h';
-       push @socketengines, 'ports' if test_header $compiler, 'ports.h';
        foreach my $socketengine (@socketengines) {
-               print "Attempting to build using the $compiler compiler and the $socketengine socket engine...\n";
-               if (system './configure', '--disable-interactive', "--socketengine=$socketengine") {
-                       print "Failed to configure using the $compiler compiler and the $socketengine socket engine!\n";
-                       exit 1;
-               }
-               $ENV{PURE_STATIC} = 1;
-               if (system 'make', '-j'.get_cpu_count, 'install') {
-                       print "Failed to compile with static modules using the $compiler compiler and the $socketengine socket engine!\n";
+               say "Attempting to build using the $compiler compiler and the $socketengine socket engine...";
+               system './configure', '--enable-extras', $ENV{TEST_BUILD_MODULES} if defined $ENV{TEST_BUILD_MODULES};
+               if (system './configure', '--development', '--socketengine', $socketengine) {
+                       say "Failed to configure using the $compiler compiler and the $socketengine socket engine!";
                        exit 1;
                }
-               delete $ENV{PURE_STATIC};
-               if (system 'make', '-j'.get_cpu_count, 'install') {
-                       print "Failed to compile with dynamic modules using the $compiler compiler and the $socketengine socket engine!\n";
+               if (system 'make', '--jobs', get_cpu_count, 'install') {
+                       say "Failed to compile using the $compiler compiler and the $socketengine socket engine!";
                        exit 1;
                }
-               print "Building using the $compiler compiler and the $socketengine socket engine succeeded!\n";
+               say "Building using the $compiler compiler and the $socketengine socket engine succeeded!";
        }
 
        system 'git', 'clean', '-dfx';