]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/inspircd.cpp
Allow Channel::WriteNotice send to other servers and status ranks.
[user/henk/code/inspircd.git] / src / inspircd.cpp
index 09e48ea1fa2840e1a2a77d4a32646ea9b9d056ca..f35482f618a975d48373385b31f4cf5edd8fde73 100644 (file)
@@ -30,7 +30,6 @@
 #include <signal.h>
 
 #ifndef _WIN32
-       #include <dirent.h>
        #include <unistd.h>
        #include <sys/resource.h>
        #include <dlfcn.h>
@@ -47,7 +46,6 @@
 #include <iostream>
 #include "xline.h"
 #include "exitcodes.h"
-#include "testsuite.h"
 
 InspIRCd* ServerInstance = NULL;
 
@@ -78,13 +76,6 @@ const char* ExitCodes[] =
                "Received SIGTERM"                                              // 10
 };
 
-#ifdef INSPIRCD_ENABLE_TESTSUITE
-/** True if we have been told to run the testsuite from the commandline,
- * rather than entering the mainloop.
- */
-static int do_testsuite = 0;
-#endif
-
 template<typename T> static void DeleteZero(T*&n)
 {
        T* t = n;
@@ -102,6 +93,15 @@ void InspIRCd::Cleanup()
        }
        ports.clear();
 
+       // Tell modules that we're shutting down.
+       const std::string quitmsg = "Server shutting down";
+       FOREACH_MOD(OnShutdown, (quitmsg));
+
+       // Disconnect all local users
+       const UserManager::LocalList& list = Users.GetLocalUsers();
+       while (!list.empty())
+               ServerInstance->Users.QuitUser(list.front(), quitmsg);
+
        GlobalCulls.Apply();
        Modules->UnloadAll();
 
@@ -123,10 +123,11 @@ void InspIRCd::SetSignals()
 {
 #ifndef _WIN32
        signal(SIGALRM, SIG_IGN);
+       signal(SIGCHLD, SIG_IGN);
        signal(SIGHUP, InspIRCd::SetSignal);
        signal(SIGPIPE, SIG_IGN);
-       signal(SIGCHLD, SIG_IGN);
-       /* We want E2BIG not a signal! */
+       signal(SIGUSR1, SIG_IGN);
+       signal(SIGUSR2, SIG_IGN);
        signal(SIGXFSZ, SIG_IGN);
 #endif
        signal(SIGTERM, InspIRCd::SetSignal);
@@ -192,9 +193,7 @@ void InspIRCd::WritePID(const std::string& filename, bool exitonfail)
                return;
        }
 
-       std::string fname(filename);
-       if (fname.empty())
-               fname = ServerInstance->Config->Paths.PrependData("inspircd.pid");
+       std::string fname = ServerInstance->Config->Paths.PrependData(filename.empty() ? "inspircd.pid" : filename);
        std::ofstream outfile(fname.c_str());
        if (outfile.is_open())
        {
@@ -290,9 +289,6 @@ InspIRCd::InspIRCd(int argc, char** argv) :
                { "nopid",      no_argument,            &do_nopid,      1       },
                { "runasroot",  no_argument,            &do_root,       1       },
                { "version",    no_argument,            &do_version,    1       },
-#ifdef INSPIRCD_ENABLE_TESTSUITE
-               { "testsuite",  no_argument,            &do_testsuite,  1       },
-#endif
                { 0, 0, 0, 0 }
        };
 
@@ -330,11 +326,6 @@ InspIRCd::InspIRCd(int argc, char** argv) :
                }
        }
 
-#ifdef INSPIRCD_ENABLE_TESTSUITE
-       if (do_testsuite)
-               do_nofork = do_debug = true;
-#endif
-
        if (do_version)
        {
                std::cout << std::endl << INSPIRCD_VERSION << std::endl;
@@ -585,16 +576,6 @@ void InspIRCd::UpdateTime()
 
 void InspIRCd::Run()
 {
-#ifdef INSPIRCD_ENABLE_TESTSUITE
-       /* See if we're supposed to be running the test suite rather than entering the mainloop */
-       if (do_testsuite)
-       {
-               TestSuite* ts = new TestSuite;
-               delete ts;
-               return;
-       }
-#endif
-
        UpdateTime();
        time_t OLDTIME = TIME.tv_sec;