SIP: Fix incoming re-invite
[lcr.git] / main.h
diff --git a/main.h b/main.h
index 427b39c..17ea68c 100644 (file)
--- a/main.h
+++ b/main.h
@@ -11,6 +11,7 @@
 
 #include <stdio.h>
 #include <stdlib.h>
+#include <stdint.h>
 #include <stdarg.h>
 #include <unistd.h>
 #include <string.h>
 #include <sys/file.h>
 #include <sys/mman.h>
 #include <sys/resource.h>
-#include <config.h>
+#include <sys/socket.h>
+#include <sys/un.h>
 
 #define NAME           "LCR"
 
-#define DEFAULT_ENDPOINT_APP EndpointAppPBX
-
 #define VERSION_STRING VERSION
 
 extern int memuse;
@@ -52,14 +52,14 @@ extern int fhuse;
 
 extern FILE *debug_fp;
 
-#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 int mask, const char *fmt, ...);
-void _printerror(const char *function, int line, const char *fmt, ...);
+#define PDEBUG(mask, fmt, arg...) _printdebug(__FILE__, __FUNCTION__, __LINE__, mask, fmt, ## arg)
+#define PERROR(fmt, arg...) _printerror(__FILE__, __FUNCTION__, __LINE__, fmt, ## arg)
+#define PDEBUG_RUNTIME(mask, fmt, arg...) _printdebug(NULL, NULL, 0, mask, fmt, ## arg)
+#define PERROR_RUNTIME(fmt, arg...) _printerror(NULL, NULL, 0, fmt, ## arg)
+void _printdebug(const char *file, const char *function, int line, unsigned int mask, const char *fmt, ...);
+void _printerror(const char *file, const char *function, int line, const char *fmt, ...);
 #define DEBUG_FUNC
-void debug(const char *function, int line, const char *prefix, char *buffer);
+void debug(const char *file, const char *function, int line, const char *prefix, char *buffer);
 
 #define DEBUG_CONFIG   0x0001
 #define DEBUG_MSG      0x0002
@@ -67,15 +67,16 @@ void debug(const char *function, int line, const 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_SIP      0x10100
 #define DEBUG_EPOINT   0x0200
 #define DEBUG_JOIN     0x0400
 #define DEBUG_VERSATEL         0x0800
 #define DEBUG_CRYPT    0x1000
 #define DEBUG_ROUTE    0x2000
 #define DEBUG_IDLETIME 0x4000
-#define DEBUG_LOG      0x7fff
 
 // check any faulty malloc
 #define MALLOC_CHECK_  1
@@ -83,15 +84,12 @@ void debug(const char *function, int line, const char *prefix, char *buffer);
 /*
  * one of the bits must be enabled in order to write log files
  */
-#define DEBUG_LOG      0x7fff
+#define DEBUG_LOG      0xfffff
 
 /*
  * load transmit buffer to avoid gaps at the beginning due to jitter
- * also the maximum load that will be kept in tx-buffer
- * also the (minimum) number of data to transmit in a frame
  */
 #define ISDN_LOAD      1024 // samples
-#define ISDN_MAXLOAD   2048 // samples
 
 /* give sendmail program. if not inside $PATH, give absolute path here (e.g. "/usr/sbin/sendmail")
  */
@@ -120,6 +118,8 @@ void debug(const char *function, int line, const char *prefix, char *buffer);
  */
 //#define BUDETECT_DEF
 
+/* internal limit of payload type in a message */
+
 #ifdef BUDETECT_DEF
  #define BUDETECT      budetect(__FILE__, __LINE__, __FUNCTION__);
  void budetect(const char *file, int line, const char *function);
@@ -127,14 +127,17 @@ void debug(const char *function, int line, const char *prefix, char *buffer);
  #define BUDETECT      ;
 #endif
 
-#ifdef __cplusplus
-extern "C" {
-#endif
-#include <mbuffer.h>
-#ifdef __cplusplus
-}
+#ifdef WITH_MISDN
+ #ifdef __cplusplus
+  extern "C" {
+ #endif
+ #include <mISDN/mbuffer.h>
+ #ifdef __cplusplus
+  }
+ #endif
 #endif
 #include "macro.h"
+#include "select.h"
 #include "options.h"
 #include "interface.h"
 #include "extension.h"
@@ -142,15 +145,45 @@ extern "C" {
 #include "endpoint.h"
 #include "endpointapp.h"
 #include "apppbx.h"
+#include "appbridge.h"
 #include "callerid.h"
 #include "route.h"
+#ifdef WITH_VOOTP
+ #ifdef __cplusplus
+  extern "C" {
+ #endif
+#include <vootp.h>
+ #ifdef __cplusplus
+  }
+ #endif
+#endif
 #include "port.h"
+#include "remote.h"
+#ifdef WITH_MISDN
 #include "mISDN.h"
 #include "dss1.h"
+#include "fxs.h"
+#endif
+#if defined WITH_GSM_BS || defined WITH_GSM_MS
+#include "gsm.h"
+#endif
+#ifdef WITH_GSM_BS
+#include "gsm_bs.h"
+#endif
+#ifdef WITH_GSM_MS
+#include "gsm_ms.h"
+#endif
+#ifdef WITH_SS5
+#include "ss5_encode.h"
+#include "ss5_decode.h"
+#include "ss5.h"
+#endif
+#ifdef WITH_SIP
+#include "sip.h"
+#endif
 #include "vbox.h"
 #include "join.h"
 #include "joinpbx.h"
-#include "joinremote.h"
 #include "cause.h"
 #include "alawulaw.h"
 #include "tones.h"
@@ -158,11 +191,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