--- lbbs/src/fork.c 2004/10/21 17:28:46 1.6 +++ lbbs/src/fork.c 2005/03/20 17:37:14 1.10 @@ -16,50 +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"); + log_error ("Close server socket failed\n"); return -2; } - - socket_client = sock_client; - strcpy(hostaddr_client,(const char *)inet_ntoa(p_sin->sin_addr)); - port_client = ntohs(p_sin->sin_port); + + //Redirect Input + close (0); + if (dup2 (socket_client, 0) == -1) + { + log_error ("Redirect stdin to client socket failed\n"); + return -3; + } //Redirect Output - close(1); + close (1); if (dup2 (socket_client, 1) == -1) { - log_error("Redirect stdout to client socket failed\n"); - return -3; + log_error ("Redirect stdout to client socket failed\n"); + return -4; } - bbs_main(); - - if (close(sock_client) == -1) + bbs_main (); + + if (close (socket_client) == -1) { - log_error("Close client socket failed\n"); + 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; }