/[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.15 by sysadm, Tue May 6 05:31:26 2025 UTC Revision 1.23 by sysadm, Tue Jun 3 13:14:26 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>
29    
30  int fork_server()  int fork_server(void)
31  {  {
32          int pid;          int pid;
33    
# Line 34  int fork_server() Line 37  int fork_server()
37          {          {
38                  SYS_child_process_count++;                  SYS_child_process_count++;
39                  log_std("Child process (%d) start\n", pid);                  log_std("Child process (%d) start\n", pid);
40                  return 0;                  return pid;
41          }          }
42          else if (pid < 0) // Error          else if (pid < 0) // Error
43          {          {
44                    log_error("fork() error (%d)\n", errno);
45                  return -1;                  return -1;
46          }          }
47    
# Line 45  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 53  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 61  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 76  int fork_server() Line 85  int fork_server()
85          close(STDOUT_FILENO);          close(STDOUT_FILENO);
86    
87          log_std("Process exit normally\n");          log_std("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