/* $Id$ */
+
+/*
+ * Uncomment this #define if you are a Citadel developer tracking
+ * down memory leaks in the server. Do NOT do this on a production
+ * system because it definitely incurs a lot of additional overhead.
+ */
+/* #define DEBUG_MEMORY_LEAKS */
+
+
#include <pthread.h>
#include "sysdep.h"
#include "server.h"
/* Unimportant progress messages, etc. */
CTDL_INFO, /* informational */
/* Debugging messages */
- CTDL_DEBUG, /* debug-level messages */
+ CTDL_DEBUG /* debug-level messages */
};
#ifdef __GNUC__
void init_sysdep (void);
void begin_critical_section (int which_one);
void end_critical_section (int which_one);
-int ig_tcp_server (int port_number, int queue_len);
+int ig_tcp_server (char *ip_addr, int port_number, int queue_len);
int ig_uds_server(char *sockpath, int queue_len);
-INLINE struct CitContext *MyContext (void);
+struct CitContext *MyContext (void);
struct CitContext *CreateNewContext (void);
void InitMyContext (struct CitContext *con);
void buffer_output(void);
void unbuffer_output(void);
+void flush_output(void);
void client_write (char *buf, int nbytes);
int client_read_to (char *buf, int bytes, int timeout);
int client_read (char *buf, int bytes);
extern volatile int time_to_die;
extern int verbosity;
extern int rescan[];
-extern pthread_t initial_thread;
extern struct worker_node {
pthread_t tid;
extern int SyslogFacility(char *name);
extern int syslog_facility;
+
+#ifdef DEBUG_MEMORY_LEAKS
+#define malloc(x) tracked_malloc(x, __FILE__, __LINE__)
+#define realloc(x,y) tracked_realloc(x, y, __FILE__, __LINE__)
+#undef strdup
+#define strdup(x) tracked_strdup(x, __FILE__, __LINE__)
+#define free(x) tracked_free(x)
+void *tracked_malloc(size_t size, char *file, int line);
+void *tracked_realloc(void *ptr, size_t size, char *file, int line);
+void tracked_free(void *ptr);
+char *tracked_strdup(const char *s, char *file, int line);
+void dump_heap(void);
+#endif