changed Makefile; build all commands as an own file
[NeonServV5.git] / main.c
diff --git a/main.c b/main.c
index 2a9a4d9bc5aad3d893c0cacbfb0cb918307d088a..2fcc3dbec18349f0feae58657adb0cb8422dc1d1 100644 (file)
--- a/main.c
+++ b/main.c
@@ -6,43 +6,60 @@
 #include "IRCEvents.h"
 #include "IRCParser.h"
 #include "modcmd.h"
+#include "WHOHandler.h"
+#include "bots.h"
+#include "mysqlConn.h"
+#include "HandleInfoHandler.h"
+#include "lang.h"
+#include "tools.h"
+#include "timeq.h"
+#include "EventLogger.h"
+#include "ModeNode.h"
 
-void just_test_it() {
-    struct UserNode *user;
-    struct ClientSocket *client;
-    
-    user = addUser("TestBot");
-    strcpy(user->ident, "test");
-    strcpy(user->realname, "testUser!");
-    user->flags |= USERFLAG_ISBOT;
-    client = create_socket("127.0.0.1", 6667, "pktest:pktest123", user); //pktest Hostmask(s): *@127.0.0.1
-    client->flags |= SOCKET_FLAG_PREFERRED;
-    connect_socket(client);
-    
-    user = addUser("TestBot2");
-    strcpy(user->ident, "test");
-    strcpy(user->realname, "testUser!");
-    user->flags |= USERFLAG_ISBOT;
-    client = create_socket("127.0.0.1", 6667, "pktest:pktest123", user); //pktest Hostmask(s): *@127.0.0.1
-    connect_socket(client);
+time_t start_time;
+
+void cleanup() {
+    free_sockets();
+    free_parser();
+    free_UserNode();
+    free_ChanNode();
+    free_bind();
+    free_modcmd();
+    free_whoqueue();
+    free_bots();
+    free_mysql();
+    free_handleinfohandler();
+    free_lang();
 }
 
 int main(void)
 {
-    parser_init();
+    start_time = time(0);
+    
+    init_mysql();
+    init_lang();
+    init_parser();
     init_UserNode();
     init_ChanNode();
+    init_ModeNode();
     init_bind();
        init_modcmd();
-    just_test_it();
+    init_handleinfohandler();
+    init_tools();
+    init_bots();
+    
+    load_languages();
     
     time_t socket_wait;
     while(1) {
         socket_wait = time(0) + SOCKET_SELECT_TIME;
         do {
             socket_loop(SOCKET_SELECT_TIME);
-        } while(time(0) > socket_wait);
+        } while(time(0) < socket_wait);
+        timeq_tick();
+        loop_bots();
         clearTempUsers();
+        destroyEvents();
     }
 }