X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=src%2Fmain.h;h=329f391ad4f8c0120c0aed51f8a70f9c0c8de80b;hb=db9df7a1356859ffb8dcca001317940c92a80045;hp=b4cf00f26cd7893c2082d9c9f8056cb509ecfe16;hpb=003f6906aeb911cce26ee25b48a818d0d1c4aea5;p=NeonServV5.git diff --git a/src/main.h b/src/main.h index b4cf00f..329f391 100644 --- a/src/main.h +++ b/src/main.h @@ -1,5 +1,5 @@ -/* main.h - NeonServ v5.2 - * Copyright (C) 2011 Philipp Kreil (pk910) +/* main.h - NeonServ v5.3 + * Copyright (C) 2011-2012 Philipp Kreil (pk910) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -18,12 +18,8 @@ #define _main_h #include "../config.h" -#define NEONSERV_VERSION "5.2" -#define VERSION_PATCHLEVEL 414 - -#ifndef BOTWAR_ALERT_CHAN -#define BOTWAR_ALERT_CHAN NULL -#endif +#define NEONSERV_VERSION "5.3" +#define VERSION_PATCHLEVEL 543 #include #include @@ -32,10 +28,13 @@ #ifdef WIN32 #include #include +#include #else +#include #include #include #include +#include #include #include #include @@ -44,6 +43,33 @@ #include #include #include +#ifdef HAVE_THREADS +#include +#ifdef WIN32 +#define pthread_self_tid() pthread_self().p +#else +#define pthread_self_tid() pthread_self() +#endif +#define THREAD_MUTEX_INIT(var) { \ + pthread_mutexattr_t mutex_attr; \ + pthread_mutexattr_init(&mutex_attr);\ + pthread_mutexattr_settype(&mutex_attr, PTHREAD_MUTEX_RECURSIVE_NP);\ + pthread_mutex_init(&var, &mutex_attr); \ +} +#define THREAD_MUTEX_INIT_TYPE(var, type) { \ + pthread_mutexattr_t mutex_attr; \ + pthread_mutexattr_init(&mutex_attr);\ + pthread_mutexattr_settype(&mutex_attr, type);\ + pthread_mutex_init(&var, &mutex_attr); \ +} +#define SYNCHRONIZE(var) pthread_mutex_lock(&var) +#define SET_SYNCHRONIZE(var) pthread_mutex_trylock(&var) +#define DESYNCHRONIZE(var) pthread_mutex_unlock(&var) +#else +#define THREAD_MUTEX_INIT(var) +#define SYNCHRONIZE(var) +#define DESYNCHRONIZE(var) +#endif #if __GNUC__ #define PRINTF_LIKE(M,N) __attribute__((format (printf, M, N))) @@ -94,6 +120,7 @@ #define BOTWAR_DETECTION_TIME 7 #define BOTWAR_DETECTION_EVENTS 6 #define REWHO_TIMEOUT 10 /* wait 10 seconds before WHO an unauthed user again */ +#define TICKS_PER_SECOND 10 //valid nick chars #define VALID_NICK_CHARS "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890{|}~[\\]^-_`" @@ -105,13 +132,24 @@ #define TEMPUSER_LIST_INDEX VALID_NICK_CHARS_FIRST_LEN +#define timeval_is_bigger(x,y) ((x.tv_sec > y.tv_sec) || (x.tv_sec == y.tv_sec && x.tv_usec > y.tv_usec)) + extern time_t start_time; extern int statistics_enabled; +#ifdef HAVE_THREADS +extern int running_threads; +extern pthread_mutex_t cache_sync; +extern pthread_mutex_t whohandler_sync, whohandler_mass_sync; + +int getCurrentThreadID(); +#endif int stricmp (const char *s1, const char *s2); int stricmplen (const char *s1, const char *s2, int len); -void restart_bot(int hard_restart); +void restart_process(); +void cleanup(); +void restart_bot(int do_hard_restart); void stop_bot(); void reload_config();