# I HATE PERL.. kthxbye
# ---------------------------------------------------
-my $conffile = "@CONFIG_DIR@/inspircd.conf";
+my $confpath = "@CONFIG_DIR@/";
my $binpath = "@BINARY_DIR@";
my $libpath = "@LIBRARY_DIR@";
-
-$ENV{"LD_LIBRARY_PATH"} = $ENV{"LD_LIBRARY_PATH"} . ":/usr/local/lib/mysql:/usr/lib/mysql:$libpath";
+my $executable = "@EXECUTABLE@";
+my @filesparsed;
# Lets see what they want to do.. Set the variable (Cause i'm a lazy coder)
my $arg = $ARGV[0];
-getpidfile();
+getpidfile($confpath."inspircd.conf");
if ($arg eq "start") { start(); exit(); }
if ($arg eq "debug") { debug(); exit(); }
+if ($arg eq "screendebug") { screendebug(); exit() }
+if ($arg eq "valdebug") { valdebug(); exit(); }
+if ($arg eq "screenvaldebug") { screenvaldebug(); exit(); }
if ($arg eq "stop") { stop(); exit(); }
if ($arg eq "status") {
if (getstatus() == 1) {
if ($arg eq "restart") {
stop();
+ unlink($pidfile) if (-e $pidfile);
start();
# kthxbye();
exit();
# Check to see its not 'running' already.
if (getstatus() == 1) { print "InspIRCd is already running.\n"; return 0; }
# If we are still alive here.. Try starting the IRCd..
- system("$binpath/inspircd");
- sleep 1;
- if (getstatus() == 0) {
- print "InspIRCd Seemingly not started, Log follows:\n";
- system("tail $binpath/ircd.log");
- } else {
- # We're good!
- return 1;
- }
+ system("$binpath/$executable");
+ return 1;
}
sub debug {
- # Check to see its not 'running' already.
- if (getstatus() == 1) { print "InspIRCd is already running.\n"; return 0; }
- # If we are still alive here.. Try starting the IRCd..
- system("gdb --args $binpath/inspircd -nofork -debug");
+ # Check to see its not 'running' already.
+ if (getstatus() == 1) { print "InspIRCd is already running.\n"; return 0; }
+
+ # Check we have gdb
+ checkgdb();
+
+ # If we are still alive here.. Try starting the IRCd..
+ system("gdb --command=.gdbargs --args $binpath/$executable -nofork -debug -nolog");
}
+sub screendebug
+{
+ # Check to see its not 'running' already.
+ if (getstatus() == 1) { print "InspIRCd is already running.\n"; return 0; }
+
+ #Check we have gdb
+ checkgdb();
+ checkscreen();
+
+ # If we are still alive here.. Try starting the IRCd..
+ print "Starting InspIRCd in `screen`, type `screen -r` when the ircd crashes to view the gdb output and get a backtrace.\n";
+ print "Once you're inside the screen session press ^C + d to re-detach from the session\n";
+ system("screen -m -d gdb --command=.gdbargs --args $binpath/$executable -nofork -debug -nolog");
+}
+
+sub valdebug
+{
+ # Check to see its not 'running' already.
+ if (getstatus() == 1) { print "InspIRCd is already running.\n"; return 0; }
+
+ # Check we have valgrind and gdb
+ checkvalgrind();
+ checkgdb();
+
+ # If we are still alive here.. Try starting the IRCd..
+ # May want to do something with these args at some point: --suppressions=.inspircd.sup --gen-suppressions=yes
+ # Could be useful when we want to stop it complaining about things we're sure aren't issues.
+ system("valgrind -v --tool=memcheck --leak-check=yes --db-attach=yes --num-callers=10 $binpath/$executable -nofork -debug -nolog");
+}
+
+sub screenvaldebug
+{
+ # Check to see its not 'running' already.
+ if (getstatus() == 1) { print "InspIRCd is already running.\n"; return 0; }
+
+ #Check we have gdb
+ checkvalgrind();
+ checkgdb();
+ checkscreen();
+
+ # If we are still alive here.. Try starting the IRCd..
+ print "Starting InspIRCd in `screen`, type `screen -r` when the ircd crashes to view the valgrind and gdb output and get a backtrace.\n";
+ print "Once you're inside the screen session press ^C + d to re-detach from the session\n";
+ system("screen -m -d valgrind -v --tool=memcheck --leak-check=yes --db-attach=yes --num-callers=10 $binpath/$executable -nofork -debug -nolog");
+}
sub stop {
if (getstatus() == 0) { print "InspIRCd is not running. (Or PID File not found)\n"; return 0; }
my $pid = getprocessid();
print "Stopping InspIRCd...\n";
system("kill -TERM $pid >/dev/null 2>&1");
- sleep 2;
if (getstatus() == 1)
{
print "InspIRCd not dying Quietly -- Forcing Kill\n";
print "InspIRCd Stopped.\n";
}
+# GetPidfile Version 2 - Now With Include Support..
+# I beg for months for include support in insp, then..
+# when it is added, it comes around and BITES ME IN THE ASS,
+# because i then have to code support into this script.. Evil.
sub getpidfile {
- open INFILE, "< $conffile" or die "Couldn't open $conffile\n";
- my(@lines) = <INFILE>;
- close INFILE;
- chomp(@lines);
+ my ($file) = @_;
+ # Before we start, do we have a PID already? (Should never occur)
+ if ($pid ne "") {
+ return;
+ }
+ # Are We using a relative path?
+ if ($file !~ /^\//) {
+ # Convert it to a full path..
+ $file = $confpath . $file;
+ }
- foreach $i (@lines) {
- $i =~ s/[^=]+=\s(.*)/\1/;
- }
+ # Have we checked this file before?
+ for (my $i = 0; $i < $filesparsed; $i++) {
+ if ($filesparsed[$i] eq $file) {
+ # Already Parsed, Possible recursive loop..
+ return;
+ }
+ }
+
+ # If we get here, Mark as 'Read'
+ $filesparsed[$filesparsed] = $file;
+
+ # Open the File..
+ open INFILE, "< $file" or die "Unable to Open file $file\n";
+ # Grab entire file contents..
+ my(@lines) = <INFILE>;
+ # Close the file
+ close INFILE;
+
+ # Clean up the file, no newlines etc..
+ chomp(@lines);
+ foreach $i (@lines) {
+ $i =~ s/[^=]+=\s(.*)/\1/;
+ }
+ my $tmp = join("",@lines);
- my $tmp = join("",@lines);
- $tmp =~ /<pid file=\"(\S+)\">/i;
+ # Does this file have a pid?
+ if ($tmp =~ /<pid file=\"(\S+)\">/i) {
+ # Set the PID file and return.
+ $pidfile = $1;
+ return;
+ }
- $pidfile = $1;
+ # If we get here, NO PID FILE! -- Check for includes (Seeing as we will eventually return,
+ # The while (1) is safe.)
+ while (1) {
+ if ($tmp =~ s/\<include file=\"(.+?)\"\>//i)
+ {
+ # Decend into that file, and check for PIDs.. (that sounds like an STD ;/)
+ getpidfile($1);
+ # Was a PID found?
+ if ($pidfile ne "") {
+ # Yes, Return.
+ return;
+ }
+ } else {
+ # End of includes / No includes found.
+ return;
+ }
+ }
}
sub getstatus {
close PIDFILE;
return $pid;
}
+
+sub checkvalgrind
+{
+ unless(`valgrind --version`)
+ {
+ print "Couldn't start valgrind: $!\n";
+ exit;
+ }
+}
+
+sub checkgdb
+{
+ unless(`gdb --version`)
+ {
+ print "Couldn't start gdb: $!\n";
+ exit;
+ }
+}
+
+sub checkscreen
+{
+ unless(`screen --version`)
+ {
+ print "Couldn't start screen: $!\n";
+ exit;
+ }
+}