Replaced polling loop for LCR and chan_lcr with select based event loop.
[lcr.git] / main.h
diff --git a/main.h b/main.h
index c0a479a..9b750e1 100644 (file)
--- a/main.h
+++ b/main.h
 #include <sys/file.h>
 #include <sys/mman.h>
 #include <sys/resource.h>
+#include <config.h>
 
 #define NAME           "LCR"
 
 #define DEFAULT_ENDPOINT_APP EndpointAppPBX
 
-#define VERSION_STRING "0.5 (Spring 2007)"
+#define VERSION_STRING VERSION
 
 extern int memuse;
 extern int mmemuse;
@@ -47,22 +48,18 @@ extern int classuse;
 extern int fduse;
 extern int fhuse;
 
-extern pthread_mutex_t mutex_lcr; // lcr process mutex
+//extern pthread_mutex_t mutex_lcr; // lcr process mutex
 
-#ifdef SOCKET_MISDN
 extern FILE *debug_fp;
-#else
-extern int global_debug;
-#endif
 
 #define PDEBUG(mask, fmt, arg...) _printdebug(__FUNCTION__, __LINE__, mask, fmt, ## arg)
 #define PERROR(fmt, arg...) _printerror(__FUNCTION__, __LINE__, fmt, ## arg)
 #define PDEBUG_RUNTIME(mask, fmt, arg...) _printdebug(NULL, 0, mask, fmt, ## arg)
 #define PERROR_RUNTIME(fmt, arg...) _printerror(NULL, 0, fmt, ## arg)
-void _printdebug(const char *function, int line, unsigned long mask, const char *fmt, ...);
+void _printdebug(const char *function, int line, unsigned int mask, const char *fmt, ...);
 void _printerror(const char *function, int line, const char *fmt, ...);
 #define DEBUG_FUNC
-void debug(const char *function, int line, char *prefix, char *buffer);
+void debug(const char *function, int line, const char *prefix, char *buffer);
 
 #define DEBUG_CONFIG   0x0001
 #define DEBUG_MSG      0x0002
@@ -70,7 +67,8 @@ void debug(const char *function, int line, char *prefix, char *buffer);
 #define DEBUG_BCHANNEL         0x0008
 #define DEBUG_PORT     0x0100
 #define DEBUG_ISDN     0x0110
-//#define DEBUG_KNOCK  0x0140
+#define DEBUG_GSM      0x0120
+#define DEBUG_SS5      0x0140
 #define DEBUG_VBOX     0x0180
 #define DEBUG_EPOINT   0x0200
 #define DEBUG_JOIN     0x0400
@@ -125,7 +123,7 @@ void debug(const char *function, int line, char *prefix, char *buffer);
 
 #ifdef BUDETECT_DEF
  #define BUDETECT      budetect(__FILE__, __LINE__, __FUNCTION__);
- void budetect(const char *file, int line, char *function);
+ void budetect(const char *file, int line, const char *function);
 #else
  #define BUDETECT      ;
 #endif
@@ -133,14 +131,12 @@ void debug(const char *function, int line, char *prefix, char *buffer);
 #ifdef __cplusplus
 extern "C" {
 #endif
-#ifndef SOCKET_MISDN
-#include <mISDNuser/isdn_net.h>
-#include <mISDNuser/net_l3.h>
-#endif
+#include <mbuffer.h>
 #ifdef __cplusplus
 }
 #endif
 #include "macro.h"
+#include "select.h"
 #include "options.h"
 #include "interface.h"
 #include "extension.h"
@@ -148,10 +144,19 @@ extern "C" {
 #include "endpoint.h"
 #include "endpointapp.h"
 #include "apppbx.h"
+#include "callerid.h"
 #include "route.h"
 #include "port.h"
 #include "mISDN.h"
 #include "dss1.h"
+#ifdef WITH_GSM
+#include "gsm.h"
+#endif
+#ifdef WITH_SS5
+#include "ss5_encode.h"
+#include "ss5_decode.h"
+#include "ss5.h"
+#endif
 #include "vbox.h"
 #include "join.h"
 #include "joinpbx.h"
@@ -163,11 +168,7 @@ extern "C" {
 #include "socket_server.h"
 #include "trace.h"
 
-extern double now_d;
-extern time_t now;
-extern struct tm *now_tm;
-extern struct timeval now_tv;
-extern struct timezone now_tz;
+extern int quit;
 
 #define DIRECTION_NONE 0
 #define DIRECTION_OUT  1