--- lbbs/src/common.c 2025/05/06 05:31:26 1.15 +++ lbbs/src/common.c 2025/05/13 03:07:54 1.19 @@ -20,7 +20,6 @@ #include #include #include -#include // Version information char app_version[256] = "LBBS-devel version 1.0"; @@ -34,8 +33,10 @@ int port_server; int port_client; // Global declaration for system -int SYS_exit; -int SYS_child_process_count; +volatile int SYS_server_exit = 0; +volatile int SYS_child_process_count = 0; +volatile int SYS_child_exit = 0; +volatile int SYS_menu_reload = 0; // Common function const char *str_space(char *string, int length) @@ -90,28 +91,56 @@ const char *get_time_str(char *s, size_t return s; } -void reload_bbs_menu(int i) +void sig_hup_handler(int i) { - if (reload_menu(&bbs_menu) < 0) - log_error("Reload menu failed\n"); - else - log_std("Reload menu successfully\n"); + SYS_menu_reload = 1; } -void system_exit(int i) +void sig_term_handler(int i) { - SYS_exit = 1; + log_std("Debug: SIGTERM captured\n"); + SYS_server_exit = 1; } -void child_exit(int i) +void sig_chld_handler(int i) { - int pid; + SYS_child_exit = 1; +} + +const char * ip_mask(char * s, int level, char mask) +{ + char * p = s; + + if (level <= 0) + { + return s; + } + if (level > 4) + { + level = 4; + } - pid = wait(0); + for (int i = 0; i < 4 - level; i++) + { + p = strchr(p, '.'); + if (p == NULL) + { + return s; + } + p++; + } - if (pid > 0) + for (int i = 0; i < level; i++) { - SYS_child_process_count--; - log_std("Child process (%d) exited\n", pid); + *p = mask; + p++; + if (i < level - 1) + { + *p = '.'; + p++; + } } + *p = '\0'; + + return s; }