--- lbbs/src/fork.c 2004/10/19 02:08:35 1.4 +++ lbbs/src/fork.c 2005/03/20 17:37:14 1.10 @@ -16,44 +16,60 @@ ***************************************************************************/ #include "common.h" +#include "io.h" +#include int -fork_server(int sock_server, int sock_client, struct sockaddr_in * p_sin) +fork_server () { 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); - - if (close(sock_server) == -1) + log_std ("Child process start\n"); + + if (close (socket_server) == -1) + { + log_error ("Close server socket failed\n"); + return -2; + } + + //Redirect Input + close (0); + if (dup2 (socket_client, 0) == -1) { - log_error("Close server socket failed\n"); + log_error ("Redirect stdin to client socket failed\n"); + return -3; } - - socket_client = sock_client; - strcpy(hostaddr_client,inet_ntoa(p_sin->sin_addr)); - port_client = ntohs(p_sin->sin_port); - - bbs_main(); - - if (close(sock_client) == -1) + + //Redirect Output + close (1); + if (dup2 (socket_client, 1) == -1) { - log_error("Close client socket failed\n"); + log_error ("Redirect stdout to client socket failed\n"); + return -4; } - sprintf(temp, "Child process [%d] exit\n", getpid()); - log_std (temp); + bbs_main (); + + if (close (socket_client) == -1) + { + log_error ("Close client socket failed\n"); + } + + log_std ("Child process exit\n"); + + //Close Input and Output for client + close (0); + close (1); - log_end(); + log_end (); //Exit child process normally - exit(0); + exit (0); return 0; }