/[LeafOK_CVS]/lbbs/src/fork.c
ViewVC logotype

Diff of /lbbs/src/fork.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.16 by sysadm, Mon May 12 03:54:14 2025 UTC Revision 1.24 by sysadm, Wed Jun 4 13:42:53 2025 UTC
# Line 19  Line 19 
19  #include "log.h"  #include "log.h"
20  #include "io.h"  #include "io.h"
21  #include "fork.h"  #include "fork.h"
22    #include "menu.h"
23  #include <stdio.h>  #include <stdio.h>
24  #include <string.h>  #include <string.h>
25    #include <signal.h>
26  #include <unistd.h>  #include <unistd.h>
27  #include <stdlib.h>  #include <stdlib.h>
28  #include <errno.h>  #include <errno.h>
29    
30  int fork_server()  int fork_server(void)
31  {  {
32          int pid;          int pid;
33    
# Line 34  int fork_server() Line 36  int fork_server()
36          if (pid > 0) // Parent process          if (pid > 0) // Parent process
37          {          {
38                  SYS_child_process_count++;                  SYS_child_process_count++;
39                  log_std("Child process (%d) start\n", pid);                  log_common("Child process (%d) start\n", pid);
40                  return 0;                  return pid;
41          }          }
42          else if (pid < 0) // Error          else if (pid < 0) // Error
43          {          {
# Line 47  int fork_server() Line 49  int fork_server()
49          if (close(socket_server) == -1)          if (close(socket_server) == -1)
50          {          {
51                  log_error("Close server socket failed\n");                  log_error("Close server socket failed\n");
                 return -2;  
52          }          }
53    
54          // Redirect Input          // Redirect Input
# Line 55  int fork_server() Line 56  int fork_server()
56          if (dup2(socket_client, STDIN_FILENO) == -1)          if (dup2(socket_client, STDIN_FILENO) == -1)
57          {          {
58                  log_error("Redirect stdin to client socket failed\n");                  log_error("Redirect stdin to client socket failed\n");
59                  return -3;                  goto cleanup;
60          }          }
61    
62          // Redirect Output          // Redirect Output
# Line 63  int fork_server() Line 64  int fork_server()
64          if (dup2(socket_client, STDOUT_FILENO) == -1)          if (dup2(socket_client, STDOUT_FILENO) == -1)
65          {          {
66                  log_error("Redirect stdout to client socket failed\n");                  log_error("Redirect stdout to client socket failed\n");
67                  return -4;                  goto cleanup;
68          }          }
69    
70            SYS_child_process_count = 0;
71    
72          bbs_main();          bbs_main();
73    
74    cleanup:
75            // Child process exit
76            SYS_server_exit = 1;
77    
78          if (close(socket_client) == -1)          if (close(socket_client) == -1)
79          {          {
80                  log_error("Close client socket failed\n");                  log_error("Close client socket failed\n");
# Line 77  int fork_server() Line 84  int fork_server()
84          close(STDIN_FILENO);          close(STDIN_FILENO);
85          close(STDOUT_FILENO);          close(STDOUT_FILENO);
86    
87          log_std("Process exit normally\n");          log_common("Process exit normally\n");
   
88          log_end();          log_end();
89    
90          // Exit child process normally          _exit(0);
         exit(0);  
91    
92          return 0;          return 0;
93  }  }


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1