--- lbbs/src/fork.c 2025/04/28 03:30:59 1.12 +++ lbbs/src/fork.c 2025/06/01 03:07:42 1.22 @@ -1,37 +1,51 @@ /*************************************************************************** fork.c - description ------------------- - begin : Mon Oct 18 2004 - copyright : (C) 2004 by Leaflet - email : leaflet@leafok.com + 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 "menu.h" +#include #include +#include +#include +#include +#include int fork_server() { int pid; - if (pid = fork()) + pid = fork(); + + if (pid > 0) // Parent process { SYS_child_process_count++; log_std("Child process (%d) start\n", pid); - return 0; + return pid; } - else if (pid < 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"); @@ -39,38 +53,41 @@ int fork_server() } // Redirect Input - close(0); - if (dup2(socket_client, 0) == -1) + close(STDIN_FILENO); + if (dup2(socket_client, STDIN_FILENO) == -1) { log_error("Redirect stdin to client socket failed\n"); return -3; } // Redirect Output - close(1); - if (dup2(socket_client, 1) == -1) + close(STDOUT_FILENO); + if (dup2(socket_client, STDOUT_FILENO) == -1) { log_error("Redirect stdout to client socket failed\n"); return -4; } + SYS_child_process_count = 0; + bbs_main(); + // Child process exit + SYS_server_exit = 1; + if (close(socket_client) == -1) { log_error("Close client socket failed\n"); } // Close Input and Output for client - close(0); - close(1); + close(STDIN_FILENO); + close(STDOUT_FILENO); log_std("Process exit normally\n"); - log_end(); - // Exit child process normally - exit(0); - + _exit(0); + return 0; }