--- lbbs/src/fork.c 2004/10/18 11:34:15 1.3 +++ lbbs/src/fork.c 2025/05/12 03:54:14 1.16 @@ -1,55 +1,88 @@ /*************************************************************************** - fork.c - description - ------------------- - begin : Mon Oct 18 2004 - copyright : (C) 2004 by Leaflet - email : leaflet@leafok.com + fork.c - description + ------------------- + Copyright : (C) 2004-2025 by Leaflet + Email : leaflet@leafok.com ***************************************************************************/ /*************************************************************************** * * * This program is free software; you can redistribute it and/or modify * * it under the terms of the GNU General Public License as published by * - * the Free Software Foundation; either version 2 of the License, or * + * the Free Software Foundation; either version 3 of the License, or * * (at your option) any later version. * * * ***************************************************************************/ #include "common.h" +#include "bbs_main.h" +#include "log.h" +#include "io.h" +#include "fork.h" +#include +#include +#include +#include +#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(); + pid = fork(); - //Exit child process normally - exit(0); + if (pid > 0) // Parent process + { + SYS_child_process_count++; + log_std("Child process (%d) start\n", pid); + return 0; + } + else if (pid < 0) // Error + { + log_error("fork() error (%d)\n", errno); + return -1; + } + + // Child process + if (close(socket_server) == -1) + { + log_error("Close server socket failed\n"); + return -2; + } + + // Redirect Input + close(STDIN_FILENO); + if (dup2(socket_client, STDIN_FILENO) == -1) + { + log_error("Redirect stdin to client socket failed\n"); + return -3; + } + + // Redirect Output + close(STDOUT_FILENO); + if (dup2(socket_client, STDOUT_FILENO) == -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(STDIN_FILENO); + close(STDOUT_FILENO); - return 0; + log_std("Process exit normally\n"); + + log_end(); + + // Exit child process normally + exit(0); + + return 0; }