diff options
Diffstat (limited to 'common/os_calls.c')
-rw-r--r-- | common/os_calls.c | 48 |
1 files changed, 37 insertions, 11 deletions
diff --git a/common/os_calls.c b/common/os_calls.c index 6d6acaef..e236088c 100644 --- a/common/os_calls.c +++ b/common/os_calls.c @@ -38,6 +38,7 @@ #include <dlfcn.h> #include <arpa/inet.h> #include <netdb.h> +#include <signal.h> #endif #include <stdlib.h> #include <string.h> @@ -68,6 +69,10 @@ static int g_memid = 0; static struct xrdp_list* g_memlist = 0; #endif +/* forward declarations */ +void g_printf(char* format, ...); +void pipe_sig(int sig_num); + /*****************************************************************************/ int g_init_system(void) { @@ -76,13 +81,15 @@ int g_init_system(void) WSAStartup(2, &w); InitializeCriticalSection(&g_term_mutex); +#else + signal(SIGPIPE, pipe_sig); #endif #ifdef MEMLEAK g_memlist = xrdp_list_create(); - printf("some info\n\r"); - printf("sizeof xrdp_bitmap is %d\n\r", sizeof(struct xrdp_bitmap)); - printf("sizeof xrdp_wm is %d\n\r", sizeof(struct xrdp_wm)); - printf("sizeof stream is %d\n\r", sizeof(struct stream)); + g_printf("some info\n\r"); + g_printf("sizeof xrdp_bitmap is %d\n\r", sizeof(struct xrdp_bitmap)); + g_printf("sizeof xrdp_wm is %d\n\r", sizeof(struct xrdp_wm)); + g_printf("sizeof stream is %d\n\r", sizeof(struct stream)); #endif return 0; } @@ -225,7 +232,7 @@ void g_hexdump(char* p, int len) offset = 0; while (offset < len) { - printf("%04x ", offset); + g_printf("%04x ", offset); thisline = len - offset; if (thisline > 16) { @@ -233,17 +240,17 @@ void g_hexdump(char* p, int len) } for (i = 0; i < thisline; i++) { - printf("%02x ", line[i]); + g_printf("%02x ", line[i]); } for (; i < 16; i++) { - printf(" "); + g_printf(" "); } for (i = 0; i < thisline; i++) { - printf("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); + g_printf("%c", (line[i] >= 0x20 && line[i] < 0x7f) ? line[i] : '.'); } - printf("\n\r"); + g_printf("\n\r"); offset += thisline; line += thisline; } @@ -509,8 +516,14 @@ int g_tcp_select(int sck1, int sck2) time.tv_sec = 0; time.tv_usec = 0; FD_ZERO(&rfds); - FD_SET(((unsigned int)sck1), &rfds); - FD_SET(((unsigned int)sck2), &rfds); + if (sck1 > 0) + { + FD_SET(((unsigned int)sck1), &rfds); + } + if (sck2 > 0) + { + FD_SET(((unsigned int)sck2), &rfds); + } max = sck1; if (sck2 > max) { @@ -934,3 +947,16 @@ int g_system(char* aexec) { return system(aexec); } + +/*****************************************************************************/ +void g_signal(int sig_num, void (*func)(int)) +{ + signal(sig_num, func); +} + +/*****************************************************************************/ +void pipe_sig(int sig_num) +{ + /* do nothing */ + g_printf("got SIGPIPE(%d)\n\r", sig_num); +} |