$config{MAX_AWAY} = $opt_away;
}
-$no_svn = 0;
-
$config{HAS_OPENSSL} =~ /OpenSSL ([-[:digit:].]+)([a-z])?(\-[a-z][0-9])? (\w{3}|[0-9]+) (\w{3}|[0-9]+) [0-9]{4}/;
$config{HAS_OPENSSL} = $1;
# File Descriptor Settings..
promptnumeric("number of clients at any one time", "MAX_CLIENT_T");
-
- $config{MAX_CLIENT} = $var;
- $config{MAX_DESCRIPTORS} = $var;
+ $config{MAX_CLIENT} = $config{MAX_CLIENT_T};
+ $config{MAX_DESCRIPTORS} = $config{MAX_CLIENT_T};
promptnumeric("length of nicknames", "NICK_LENGT");
promptnumeric("length of channel names", "CHAN_LENGT");
return $config{OSNAME};
}
-sub is_dir {
- my ($path) = @_;
- if (chdir($path)) {
- chdir($this);
- return 1;
- } else {
- # Just in case..
- chdir($this);
- return 0;
- }
-}
-
-sub getmodules {
- my $i = 0;
- print "Detecting modules ";
- opendir(DIRHANDLE, "src/modules");
- foreach $name (sort readdir(DIRHANDLE)) {
- if ($name =~ /^m_(.+)\.cpp$/)
- {
- $mod = $1;
- if ($mod !~ /_static$/) {
- $modlist[$i++] = $mod;
- print ".";
- }
- }
- }
- closedir(DIRHANDLE);
- print "\nOk, $i modules.\n";
-}
-
-sub getrevision {
- if ($no_svn) {
- return "0";
- }
- my $data = `svn info`;
-
- if ($data eq "") {
- $no_svn = 1;
- $rev = "0";
- return $rev;
- }
- $data =~ /Revision: (\d+)/;
- my $rev = $1;
- if (!defined($rev)) {
- $rev = "0";
- }
- return $rev;
-}
-
sub writefiles {
my($writeheader) = @_;
# First File.. inspircd_config.h
}
chomp($modules); # Remove Redundant whitespace..
+ opendir(DIRHANDLE, "src/modules");
+ foreach $name (sort readdir(DIRHANDLE)) {
+ if ($name =~ /^m_(.+?)$/) {
+ if (opendir(MDIRHANDLE, "src/modules/$name") != 0) {
+ closedir(MDIRHANDLE);
+ $modules .= "$name.so ";
+ }
+ }
+ }
+ closedir(DIRHANDLE);
+
# Write all .in files.
my $tmp = "";
}
}
-sub getcompilerflags {
- my ($file) = @_;
- open(FLAGS, $file);
- while (<FLAGS>) {
- if ($_ =~ /^\/\* \$CompileFlags: (.+) \*\/$/) {
- close(FLAGS);
- return translate_functions($1,$file);
- }
- }
- close(FLAGS);
- return undef;
-}
-
-sub getlinkerflags {
- my ($file) = @_;
- open(FLAGS, $file);
- while (<FLAGS>) {
- if ($_ =~ /^\/\* \$LinkerFlags: (.+) \*\/$/) {
- close(FLAGS);
- return translate_functions($1,$file);
- }
- }
- close(FLAGS);
- return undef;
-}
-
-sub getdependencies {
- my ($file) = @_;
- open(FLAGS, $file);
- while (<FLAGS>) {
- if ($_ =~ /^\/\* \$ModDep: (.+) \*\/$/) {
- close(FLAGS);
- return translate_functions($1,$file);
- }
- }
- close(FLAGS);
- return undef;
-}
-
-sub resolve_directory {
- use File::Spec;
- return File::Spec->rel2abs($_[0]);
-}
-
-sub yesno {
- my ($flag,$prompt) = @_;
- print "$prompt [\033[1;32m$config{$flag}\033[0m] -> ";
- chomp($tmp = <STDIN>);
- if ($tmp eq "") { $tmp = $config{$flag} }
-
- if (($tmp eq "") || ($tmp =~ /^y/i)) {
- $config{$flag} = "y";
- } else {
- $config{$flag} = "n";
- }
- return;
-}
-
sub write_static_modules_makefile {
# Modules Makefile..
print "Writing \033[1;32msrc/modules/Makefile\033[0m\n";
print "done\n";
}
}
+
print MODLIST "{0}};\n\n#endif\n";
close(MODLIST);
}
my $crud = "";
foreach $i (@modlist) {
- ###
- # Write Entry to the MakeFile
- ###
- $cmflags = getcompilerflags("src/modules/m_".$i.".cpp");
- $liflags = getlinkerflags("src/modules/m_".$i.".cpp");
- $deps = getdependencies("src/modules/m_".$i.".cpp");
-
- #print "file: $i: cmflags=$cmflags; liflags=$liflags; deps=$deps\n";
-
- print FILEHANDLE <<EOCHEESE;
+ ###
+ # Write Entry to the MakeFile
+ ###
+ $cmflags = getcompilerflags("src/modules/m_".$i.".cpp");
+ $liflags = getlinkerflags("src/modules/m_".$i.".cpp");
+ $deps = getdependencies("src/modules/m_".$i.".cpp");
+
+ #print "file: $i: cmflags=$cmflags; liflags=$liflags; deps=$deps\n";
+
+ print FILEHANDLE <<EOCHEESE;
m_$i.so: m_$i.cpp ../../include/modules.h ../../include/users.h ../../include/channels.h ../../include/base.h ../../include/inspircd_config.h ../../include/inspircd.h ../../include/configreader.h $deps
\$(CC) -pipe -I../../include \$(FLAGS) $cmflags -export-dynamic -c m_$i.cpp
\$(CC) -pipe \$(FLAGS) -shared $liflags -o m_$i.so m_$i.o $extra
EOCHEESE
- $crud = $crud . " install -m \$(INSTMODE) m_$i.so \$(MODPATH)\n";
+ $crud = $crud . " install -m \$(INSTMODE) m_$i.so \$(MODPATH)\n";
###
- # End Write Entry to the MakeFile
- ###
+ # End Write Entry to the MakeFile
+ ###
}
+
+ opendir(DIRHANDLE, "src/modules");
+ foreach $name (sort readdir(DIRHANDLE)) {
+ if ($name =~ /^m_(.+?)$/) {
+ $crapola = "";
+ $crap2 = "ar r $name.a ";
+ $crap3 = "";
+ # A module made of multiple files, in a dir, e.g. src/modules/m_spanningtree/
+ if (opendir(MDIRHANDLE, "src/modules/$name") != 0) {
+ print "Composing Makefile rules for directory \033[1;32m$name\033[0m... ";
+ my $i = 0;
+ print FILEHANDLE "$name.a: ../../include/modules.h ../../include/users.h ../../include/channels.h ../../include/base.h ../../include/inspircd_config.h ../../include/inspircd.h ../../include/configreader.h $deps";
+ foreach $fname (sort readdir(MDIRHANDLE)) {
+ if ($fname =~ /\.cpp$/) {
+ $cmflags = getcompilerflags("src/modules/$name/$fname");
+ $liflags = getlinkerflags("src/modules/$name/$fname");
+ $deps = getdependencies("src/modules/$name/$fname");
+ print FILEHANDLE " $name/$fname";
+ $crapola = $crapola . " \$(CC) -pipe -I../../include \$(FLAGS) $cmflags -export-dynamic -c $name/$fname\n";
+ $oname = $fname;
+ $oname =~ s/\.cpp$/.o/g;
+ $crap2 = $crap2 . " $oname";
+ $crap3 = $crap3 . " $name/$fname";
+ $i++;
+ }
+ }
+ print "(\033[1;32m$i files found\033[0m)\n";
+ print FILEHANDLE "\n$crapola\n";
+ print FILEHANDLE "$name.so: $name.a ../../include/modules.h ../../include/users.h ../../include/channels.h ../../include/base.h ../../include/inspircd_config.h ../../include/inspircd.h ../../include/configreader.h$crap3\n $crap2\n";
+ print FILEHANDLE " ranlib $name.a$crap3\n";
+ print FILEHANDLE " \$(CC) -pipe $liflags -shared -o $name.so $name.a\n";
+ closedir(MDIRHANDLE);
+ $crud = $crud . " install -m \$(INSTMODE) $name.so \$(MODPATH)\n";
+ }
+ }
+ }
+ closedir(DIRHANDLE);
+
print FILEHANDLE "modinst:\n \@echo \"Installing modules...\"\n" . $crud;
}
close(FH);
}
-sub showhelp
-{
- chomp($PWD = `pwd`);
- print "Usage: configure [options]
-
-*** NOTE: NON-INTERACTIVE CONFIGURE IS *NOT* SUPPORTED BY THE ***
-*** INSPIRCD DEVELOPMENT TEAM. DO NOT ASK FOR HELP REGARDING ***
-*** NON-INTERACTIVE CONFIGURE ON THE FORUMS OR ON IRC! ***
-
-Options: [defaults in brackets after descriptions]
-
-When no options are specified, interactive
-configuration is started and you must specify
-any required values manually. If one or more
-options are specified, non-interactive configuration
-is started, and any omitted values are defaulted.
-
-Arguments with a single \"-\" symbol, as in
-InspIRCd 1.0.x, are also allowed.
-
- --disable-interactive Sets no options intself, but
- will disable any interactive prompting.
- --update Update makefiles and dependencies
- --modupdate Detect new modules and write makefiles
- --svnupdate {rebuild} Update working copy via subversion
- {and optionally rebuild it}
- --clean Remove .config.cache file and go interactive
- --enable-gnutls Enable GnuTLS module [no]
- --enable-openssl Enable OpenSSL module [no]
- --with-nick-length=[n] Specify max. nick length [32]
- --with-channel-length=[n] Specify max. channel length [64]
- --with-max-channels=[n] Specify max. number of channels
- a normal user may join [20]
- --with-max-oper-channels=[n] Specify max. number of channels
- an irc operator may join [60]
- --with-max-clients=[n] Specify maximum number of users
- which may connect locally
- --enable-optimization=[n] Optimize using -O[n] gcc flag
- --enable-epoll Enable epoll() where supported [set]
- --enable-kqueue Enable kqueue() where supported [set]
- --disable-epoll Do not enable epoll(), fall back
- to select() [not set]
- --disable-kqueue Do not enable kqueue(), fall back
- to select() [not set]
- --enable-ipv6 Build ipv6 native InspIRCd [no]
- --enable-remote-ipv6 Build with ipv6 support for remote
- servers on the network [yes]
- --disable-remote-ipv6 Do not allow remote ipv6 servers [not set]
- --with-cc=[filename] Use an alternative g++ binary to
- build InspIRCd [g++]
- --with-ident-length=[n] Specify max length of ident [12]
- --with-quit-length=[n] Specify max length of quit [200]
- --with-topic-length=[n] Specify max length of topic [350]
- --with-kick-length=[n] Specify max length of kick [200]
- --with-gecos-length=[n] Specify max length of gecos [150]
- --with-away-length=[n] Specify max length of away [150]
- --with-max-modes=[n] Specify max modes per line which
- have parameters [20]
- --prefix=[directory] Base directory to install into (if defined,
- can automatically define config, module, bin
- and library dirs as subdirectories of prefix)
- [$PWD]
- --config-dir=[directory] Config file directory for config and SSL certs
- [$PWD/conf]
- --module-dir=[directory] Modules directory for loadable modules
- [$PWD/modules]
- --binary-dir=[directory] Binaries directory for core binary
- [$PWD/bin]
- --library-dir=[directory] Library directory for core libraries
- [$PWD/lib]
- --help Show this help text and exit
-
-";
- exit(0);
-}