156 lines
4.0 KiB
C
156 lines
4.0 KiB
C
#include "version.h"
|
|
#include <signal.h>
|
|
#include <errno.h>
|
|
#include <unistd.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include "buf.h"
|
|
#include "net.h"
|
|
#include "char.h"
|
|
#include "item.h"
|
|
#include "object.h"
|
|
#include "configfile.h"
|
|
#include "lssproto_serv.h"
|
|
#include "saacproto_cli.h"
|
|
#include "log.h"
|
|
#include "petmail.h"
|
|
#ifdef _ALLBLUES_LUA
|
|
#include "mylua/mylua.h"
|
|
#endif
|
|
/*------------------------------------------------------------
|
|
* 卅仄
|
|
------------------------------------------------------------*/
|
|
static void endlsprotocol( void )
|
|
{
|
|
lssproto_CleanupServer();
|
|
saacproto_CleanupClient();
|
|
}
|
|
|
|
/*------------------------------------------------------------
|
|
* 允屯化及忡绣仄卅仃木壬卅日卅中犯□正毛母件皿允月楮醒
|
|
* 卅仄
|
|
------------------------------------------------------------*/
|
|
static void allDataDump( void )
|
|
{
|
|
closeAllLogFile();
|
|
#ifdef _PET_ITEM
|
|
storeObjects( getStoredir() );
|
|
storePetmail();
|
|
#endif
|
|
#ifdef _ALLBLUES_LUA
|
|
closemyluaload();
|
|
#endif
|
|
storeCharaData();
|
|
}
|
|
|
|
/*------------------------------------------------------------
|
|
* 卅仄
|
|
------------------------------------------------------------*/
|
|
void shutdownProgram( void )
|
|
{
|
|
printf("关闭SAAC连接:%d\n",acfd);
|
|
printf("关闭绑定端口:%d\n",bindedfd);
|
|
close( acfd );
|
|
close( bindedfd );
|
|
memEnd();
|
|
}
|
|
#ifdef _GMSV_DEBUG
|
|
char *DebugMainFunction = NULL;
|
|
extern time_t initTime;
|
|
#endif
|
|
extern int player_online;
|
|
extern int player_maxonline;
|
|
char saacretfunc[255]="";
|
|
char *saacsendfunc = NULL;
|
|
int cliretfunc=0;
|
|
int clisendfunc=0;
|
|
char playcdkey[16] = "";
|
|
char *errraw = NULL;
|
|
void sigshutdown( int number )
|
|
{
|
|
if( number == 0 ){
|
|
print( "\nGMSV正常关闭\n" );
|
|
}else{
|
|
print( "\n=========以下是服务器出错原因=========\n");
|
|
print( "标准信息: %d\n" , number );
|
|
#ifdef _GMSV_DEBUG
|
|
print( "主 函 数: %s\n", DebugMainFunction );
|
|
#endif
|
|
print( "在线人数: %d\n", player_online);
|
|
print( "最高在线: %d\n", player_maxonline);
|
|
print( "SAAC接收: %s\n", saacretfunc);
|
|
print( "SAAC发送: %s\n", saacsendfunc);
|
|
print( "cli 接收: %d\n", cliretfunc);
|
|
print( "cli 发送: %d\n", clisendfunc);
|
|
print( "错误账号: %s\n", playcdkey);
|
|
print( "错误封包: %s\n", errraw);
|
|
#ifdef _GMSV_DEBUG
|
|
{
|
|
time_t new_t;
|
|
int dd,hh,mm,ss;
|
|
char buf[128];
|
|
time(&new_t);
|
|
if(initTime==0){
|
|
print( "运行时间: 尚未初始化完\n" );
|
|
}else{
|
|
new_t-=initTime;
|
|
|
|
dd=(int) new_t / 86400; new_t=new_t % 86400;
|
|
hh=(int) new_t / 3600; new_t=new_t % 3600;
|
|
mm=(int) new_t / 60; new_t=new_t % 60;
|
|
ss=(int) new_t;
|
|
|
|
if (dd>0) {
|
|
snprintf( buf, sizeof( buf ) , "服务器共运行了 %d 日 %d 小时 %d 分 %d 秒。",dd,hh,mm,ss);
|
|
} else if (hh>0) {
|
|
snprintf( buf, sizeof( buf ) , "服务器共运行了 %d 小时 %d 分 %d 秒。",hh,mm,ss);
|
|
} else {
|
|
snprintf( buf, sizeof( buf ) , "服务器共运行了 %d 分 %d 秒。",mm,ss);
|
|
}
|
|
print( "运行时间: %s\n", buf );
|
|
}
|
|
}
|
|
#endif
|
|
print( "=========以上是服务器出错原因=========\n");
|
|
}
|
|
remove( "gmsvlog.err2");
|
|
rename( "gmsvlog.err1", "gmsvlog.err2" );
|
|
rename( "gmsvlog.err", "gmsvlog.err1" );
|
|
rename( "gmsvlog", "gmsvlog.err" );
|
|
|
|
allDataDump();
|
|
|
|
signal( SIGINT , SIG_IGN );
|
|
signal( SIGQUIT, SIG_IGN );
|
|
signal( SIGKILL, SIG_IGN );
|
|
signal( SIGSEGV, SIG_IGN );
|
|
signal( SIGPIPE, SIG_IGN );
|
|
signal( SIGTERM, SIG_IGN );
|
|
|
|
shutdownProgram();
|
|
exit(number);
|
|
}
|
|
|
|
|
|
|
|
void signalset( void )
|
|
{
|
|
// CoolFish: Test Signal 2001/10/26
|
|
print("\n开始获取信号..\n");
|
|
|
|
print("SIGINT:%d\n", SIGINT);
|
|
print("SIGQUIT:%d\n", SIGQUIT);
|
|
print("SIGKILL:%d\n", SIGKILL);
|
|
print("SIGSEGV:%d\n", SIGSEGV);
|
|
print("SIGPIPE:%d\n", SIGPIPE);
|
|
print("SIGTERM:%d\n", SIGTERM);
|
|
|
|
signal( SIGINT , sigshutdown );
|
|
signal( SIGQUIT, sigshutdown );
|
|
signal( SIGKILL, sigshutdown );
|
|
signal( SIGSEGV, sigshutdown );
|
|
signal( SIGPIPE, SIG_IGN );
|
|
signal( SIGTERM, sigshutdown );
|
|
}
|