--- lbbs/src/fork.c 2004/10/19 02:12:28 1.5 +++ lbbs/src/fork.c 2005/03/20 17:37:14 1.10 @@ -16,41 +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; - + if (pid = fork ()) return 0; else if (pid < 0) return -1; log_std ("Child process start\n"); - - if (close(sock_server) == -1) + + 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; + } + + bbs_main (); + + if (close (socket_client) == -1) + { + log_error ("Close client socket failed\n"); } log_std ("Child process exit\n"); - log_end(); + //Close Input and Output for client + close (0); + close (1); + + log_end (); //Exit child process normally - exit(0); + exit (0); return 0; }