| 1 |
/*************************************************************************** |
/*************************************************************************** |
| 2 |
common.c - description |
common.c - description |
| 3 |
------------------- |
------------------- |
| 4 |
begin : Mon Oct 18 2004 |
Copyright : (C) 2004-2025 by Leaflet |
| 5 |
copyright : (C) 2004 by Leaflet |
Email : leaflet@leafok.com |
|
email : leaflet@leafok.com |
|
| 6 |
***************************************************************************/ |
***************************************************************************/ |
| 7 |
|
|
| 8 |
/*************************************************************************** |
/*************************************************************************** |
| 9 |
* * |
* * |
| 10 |
* This program is free software; you can redistribute it and/or modify * |
* This program is free software; you can redistribute it and/or modify * |
| 11 |
* it under the terms of the GNU General Public License as published by * |
* it under the terms of the GNU General Public License as published by * |
| 12 |
* the Free Software Foundation; either version 2 of the License, or * |
* the Free Software Foundation; either version 3 of the License, or * |
| 13 |
* (at your option) any later version. * |
* (at your option) any later version. * |
| 14 |
* * |
* * |
| 15 |
***************************************************************************/ |
***************************************************************************/ |
| 25 |
// Version information |
// Version information |
| 26 |
char app_version[256] = "LBBS-devel version 1.0"; |
char app_version[256] = "LBBS-devel version 1.0"; |
| 27 |
|
|
|
// Global declaration for enviroment |
|
|
char app_home_dir[256]; |
|
|
char app_temp_dir[256]; |
|
|
|
|
| 28 |
// Global declaration for sockets |
// Global declaration for sockets |
| 29 |
int socket_server; |
int socket_server; |
| 30 |
int socket_client; |
int socket_client; |
| 49 |
return string; |
return string; |
| 50 |
} |
} |
| 51 |
|
|
| 52 |
const char *get_time_str(char *string, size_t length) |
const char *get_time_str(char *s, size_t len) |
| 53 |
{ |
{ |
| 54 |
char week[20]; |
time_t curtime = time(NULL); |
|
char buffer[LINE_BUFFER_LEN]; |
|
|
time_t curtime; |
|
| 55 |
struct tm *loctime; |
struct tm *loctime; |
|
|
|
|
curtime = time(NULL); |
|
| 56 |
loctime = localtime(&curtime); |
loctime = localtime(&curtime); |
| 57 |
|
|
| 58 |
strftime(buffer, sizeof(buffer), "%Y年%m月%d日%H:%M:%S ", loctime); |
size_t j = strftime(s, len, "%Y年%m月%d日%H:%M:%S ", loctime); |
| 59 |
|
|
| 60 |
|
if (j == 0) |
| 61 |
|
{ |
| 62 |
|
return NULL; |
| 63 |
|
} |
| 64 |
|
|
| 65 |
switch (loctime->tm_wday) |
switch (loctime->tm_wday) |
| 66 |
{ |
{ |
| 67 |
case 0: |
case 0: |
| 68 |
strncpy(week, "星期天", sizeof(week)); |
strncat(s, "星期天", len - j); |
| 69 |
break; |
break; |
| 70 |
case 1: |
case 1: |
| 71 |
strncpy(week, "星期一", sizeof(week)); |
strncat(s, "星期一", len - j); |
| 72 |
break; |
break; |
| 73 |
case 2: |
case 2: |
| 74 |
strncpy(week, "星期二", sizeof(week)); |
strncat(s, "星期二", len - j); |
| 75 |
break; |
break; |
| 76 |
case 3: |
case 3: |
| 77 |
strncpy(week, "星期三", sizeof(week)); |
strncat(s, "星期三", len - j); |
| 78 |
break; |
break; |
| 79 |
case 4: |
case 4: |
| 80 |
strncpy(week, "星期四", sizeof(week)); |
strncat(s, "星期四", len - j); |
| 81 |
break; |
break; |
| 82 |
case 5: |
case 5: |
| 83 |
strncpy(week, "星期五", sizeof(week)); |
strncat(s, "星期五", len - j); |
| 84 |
break; |
break; |
| 85 |
case 6: |
case 6: |
| 86 |
strncpy(week, "星期六", sizeof(week)); |
strncat(s, "星期六", len - j); |
| 87 |
break; |
break; |
| 88 |
} |
} |
|
strncat(buffer, week, sizeof(week)); |
|
|
|
|
|
strncpy(string, buffer, length); |
|
| 89 |
|
|
| 90 |
return string; |
return s; |
| 91 |
} |
} |
| 92 |
|
|
| 93 |
void reload_bbs_menu(int i) |
void reload_bbs_menu(int i) |
| 94 |
{ |
{ |
| 95 |
if (reload_menu(&bbs_menu) < 0) |
if (reload_menu(&bbs_menu) < 0) |
| 96 |
|
{ |
| 97 |
log_error("Reload menu failed\n"); |
log_error("Reload menu failed\n"); |
| 98 |
|
} |
| 99 |
else |
else |
| 100 |
|
{ |
| 101 |
log_std("Reload menu successfully\n"); |
log_std("Reload menu successfully\n"); |
| 102 |
|
} |
| 103 |
} |
} |
| 104 |
|
|
| 105 |
void system_exit(int i) |
void system_exit(int i) |
| 119 |
log_std("Child process (%d) exited\n", pid); |
log_std("Child process (%d) exited\n", pid); |
| 120 |
} |
} |
| 121 |
} |
} |
| 122 |
|
|
| 123 |
|
const char * ip_mask(char * s, int level, char mask) |
| 124 |
|
{ |
| 125 |
|
char * p = s; |
| 126 |
|
|
| 127 |
|
if (level <= 0) |
| 128 |
|
{ |
| 129 |
|
return s; |
| 130 |
|
} |
| 131 |
|
if (level > 4) |
| 132 |
|
{ |
| 133 |
|
level = 4; |
| 134 |
|
} |
| 135 |
|
|
| 136 |
|
for (int i = 0; i < 4 - level; i++) |
| 137 |
|
{ |
| 138 |
|
p = strchr(p, '.'); |
| 139 |
|
if (p == NULL) |
| 140 |
|
{ |
| 141 |
|
return s; |
| 142 |
|
} |
| 143 |
|
p++; |
| 144 |
|
} |
| 145 |
|
|
| 146 |
|
for (int i = 0; i < level; i++) |
| 147 |
|
{ |
| 148 |
|
*p = mask; |
| 149 |
|
p++; |
| 150 |
|
if (i < level - 1) |
| 151 |
|
{ |
| 152 |
|
*p = '.'; |
| 153 |
|
p++; |
| 154 |
|
} |
| 155 |
|
} |
| 156 |
|
*p = '\0'; |
| 157 |
|
|
| 158 |
|
return s; |
| 159 |
|
} |