--- lbbs/src/fork.c 2004/10/19 02:08:35 1.4 +++ lbbs/src/fork.c 2004/10/21 17:28:46 1.6 @@ -21,25 +21,32 @@ int fork_server(int sock_server, int sock_client, struct sockaddr_in * p_sin) { int pid; - char temp[256]; if (pid = fork ()) return 0; else if (pid < 0) return -1; - sprintf(temp, "Child process [%d] start\n", getpid()); - log_std (temp); + log_std ("Child process start\n"); if (close(sock_server) == -1) { log_error("Close server socket failed\n"); + return -2; } socket_client = sock_client; - strcpy(hostaddr_client,inet_ntoa(p_sin->sin_addr)); + strcpy(hostaddr_client,(const char *)inet_ntoa(p_sin->sin_addr)); port_client = ntohs(p_sin->sin_port); + //Redirect Output + close(1); + if (dup2 (socket_client, 1) == -1) + { + log_error("Redirect stdout to client socket failed\n"); + return -3; + } + bbs_main(); if (close(sock_client) == -1) @@ -47,8 +54,7 @@ fork_server(int sock_server, int sock_cl log_error("Close client socket failed\n"); } - sprintf(temp, "Child process [%d] exit\n", getpid()); - log_std (temp); + log_std ("Child process exit\n"); log_end();