--- lbbs/src/fork.c 2004/10/18 11:34:15 1.3 +++ lbbs/src/fork.c 2025/04/28 03:30:59 1.12 @@ -1,9 +1,9 @@ /*************************************************************************** - fork.c - description - ------------------- - begin : Mon Oct 18 2004 - copyright : (C) 2004 by Leaflet - email : leaflet@leafok.com + fork.c - description + ------------------- + begin : Mon Oct 18 2004 + copyright : (C) 2004 by Leaflet + email : leaflet@leafok.com ***************************************************************************/ /*************************************************************************** @@ -16,40 +16,61 @@ ***************************************************************************/ #include "common.h" +#include "io.h" +#include -int -fork_server(int sock_server, int sock_client, struct sockaddr * p_sin) +int 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_error("Close server socket failed\n"); - } - - bbs_main(); - - if (close(sock_client) == -1) - { - log_error("Close client socket failed\n"); - } - - sprintf(temp, "Child process [%d] exit\n", getpid()); - log_std (temp); + int pid; - log_end(); + if (pid = fork()) + { + SYS_child_process_count++; + log_std("Child process (%d) start\n", pid); + return 0; + } + else if (pid < 0) + return -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("Redirect stdin to client socket failed\n"); + return -3; + } + + // Redirect Output + close(1); + if (dup2(socket_client, 1) == -1) + { + 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"); + } + + // Close Input and Output for client + close(0); + close(1); - //Exit child process normally - exit(0); + log_std("Process exit normally\n"); - return 0; + log_end(); + + // Exit child process normally + exit(0); + + return 0; }