2170 lines
54 KiB
C
2170 lines
54 KiB
C
![]() |
#define _MAIN_C_
|
|||
|
|
|||
|
#ifdef _SASQL1
|
|||
|
#include "sasql.h"
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
#include "main.h"
|
|||
|
#include "util.h"
|
|||
|
#include "mail.h"
|
|||
|
#include "db.h"
|
|||
|
#include "saacproto_util.h"
|
|||
|
#include "saacproto_serv.h"
|
|||
|
#ifdef _UNIVERSE_CHATROOM
|
|||
|
#include "chatroom.h"
|
|||
|
#endif
|
|||
|
// CoolFish: Family 2001/5/9
|
|||
|
#include "acfamily.h"
|
|||
|
#include "version.h"
|
|||
|
|
|||
|
#ifdef _DEATH_CONTEND
|
|||
|
#include "deathcontend.h"
|
|||
|
#endif
|
|||
|
|
|||
|
#include <signal.h>
|
|||
|
#include <sys/types.h>
|
|||
|
#include <time.h>
|
|||
|
#include <sys/time.h>
|
|||
|
#include <errno.h>
|
|||
|
#include <sys/wait.h>
|
|||
|
#include <getopt.h>
|
|||
|
#include <stdio.h>
|
|||
|
#include <malloc.h>
|
|||
|
#include <strings.h>
|
|||
|
#include <string.h>
|
|||
|
#include <unistd.h>
|
|||
|
#include <netdb.h>
|
|||
|
#include <errno.h>
|
|||
|
#include <sys/socket.h>
|
|||
|
#include <netinet/in.h>
|
|||
|
#include <arpa/inet.h>
|
|||
|
#include <time.h>
|
|||
|
#include <fcntl.h>
|
|||
|
#include <netinet/tcp.h>
|
|||
|
|
|||
|
#include "saacproto_work.h"
|
|||
|
#ifdef _OACSTRUCT_TCP
|
|||
|
#include "saacproto_oac.h"
|
|||
|
#endif
|
|||
|
#ifdef _PAUCTION_MAN
|
|||
|
#include "auction.h"
|
|||
|
#endif
|
|||
|
#include "lock.h"
|
|||
|
#define BACKLOGNUM 5
|
|||
|
|
|||
|
|
|||
|
#ifdef _FIX_WORKS
|
|||
|
#include "saacproto_work.h"
|
|||
|
int worksockfd;
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _LOCK_SERVER
|
|||
|
#include "saacproto_lserver.h"
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _SEND_EFFECT // WON ADD <20><><EFBFBD><EFBFBD>ѩ<EFBFBD><D1A9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ч
|
|||
|
#include "recv.h"
|
|||
|
#endif
|
|||
|
|
|||
|
#include "defend.h"
|
|||
|
|
|||
|
#include "char.h"
|
|||
|
|
|||
|
#ifdef _SASQL
|
|||
|
#include "sasql.h"
|
|||
|
#endif
|
|||
|
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
|
|||
|
struct membuf
|
|||
|
{
|
|||
|
int use;
|
|||
|
char buf[512];
|
|||
|
// char buf[1024*128];
|
|||
|
int len;
|
|||
|
int next;
|
|||
|
};
|
|||
|
|
|||
|
struct connection
|
|||
|
{
|
|||
|
int use;
|
|||
|
int fd;
|
|||
|
int mbtop_ri;
|
|||
|
int mbtop_wi;
|
|||
|
struct sockaddr_in remoteaddr;
|
|||
|
int closed_by_remote;
|
|||
|
};
|
|||
|
#else
|
|||
|
#endif
|
|||
|
|
|||
|
struct membuf *mb;
|
|||
|
int mbsize;
|
|||
|
int mbuse ;
|
|||
|
|
|||
|
int mainsockfd; /* accept <20><> <20><>¦<EFBFBD>ѱ<EFBFBD><D1B1><EFBFBD>ľ<EFBFBD><C4BE> */
|
|||
|
struct sockaddr_in localaddr; /* bind <20><><EFBFBD><EFBFBD>ʧ<EFBFBD><CAA7><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
|
|||
|
|
|||
|
struct connection *con; /* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
|
|||
|
static int mb_finder=0; /* mb<6D><62><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><C3AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><D7BB><EFBFBD>
|
|||
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD>ʢ<EFBFBD><EFBFBD> */
|
|||
|
// WON FIX
|
|||
|
char tmpbuf[65536];
|
|||
|
//char tmpbuf[65536*3]; /* read<61><64> */
|
|||
|
|
|||
|
struct timeval select_timeout;
|
|||
|
|
|||
|
time_t sys_time =0; // Robin add
|
|||
|
|
|||
|
extern gmsv gs[MAXCONNECTION];
|
|||
|
|
|||
|
int tcpstruct_init( char *addr, int port, int timeout_ms, int mem_use, int deb);
|
|||
|
int tcpstruct_accept1( void );
|
|||
|
int tcpstruct_accept( int *tis , int ticount );
|
|||
|
int tcpstruct_close( int ti );
|
|||
|
int tcpstruct_read( int ti , char *buf , int len );
|
|||
|
int tcpstruct_readline( int ti , char *buf , int len ,int k ,int r);
|
|||
|
int tcpstruct_readline_chop( int ti , char *buf, int len );
|
|||
|
int tcpstruct_write( int ti , char *buf , int len );
|
|||
|
int tcpstruct_countmbuse( void );
|
|||
|
int tcpstruct_connect( char *addr , int port );
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
void set_nodelay( int sock );
|
|||
|
|
|||
|
|
|||
|
#define OK 0 /* <20><> */
|
|||
|
#define TCPSTRUCT_ENOMEM -1 /* malloc <20><> */
|
|||
|
#define TCPSTRUCT_ESOCK -2 /* socket <20><> */
|
|||
|
#define TCPSTRUCT_EBIND -3 /* bind <20><> */
|
|||
|
#define TCPSTRUCT_ELISTEN -4 /* listen <20><> */
|
|||
|
#define TCPSTRUCT_EBUG -6 /* <20><><EFBFBD><EFBFBD>ƥؤ<C6A5><D8A4> */
|
|||
|
#define TCPSTRUCT_EINVCIND -7 /* con<6F><EFBFBD>index<65><78><EFBFBD>ƾ<EFBFBD><C6BE><EFBFBD><EFBFBD>з<EFBFBD> */
|
|||
|
#define TCPSTRUCT_EREADFIN -8 /* read <20><><EFBFBD>·<EFBFBD><C2B7><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>ʻ<EFBFBD> closed by remote */
|
|||
|
#define TCPSTRUCT_EHOST -9 /* gethostbyname <20><> */
|
|||
|
#define TCPSTRUCT_ECONNECT -10 /* connect <20><> */
|
|||
|
#define TCPSTRUCT_ECFULL -11 /* con <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
#define TCPSTRUCT_ETOOLONG -12 /* <20>滥ئ<E6BBA5><D8A6><EFBFBD>ʿ<EFBFBD> */
|
|||
|
#define TCPSTRUCT_EMBFULL -13 /* mb <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
#define TCPSTRUCT_ECLOSEAGAIN -14 /* close <20><>2<EFBFBD>Խ<EFBFBD>ľ<EFBFBD><C4BE> */
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
int port; /* <20>ء<EFBFBD>ة<EFBFBD>ӡ<EFBFBD><D3A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><C6BB><EFBFBD><EFBFBD>º̡<C2BA><CCA1><EFBFBD> */
|
|||
|
int Total_Charlist;
|
|||
|
int Expired_mail;
|
|||
|
int Del_Family_or_Member;
|
|||
|
int Write_Family;
|
|||
|
#ifdef _NEW_PLAYERGOLD
|
|||
|
int New_PlayerGold;
|
|||
|
#endif
|
|||
|
|
|||
|
// Nuke start
|
|||
|
char *chartime()
|
|||
|
{
|
|||
|
static char buf[80];
|
|||
|
time_t t;
|
|||
|
t=time(0);
|
|||
|
strcpy(buf,ctime(&t));
|
|||
|
buf[strlen(buf)-1]=0;
|
|||
|
return(buf);
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
sigaction<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
*/
|
|||
|
void sighandle( int a )
|
|||
|
{
|
|||
|
if (a==SIGUSR1) log("sigusr1<EFBFBD>ź<EFBFBD>!\n");
|
|||
|
|
|||
|
if (a==SIGUSR2) {
|
|||
|
sigusr2( a);
|
|||
|
log("sigusr2<EFBFBD>ź<EFBFBD>!\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
#ifdef _SQL_BACKGROUND
|
|||
|
if(!sasql_initonline())
|
|||
|
log("\n<EFBFBD><EFBFBD><EFBFBD>ݿⱣ<EFBFBD><EFBFBD>ʧ<EFBFBD>ܣ<EFBFBD>\n");
|
|||
|
#endif
|
|||
|
log("<EFBFBD>õ<EFBFBD>һ<EFBFBD><EFBFBD><EFBFBD>ź<EFBFBD>! <20>쳣<EFBFBD>ж<EFBFBD>......\n" );
|
|||
|
exit(1);
|
|||
|
}
|
|||
|
|
|||
|
void sigusr2(int a);
|
|||
|
|
|||
|
// Arminius 7.20 memory unlock
|
|||
|
void sigusr1(int a)
|
|||
|
{
|
|||
|
int i;
|
|||
|
FILE *f;
|
|||
|
char key[4096],buf[4096];
|
|||
|
|
|||
|
signal(SIGUSR1, sigusr1);
|
|||
|
|
|||
|
f = fopen("./unlock.arg", "r");
|
|||
|
|
|||
|
if (f) {
|
|||
|
memset(key, 0, 4096);
|
|||
|
fread(key, 4096, 1, f);
|
|||
|
for (i=0; i<strlen(key); i++) if (key[i]=='\n') key[i]='\0';
|
|||
|
|
|||
|
switch (key[0]) {
|
|||
|
case 'P': // unlock player
|
|||
|
if (DeleteMemLock(getHash(&key[1]) & 0xff,&key[1],&i)) {
|
|||
|
log("ADM: memunlock: %s success.\n", key);
|
|||
|
} else {
|
|||
|
log("ADM: memunlock: %s failed.\n", key);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 'S': // unlock server
|
|||
|
DeleteMemLockServer(&key[1]);
|
|||
|
log("ADM: memunlock: %s\n", key);
|
|||
|
break;
|
|||
|
case 'C': // check player lock
|
|||
|
GetMemLockState(getHash(&key[1]) & 0xff, &key[1], buf);
|
|||
|
sprintf(key, "echo \"%s\" > ./sigusr1.result", buf);
|
|||
|
system(key);
|
|||
|
break;
|
|||
|
#ifdef _CK_ONLINE_PLAYER_COUNT // WON ADD <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
case 'W':
|
|||
|
PlayerCount();
|
|||
|
break;
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _SEND_EFFECT // WON ADD <20><><EFBFBD><EFBFBD>ѩ<EFBFBD><D1A9><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ч
|
|||
|
case 'E':
|
|||
|
log("\nAC <20><> GS <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ѩ<EFBFBD><D1A9>Ч!!\n");
|
|||
|
SendEffect(&key[1]);
|
|||
|
break;
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _BAD_PLAYER // WON ADD <20>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD>ȥ<EFBFBD><C8A5>
|
|||
|
case 'B':
|
|||
|
log("\nAC <20><><EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD>Ҽ<EFBFBD><D2BC><EFBFBD>!!\n");
|
|||
|
BadPlayer();
|
|||
|
break;
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _RECAL_BACKUP_PLAYER // WON <20><><EFBFBD>ݹ<EFBFBD><DDB9><EFBFBD>
|
|||
|
case 'U':
|
|||
|
log("\n<EFBFBD><EFBFBD><EFBFBD>ͱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>");
|
|||
|
// <20>õ<EFBFBD><C3B5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
send_backup_player_data();
|
|||
|
break;
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _GM_BROADCAST // WON ADD <20>ͷ<EFBFBD><CDB7><EFBFBD><EFBFBD><EFBFBD>ϵͳ
|
|||
|
case 'G':
|
|||
|
log("\n won test 1 ==> _GM_BROADCAST" );
|
|||
|
broadcast(key);
|
|||
|
break;
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _KILLDEADWORKER // <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Worker<65><72>ʼ<EFBFBD><CABC>
|
|||
|
case 'K':
|
|||
|
log("\nKILL ALL WORKER!!!!!\n");
|
|||
|
initWorkerPort();
|
|||
|
break;
|
|||
|
#endif
|
|||
|
|
|||
|
case 'L': // Robin <20>г<EFBFBD><D0B3><EFBFBD><EFBFBD><EFBFBD>Server<65><72><EFBFBD><EFBFBD>
|
|||
|
log("\nList All Server Conncet!!!!!\n");
|
|||
|
for( i =0; i <MAXCONNECTION; i++)
|
|||
|
if( gs[i].use)
|
|||
|
log("\n gs[%d] fd:%d name:%s ", i, gs[i].fd, gs[i].name );
|
|||
|
break;
|
|||
|
|
|||
|
}
|
|||
|
log(" sigusr1_over_1 ");
|
|||
|
fclose(f);
|
|||
|
log(" sigusr1_over_2 ");
|
|||
|
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static int netWrite( int ti , char *buf , int len)
|
|||
|
{
|
|||
|
return tcpstruct_write( ti , buf, len );
|
|||
|
}
|
|||
|
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
typedef enum
|
|||
|
{
|
|||
|
WKSTAT_IDLE = 0, /* <20><><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD>ئ<EFBFBD><D8A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
WKSTAT_WAITING = 2 /* <20><><EFBFBD><EFBFBD><EFBFBD>о<EFBFBD><D0BE>ռ<EFBFBD>߯<EFBFBD><DFAF>ë<EFBFBD><C3AB><EFBFBD>Ȼ<EFBFBD><C8BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
} WKSTAT;
|
|||
|
|
|||
|
struct worker
|
|||
|
{
|
|||
|
int use;
|
|||
|
int port;
|
|||
|
int ti;
|
|||
|
int request_ti;
|
|||
|
WKSTAT status;
|
|||
|
time_t last_query;
|
|||
|
void (*callback)( int ti , int result , char *cparam0 , char *cparam1,
|
|||
|
char *cparam2 , char *cparam3, char *cparam4,
|
|||
|
int iparam1 , int iparam2 );
|
|||
|
#define CPARAMNUM 5
|
|||
|
char cparam[CPARAMNUM][CHARDATASIZE];
|
|||
|
#define IPARAMNUM 3
|
|||
|
int iparam[IPARAMNUM];
|
|||
|
};
|
|||
|
|
|||
|
struct worker wk[MAXWK];
|
|||
|
#endif
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
static void addWorkerPort( int port )
|
|||
|
{
|
|||
|
int i;
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
if( wk[i].use == 0 ){
|
|||
|
wk[i].use = 1;
|
|||
|
wk[i].port = port;
|
|||
|
wk[i].ti = -1;
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
exit(1);
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
int worker_finder = 0;
|
|||
|
|
|||
|
static void initWorkerPort( void )
|
|||
|
{
|
|||
|
int i;
|
|||
|
bzero( &wk , sizeof( wk ));
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
#ifdef _FIX_WORKS
|
|||
|
wk[i].use = 0;
|
|||
|
wk[i].status = WKSTAT_IDLE;
|
|||
|
if( wk[i].fd < 0 )
|
|||
|
close( wk[i].fd);
|
|||
|
wk[i].fd = -1;
|
|||
|
wk[i].last_query = -1;
|
|||
|
#else
|
|||
|
wk[i].status = WKSTAT_IDLE;
|
|||
|
#endif
|
|||
|
}
|
|||
|
worker_finder = 0;
|
|||
|
}
|
|||
|
|
|||
|
static void connectToWorker( void )
|
|||
|
{
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
int i;
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
if( wk[i].use ){
|
|||
|
int ti = tcpstruct_connect( "127.0.0.1" , wk[i].port );
|
|||
|
if( ti >= 0 ){
|
|||
|
wk[i].ti = ti;
|
|||
|
} else {
|
|||
|
exit(1);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
}
|
|||
|
|
|||
|
static int countWorker( void );
|
|||
|
|
|||
|
// Nuke
|
|||
|
int addWorkerTask( char *id , char *pas , char *flag,
|
|||
|
void (*callbk)( int ti , int result ,
|
|||
|
char *cp0 , char *cp1 , char *cp2 ,
|
|||
|
char *cp3 , char *cp4, int i0 , int i1) ,
|
|||
|
int ti ,
|
|||
|
char *cparam0 , char *cparam1 ,
|
|||
|
char *cparam2 , char *cparam3 , char *cparam4 ,
|
|||
|
int iparam0 , int iparam1)
|
|||
|
{
|
|||
|
|
|||
|
int i;
|
|||
|
// Spock +1 2000/11/2
|
|||
|
char *process = cparam3;
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
int n;
|
|||
|
worker_finder ++;
|
|||
|
if( worker_finder >= MAXWK ) worker_finder = 0;
|
|||
|
n = worker_finder;
|
|||
|
if( wk[n].use && wk[n].status == WKSTAT_IDLE ){
|
|||
|
char s[256];
|
|||
|
|
|||
|
log("ʹ<EFBFBD>ù<EFBFBD><EFBFBD><EFBFBD>վ:%d \n", n);
|
|||
|
|
|||
|
// Nuke
|
|||
|
{
|
|||
|
int i;
|
|||
|
for (i=0;id[i];i++) if (id[i]==' ') return -1;
|
|||
|
}
|
|||
|
|
|||
|
// Spock 2000/11/2
|
|||
|
snprintf( s , sizeof( s ) , "%s %s %s %s\n", id , pas , flag , process);
|
|||
|
// Spock end
|
|||
|
#ifdef _FIX_WORKS
|
|||
|
if( cWork_write( wk[n].ti, s, strlen(s)) <= 0 ) {
|
|||
|
#else
|
|||
|
if( tcpstruct_write( wk[n].ti , s , strlen(s)) != strlen(s) ){
|
|||
|
#endif
|
|||
|
return -1;
|
|||
|
} else {
|
|||
|
}
|
|||
|
|
|||
|
snprintf( wk[n].cparam[0] , CHARDATASIZE , "%s", cparam0 );
|
|||
|
snprintf( wk[n].cparam[1] , CHARDATASIZE , "%s", cparam1 );
|
|||
|
snprintf( wk[n].cparam[2] , CHARDATASIZE , "%s", cparam2 );
|
|||
|
snprintf( wk[n].cparam[3] , CHARDATASIZE , "%s", cparam3 );
|
|||
|
snprintf( wk[n].cparam[4] , CHARDATASIZE , "%s", cparam4 );
|
|||
|
wk[n].iparam[0] = iparam0;
|
|||
|
wk[n].iparam[1] = iparam1;
|
|||
|
wk[n].status = WKSTAT_WAITING;
|
|||
|
wk[n].callback = callbk;
|
|||
|
wk[n].request_ti = ti ;
|
|||
|
wk[n].last_query = time(NULL);
|
|||
|
|
|||
|
return 0;
|
|||
|
}
|
|||
|
}
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>վ<EFBFBD><EFBFBD>æ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>վֹͣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>. <20><EFBFBD>еĹ<D0B5><C4B9><EFBFBD>վ<EFBFBD><D5BE>:%d\n", countWorker() );
|
|||
|
return -1;
|
|||
|
}
|
|||
|
|
|||
|
static int countWorker( void )
|
|||
|
{
|
|||
|
int i,c=0;
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
if( wk[i].use )c++;
|
|||
|
}
|
|||
|
return c;
|
|||
|
}
|
|||
|
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
static void checkWorkerClosed( int ti )
|
|||
|
{
|
|||
|
int i;
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
if( wk[i].ti == ti ){
|
|||
|
wk[i].use = 0;
|
|||
|
wk[i].ti = -1;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
static void doWorker( int ti , char *m )
|
|||
|
{
|
|||
|
int i;
|
|||
|
int res=-1;
|
|||
|
|
|||
|
char deadline[128];
|
|||
|
|
|||
|
#ifdef _TIMEOUTKICK
|
|||
|
//log("<22><><EFBFBD><EFBFBD>վ:%s ", m);
|
|||
|
// Nuke 20040519: Protect from error from worker
|
|||
|
if (m)
|
|||
|
{
|
|||
|
char *p1,*p2;
|
|||
|
p1=strtok(m," ");
|
|||
|
p2=strtok(0," ");
|
|||
|
|
|||
|
if (p1)
|
|||
|
res = atoi( p1 );
|
|||
|
else
|
|||
|
res=-1;
|
|||
|
|
|||
|
if (p2)
|
|||
|
strcpy( deadline, p2 ); // ȡ<><C8A1> deadline
|
|||
|
else {
|
|||
|
strcpy( deadline, "0" );
|
|||
|
//log("\n <20><><EFBFBD><EFBFBD>վ<EFBFBD>ش<EFBFBD><D8B4><EFBFBD>Ϣ:%d:%s ", ti, p1);
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
res=-1;
|
|||
|
strcpy( deadline, "0" );
|
|||
|
}
|
|||
|
#else
|
|||
|
res = atoi( m );
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _NO_DOUBLECHECK
|
|||
|
res =0;
|
|||
|
#endif
|
|||
|
for( i=0; i<MAXWK; i++){
|
|||
|
if( wk[i].use && wk[i].ti == ti ){
|
|||
|
if( wk[i].status == WKSTAT_WAITING ){
|
|||
|
if( wk[i].callback ){
|
|||
|
|
|||
|
#ifdef _TIMEOUTKICK
|
|||
|
strcpy( wk[i].cparam[4] ,deadline);
|
|||
|
#endif
|
|||
|
// Robin log
|
|||
|
//log(" wk[%d] c0:%s c1:%s c2:%s c3:%s c4:%s i0:%d i1:%d ",
|
|||
|
// wk[i].request_ti, wk[i].cparam[0], wk[i].cparam[1],
|
|||
|
// wk[i].cparam[2], wk[i].cparam[3], wk[i].cparam[4],
|
|||
|
// wk[i].iparam[0], wk[i].iparam[1]);
|
|||
|
|
|||
|
wk[i].callback( wk[i].request_ti , res,
|
|||
|
wk[i].cparam[0] ,
|
|||
|
wk[i].cparam[1] ,
|
|||
|
wk[i].cparam[2] ,
|
|||
|
wk[i].cparam[3] ,
|
|||
|
wk[i].cparam[4] ,
|
|||
|
wk[i].iparam[0] ,
|
|||
|
wk[i].iparam[1] );
|
|||
|
} else {
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>վ: ©<><C2A9>! callback <20><><EFBFBD>ܳ<EFBFBD>ʼ<EFBFBD><CABC>\n");
|
|||
|
}
|
|||
|
wk[i].status = WKSTAT_IDLE;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
static int isWorker( int ti )
|
|||
|
{
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
int i;
|
|||
|
for(i=0;i<MAXWK;i++){
|
|||
|
if( wk[i].use && wk[i].ti == ti )return 1;
|
|||
|
}
|
|||
|
#endif
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
gmsv gs[MAXCONNECTION];
|
|||
|
|
|||
|
int login_game_server( int ti , char *svname , char *svpas ,
|
|||
|
char *result , int resultlen ,
|
|||
|
char *retdata , int retdatalen )
|
|||
|
{
|
|||
|
if( strcmp( svpas , svpass ) == 0 ){
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȷ %s\n" , svname );
|
|||
|
} else {
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> %s\n" , svname );
|
|||
|
snprintf( result , resultlen , FAILED );
|
|||
|
snprintf( retdata , retdatalen , "bad passwd" );
|
|||
|
return 0;
|
|||
|
}
|
|||
|
{
|
|||
|
int i;
|
|||
|
for(i=0;i<MAXCONNECTION;i++){
|
|||
|
if( gs[i].use &&
|
|||
|
strcmp( gs[i].name , svname ) == 0 ){
|
|||
|
snprintf( result, resultlen, FAILED );
|
|||
|
snprintf( retdata , retdatalen, "duplicate login" );
|
|||
|
return 0;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
snprintf( gs[ti].name , sizeof(gs[ti].name), "%s" , svname );
|
|||
|
gs[ti].fd = ti;
|
|||
|
snprintf( result , resultlen ,SUCCESSFUL );
|
|||
|
snprintf( retdata , retdatalen , "Nothing special" );
|
|||
|
DeleteMemLockServer(svname); // Arminius 7.31 unlock server
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
int logout_game_server( int ti )
|
|||
|
{
|
|||
|
|
|||
|
gs[ti].use = 0;
|
|||
|
gs[ti].fd = -1;
|
|||
|
gs[ti].name[0] = 0;
|
|||
|
tcpstruct_close( ti );
|
|||
|
return 0;
|
|||
|
}
|
|||
|
int is_game_server_login( int ti )
|
|||
|
{
|
|||
|
return gs[ti].use;
|
|||
|
}
|
|||
|
|
|||
|
static int readConfig( char *path )
|
|||
|
{
|
|||
|
char buf[2048];
|
|||
|
FILE *fp;
|
|||
|
|
|||
|
fp = fopen( path , "r" );
|
|||
|
if( fp == NULL ){ return -2; }
|
|||
|
|
|||
|
while( fgets( buf , sizeof( buf ) , fp )){
|
|||
|
char command[1024];
|
|||
|
char param[2048];
|
|||
|
chop(buf);
|
|||
|
|
|||
|
easyGetTokenFromString( buf , 1 , command , sizeof( command ));
|
|||
|
easyGetTokenFromString( buf , 2 , param , sizeof( param ));
|
|||
|
|
|||
|
if( strcmp( command , "port" ) == 0 ){
|
|||
|
port = atoi( param );
|
|||
|
log( "<EFBFBD>˿<EFBFBD>:%d\n",port );
|
|||
|
} else if( strcmp( command , "logdir" ) == 0 ){
|
|||
|
snprintf( logdir , sizeof( logdir) , param );
|
|||
|
log( "<EFBFBD><EFBFBD>־Ŀ¼:%s\n",logdir );
|
|||
|
} else if( strcmp( command , "lockdir" ) == 0 ){
|
|||
|
snprintf( lockdir , sizeof( lockdir) , param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",lockdir );
|
|||
|
} else if( strcmp( command , "chardir" ) == 0 ){
|
|||
|
snprintf( chardir , sizeof( chardir) , param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",chardir );
|
|||
|
#ifdef _SLEEP_CHAR
|
|||
|
snprintf( sleepchardir , sizeof( sleepchardir), "%s_sleep", chardir);
|
|||
|
log( "˯<EFBFBD><EFBFBD>Ŀ¼:%s\n",sleepchardir );
|
|||
|
#endif
|
|||
|
} else if( strcmp( command , "pass" ) == 0 ){
|
|||
|
snprintf( svpass , sizeof( svpass ) , param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",svpass );
|
|||
|
} else if( strcmp( command , "wklogdir" ) == 0 ){
|
|||
|
snprintf( wklogdir , sizeof( wklogdir) , param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>־:%s\n",wklogdir );
|
|||
|
} else if( strcmp( command , "dbdir" ) == 0 ){
|
|||
|
snprintf( dbdir , sizeof( dbdir) , param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",dbdir );
|
|||
|
} else if( strcmp( command, "rotate_interval" ) == 0 ){
|
|||
|
log_rotate_interval = atoi( param );
|
|||
|
log( "<EFBFBD><EFBFBD>־ѭ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d\n",log_rotate_interval );
|
|||
|
} else if( strcmp( command, "maildir" ) == 0 ){
|
|||
|
snprintf( maildir, sizeof( maildir ), param );
|
|||
|
log( "<EFBFBD>ʼ<EFBFBD>Ŀ¼:%s\n",maildir );
|
|||
|
#ifdef __FAMILY
|
|||
|
// CoolFish: Family 2001/5/9
|
|||
|
} else if( strcmp( command, "familydir" ) == 0 ){
|
|||
|
snprintf( familydir, sizeof( familydir ), param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼:%s\n",familydir );
|
|||
|
} else if( strcmp( command, "fmpointdir" ) == 0 ){
|
|||
|
snprintf( fmpointdir, sizeof( fmpointdir ), param );
|
|||
|
log( "ׯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",fmpointdir );
|
|||
|
} else if( strcmp( command, "fmsmemodir" ) == 0 ){
|
|||
|
snprintf( fmsmemodir, sizeof( fmsmemodir ), param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>屸<EFBFBD><EFBFBD>:%s\n",fmsmemodir );
|
|||
|
#endif
|
|||
|
#ifdef _LOCK_SERVER
|
|||
|
} else if( strcmp( command, "SANAME" ) == 0 ){
|
|||
|
snprintf( SaName, sizeof( SaName ), param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>屸<EFBFBD><EFBFBD>:%s\n",SaName );
|
|||
|
} else if( strcmp( command, "LSADDRESS" ) == 0 ){
|
|||
|
snprintf( LSADDRESS, sizeof( LSADDRESS ), param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ַ:%s\n",LSADDRESS );
|
|||
|
} else if( strcmp( command, "LSPORT" ) == 0 ){//TESTNAME
|
|||
|
LSPORT = atoi( param);
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˿<EFBFBD>:%d\n",LSPORT );
|
|||
|
} else if( strcmp( command, "TESTNAME" ) == 0 ){
|
|||
|
snprintf( TESTNAME, sizeof( TESTNAME ), param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n",TESTNAME );
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _OACSTRUCT_TCP
|
|||
|
} else if( strcmp( command, "OACBIND" ) == 0 ){
|
|||
|
OACbindtype = atoi( param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD>:%d\n",OACbindtype );
|
|||
|
#endif
|
|||
|
|
|||
|
} else if( strcmp( command, "saacname" ) == 0 ){ // <20><>ϵ<EFBFBD><CFB5>
|
|||
|
snprintf( saacname, sizeof( saacname ), param );
|
|||
|
log( "saac<EFBFBD><EFBFBD>:%s\n",saacname );
|
|||
|
} else if( strcmp( command , "Total_Charlist" ) == 0 ){
|
|||
|
Total_Charlist = atoi( param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d\n",Total_Charlist );
|
|||
|
} else if( strcmp( command , "Expired_mail" ) == 0 ){
|
|||
|
Expired_mail = atoi( param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>½<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d\n",Expired_mail );
|
|||
|
} else if( strcmp( command , "Del_Family_or_Member" ) == 0 ){
|
|||
|
Del_Family_or_Member = atoi( param );
|
|||
|
log( "ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ա<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d\n",Del_Family_or_Member );
|
|||
|
} else if( strcmp( command , "Write_Family" ) == 0 ){
|
|||
|
Write_Family = atoi( param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d\n",Write_Family );
|
|||
|
#ifdef _NEW_PLAYERGOLD
|
|||
|
} else if( strcmp( command , "NEW_PLAYERGOLD" ) == 0 ){
|
|||
|
New_PlayerGold = atoi( param );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>ʺŸ<EFBFBD>Ǯ:%d\n",New_PlayerGold );
|
|||
|
#endif
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
fclose(fp);
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
static void parseOpts( int argc, char **argv )
|
|||
|
{
|
|||
|
int c , option_index;
|
|||
|
|
|||
|
while(1){
|
|||
|
static struct option long_options[] = {
|
|||
|
{"wkport" , 1 , 0 , 'w'},
|
|||
|
{"help" , 0 , 0 , 'h' },
|
|||
|
{0,0,0,0}
|
|||
|
};
|
|||
|
c = getopt_long( argc , argv , "w:h" , long_options , &option_index );
|
|||
|
if( c == -1 )break;
|
|||
|
switch( c ){
|
|||
|
case 'h':
|
|||
|
fprintf( stderr ,
|
|||
|
"ʹ<EFBFBD>÷<EFBFBD><EFBFBD><EFBFBD>: saac [-h] [-w port] [-w port] ... \n"
|
|||
|
"-h : <20><>ʾsaac<61>İ<EFBFBD><C4B0><EFBFBD>\n"
|
|||
|
"-w port : <20><><EFBFBD><EFBFBD>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD>վ<EFBFBD><D5BE><EFBFBD>̶˿<CCB6>\n"
|
|||
|
"Copyright 2006 <20><>zoro<72><6F><EFBFBD><EFBFBD><EFBFBD><EFBFBD> "
|
|||
|
"( Longzoro System Supply )\n");
|
|||
|
exit(0);
|
|||
|
break;
|
|||
|
case 'w':
|
|||
|
wknum ++;
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>ӹ<EFBFBD><EFBFBD><EFBFBD>վ<EFBFBD>˿<EFBFBD> %d\n", atoi ( optarg ));
|
|||
|
addWorkerPort( atoi( optarg ));
|
|||
|
#endif
|
|||
|
break;
|
|||
|
default:
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>ܶ<EFBFBD><EFBFBD><EFBFBD>ѡ<EFBFBD><EFBFBD> %c\n" , c );
|
|||
|
exit(0);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
double
|
|||
|
time_diff(struct timeval subtrahend,
|
|||
|
struct timeval subtractor);
|
|||
|
int main( int argc , char **argv )
|
|||
|
{
|
|||
|
|
|||
|
// Nuke +1 1012: Loop counter
|
|||
|
int counter = 0;
|
|||
|
|
|||
|
signal(SIGUSR1, sigusr1);
|
|||
|
|
|||
|
log_rotate_interval = 3600 * 24 * 7;
|
|||
|
|
|||
|
Lock_Init(); // Arminius 7.17 memory lock
|
|||
|
|
|||
|
#ifdef _SASQL1
|
|||
|
sasql_init();
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _SASQL
|
|||
|
sasql_init();
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _UNLOCKPOOL
|
|||
|
init_UnlockPool();
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _LOCK_SERVER
|
|||
|
LServerInit();
|
|||
|
#endif
|
|||
|
#ifdef _PAUCTION_MAN
|
|||
|
IAData_Init();
|
|||
|
#endif
|
|||
|
#ifdef _NEW_PLAYERGOLD
|
|||
|
NEWPLAYER_FreeGoldInit();
|
|||
|
#endif
|
|||
|
#ifdef _UNIVERSE_CHATROOM
|
|||
|
CHATROOM_Init();
|
|||
|
#endif
|
|||
|
UNlockM_Init();
|
|||
|
initWorkerPort();
|
|||
|
parseOpts( argc, argv );
|
|||
|
if(readConfig( "acserv.cf" )<0){
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>ڵ<EFBFBD>ǰĿ¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȡ acserv.cf .\n" );
|
|||
|
exit(1);
|
|||
|
}
|
|||
|
|
|||
|
#ifdef _DEATH_CONTEND
|
|||
|
if( PKLIST_InitPkTeamList( 2000 ) == -1 ) exit(1);
|
|||
|
|
|||
|
if( PKLIST_LoadUserfromFile( "pklist", "user1.txt" ) != -1 ){
|
|||
|
PKLIST_CutStartUserfromFile( "pklist", "d.txt" );
|
|||
|
}
|
|||
|
|
|||
|
if( PKLIST_LoadPkTeamListfromFile( "pklist", "pk_list_team.txt" ) == - 1 ) exit(1);
|
|||
|
|
|||
|
|
|||
|
PKLIST_alteUserfromFile( "pklist", "alteuser.txt");
|
|||
|
PKLIST_CheckRepeatBattleHistory();
|
|||
|
PKLIST_Sort_PKListSort();
|
|||
|
|
|||
|
|
|||
|
PKLIST_CheckAllUser();
|
|||
|
PKLIST_BackupPkTeamListfromFile( "pklist", "pk_list_team.txt" );
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
|
|||
|
log( "<EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ŀ¼\n" );
|
|||
|
dbRead( dbdir );
|
|||
|
#ifdef _DEFEND_NEWUSERS
|
|||
|
DEFEND_InitList();
|
|||
|
#endif
|
|||
|
#ifdef __FAMILY
|
|||
|
log("<EFBFBD><EFBFBD>ȡ <20><><EFBFBD><EFBFBD>ׯ\n");
|
|||
|
readFMSMemo(fmsmemodir);
|
|||
|
log("<EFBFBD><EFBFBD>ȡ <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>\n");
|
|||
|
readFMPoint(fmpointdir);
|
|||
|
log("<EFBFBD><EFBFBD>ȡ <20><><EFBFBD><EFBFBD>Ŀ¼\n");
|
|||
|
readFamily(familydir);
|
|||
|
#endif
|
|||
|
log( "<EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>Ŀ¼\n" );
|
|||
|
prepareDirectories( chardir );
|
|||
|
log( "<EFBFBD><EFBFBD> <20><>־Ŀ¼\n" );
|
|||
|
prepareDirectories( logdir );
|
|||
|
log( "<EFBFBD><EFBFBD> <20><><EFBFBD><EFBFBD>Ŀ¼\n");
|
|||
|
prepareDirectories( lockdir );
|
|||
|
log( "<EFBFBD><EFBFBD> <20>ʼ<EFBFBD>Ŀ¼\n" );
|
|||
|
prepareDirectories( maildir );
|
|||
|
|
|||
|
#ifdef _SLEEP_CHAR
|
|||
|
prepareDirectories( sleepchardir );
|
|||
|
log( "<EFBFBD><EFBFBD> ˯<>ߵ<EFBFBD><DFB5><EFBFBD>Ŀ¼\n" );
|
|||
|
#endif
|
|||
|
|
|||
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>Ȼ<EFBFBD><C8BB>¶<EFBFBD><C2B6><EFBFBD><EFBFBD><EFBFBD>ë <20>ij<EFBFBD><C4B3><EFBFBD> */
|
|||
|
if( readMail(maildir) < 0 ){
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>ܳ<EFBFBD>ʼ<EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD>\n" );
|
|||
|
exit(1);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
/* TCPSTRUCT ë<><C3AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
{
|
|||
|
int tcpr;
|
|||
|
if( ( tcpr = tcpstruct_init( NULL , port , 0 ,
|
|||
|
CHARDATASIZE * 16 * MAXCONNECTION , 1 /* DEBUG */ ) ) < 0 ){
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD>ܿ<EFBFBD><EFBFBD><EFBFBD>TCP: %d\n", tcpr );
|
|||
|
return 1;
|
|||
|
}
|
|||
|
}
|
|||
|
saacproto_InitServer( netWrite , CHARDATASIZE );
|
|||
|
connectToWorker();
|
|||
|
|
|||
|
#ifdef _OACSTRUCT_TCP
|
|||
|
{
|
|||
|
int ret;
|
|||
|
if( (ret=OAC_InitTcpIp( OACbindtype, NULL, 0)) != OK ){
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>TCP/ID<49><44><EFBFBD><EFBFBD>:%d\n", ret );
|
|||
|
return 1;
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _LOCK_SERVER
|
|||
|
if( connectToLServer( LSADDRESS, LSPORT) == FALSE ) {
|
|||
|
log("%s", "<EFBFBD><EFBFBD>½<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD><EFBFBD>!!\n");
|
|||
|
return 1;
|
|||
|
}else {
|
|||
|
log("%s", "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ɹ<EFBFBD>!!");
|
|||
|
usleep( 100*10000);
|
|||
|
LServer_SALogin_send();
|
|||
|
}
|
|||
|
#endif
|
|||
|
{
|
|||
|
struct sigaction s,os;
|
|||
|
|
|||
|
bzero( &s, sizeof(s));
|
|||
|
s.sa_handler = sighandle;
|
|||
|
s.sa_flags = SA_NOMASK;
|
|||
|
sigaction( SIGTERM, &s, &os );
|
|||
|
|
|||
|
bzero( &s, sizeof(s));
|
|||
|
s.sa_handler = sighandle;
|
|||
|
s.sa_flags = SA_NOMASK;
|
|||
|
sigaction( SIGINT, &s, &os );
|
|||
|
|
|||
|
bzero( &s, sizeof( s ));
|
|||
|
s.sa_handler = SIG_IGN;
|
|||
|
s.sa_flags = SA_NOMASK;
|
|||
|
sigaction( SIGPIPE, &s, &os );
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
#ifdef _BAD_PLAYER // WON ADD <20>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD><EFBFBD>ȥ<EFBFBD><C8A5>
|
|||
|
log("\n <20><><EFBFBD><EFBFBD><EFBFBD>ͻ<EFBFBD><CDBB><EFBFBD><EFBFBD>ҽ<EFBFBD><D2BD><EFBFBD><EFBFBD><EFBFBD>!!");
|
|||
|
BadPlayer();
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _AC_SEND_FM_PK // WON ADD ׯ<D7AF><D4B0>ս<EFBFBD>б<EFBFBD><D0B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>AC
|
|||
|
load_fm_pk_list();
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _ACFMPK_LIST
|
|||
|
FMPK_LoadList();
|
|||
|
#endif
|
|||
|
#ifdef _ALLDOMAN
|
|||
|
LOAD_herolist(); // Syu ADD <20><><EFBFBD>а<EFBFBD>NPC
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _ANGEL_SUMMON
|
|||
|
initMissionTable();
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _RACEMAN
|
|||
|
initRankTable();
|
|||
|
#endif
|
|||
|
|
|||
|
log( "\n<EFBFBD>汾<EFBFBD><EFBFBD><EFBFBD><EFBFBD>zoro<EFBFBD><EFBFBD>SAAC<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>v1.1\n" );
|
|||
|
|
|||
|
log( "\n<EFBFBD><EFBFBD>ʼѭ<EFBFBD><EFBFBD>\n" );
|
|||
|
|
|||
|
signal(SIGUSR1,sigusr1); // Arminius 7.20 memory lock
|
|||
|
#ifdef _CHANGEGALAXY
|
|||
|
signal(SIGUSR2, sighandle); // Robin 2003/10/27 <20><>ϵ<EFBFBD><CFB5><EFBFBD><EFBFBD>
|
|||
|
#endif
|
|||
|
while(1){
|
|||
|
int newti,i;
|
|||
|
static time_t main_loop_time;
|
|||
|
|
|||
|
#if 1
|
|||
|
sys_time = time(NULL);
|
|||
|
|
|||
|
if( main_loop_time != sys_time){
|
|||
|
#else
|
|||
|
if( main_loop_time != time(NULL)){
|
|||
|
#endif
|
|||
|
main_loop_time = time(NULL);
|
|||
|
counter++;
|
|||
|
//andy add 2002/06/20
|
|||
|
UNlockM_UnlockPlayer();
|
|||
|
|
|||
|
#ifdef _ANGEL_SUMMON
|
|||
|
checkMissionTimelimit();
|
|||
|
#endif
|
|||
|
#ifdef _UNLOCKPOOL
|
|||
|
UnlockPoolProc();
|
|||
|
#endif
|
|||
|
|
|||
|
// Nuke *1 1012
|
|||
|
if( ( counter % Total_Charlist ) == 0 ){
|
|||
|
char *c = ctime( &main_loop_time );
|
|||
|
if( c ){
|
|||
|
struct timeval st,et;
|
|||
|
log( "\nTIME:%s\n",c );
|
|||
|
gettimeofday( &st,NULL);
|
|||
|
dbFlush(dbdir);
|
|||
|
gettimeofday( &et,NULL);
|
|||
|
log( "Flushed db(%fsec)\n", time_diff(et,st) );
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d NG:%d\n",
|
|||
|
total_ok_charlist, total_ng_charlist );
|
|||
|
}
|
|||
|
}
|
|||
|
// Nuke **1 1012
|
|||
|
if( ( counter % 600 ) == 0 ){
|
|||
|
struct timeval st,et;
|
|||
|
gettimeofday( &st,NULL);
|
|||
|
expireMail();
|
|||
|
gettimeofday( &et,NULL);
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʼ<EFBFBD>(%fsec)\n", time_diff(et,st) );
|
|||
|
}
|
|||
|
#ifdef _NEW_PLAYERGOLD
|
|||
|
if( ( counter % 300 ) == 0 ){
|
|||
|
backupNEWPlayerListFile( "newuser.txt", "newuser.bak");
|
|||
|
}
|
|||
|
#endif
|
|||
|
#ifdef __FAMILY
|
|||
|
|
|||
|
#ifndef _DEATH_FAMILY_LOGIN_CHECK // WON ADD <20><><EFBFBD><EFBFBD>ս<EFBFBD><D5BD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
if ((counter % /*10800*/600) == 0) // 3hr( -> 1min)
|
|||
|
{
|
|||
|
struct timeval st, et;
|
|||
|
time_t t1;
|
|||
|
gettimeofday(&st, NULL);
|
|||
|
time(&t1);
|
|||
|
delovertimeFMMem(t1);
|
|||
|
gettimeofday(&et, NULL);
|
|||
|
log("ɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ա(%fsec)\n", time_diff(et, st));
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
if ((counter % 300) == 0) // 300( -> 60)
|
|||
|
{
|
|||
|
struct timeval st, et;
|
|||
|
gettimeofday(&st, NULL);
|
|||
|
writeFamily(familydir);
|
|||
|
writeFMPoint(fmpointdir);
|
|||
|
writeFMSMemo(fmsmemodir);
|
|||
|
gettimeofday(&et, NULL);
|
|||
|
log("<EFBFBD><EFBFBD>¼<EFBFBD><EFBFBD><EFBFBD><EFBFBD>(%fsec)\n", time_diff(et, st));
|
|||
|
}
|
|||
|
#endif
|
|||
|
}
|
|||
|
|
|||
|
#ifdef _OACSTRUCT_TCP
|
|||
|
OAC_select();
|
|||
|
OAC_ReadMessLine();
|
|||
|
#endif
|
|||
|
|
|||
|
newti = tcpstruct_accept1();
|
|||
|
if( newti >= 0 ){
|
|||
|
log( "ͬ<EFBFBD><EFBFBD>: %d\n" , newti );
|
|||
|
gs[newti].use = 1;
|
|||
|
}
|
|||
|
|
|||
|
#ifdef _LOCK_SERVER
|
|||
|
{
|
|||
|
int mlen;
|
|||
|
char buf[4096];
|
|||
|
if( CHECK_LS_BEUSE() == TRUE ) {
|
|||
|
TcpIp_LS_accept();
|
|||
|
|
|||
|
}
|
|||
|
//Show_LS_MEMBufferList();
|
|||
|
|
|||
|
mlen = MMGet_LsReadBuflist( buf, sizeof( buf));
|
|||
|
if( mlen > 0 ) {
|
|||
|
if( lockproto_SaacDispatchMessage( buf) < 0 ) {
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ϣ:%s", buf);
|
|||
|
}
|
|||
|
}
|
|||
|
CHECK_LSTYPE();
|
|||
|
#ifdef _TEST_LOCKSERVER
|
|||
|
TEST_TOLOCKSERVER();
|
|||
|
#endif
|
|||
|
}
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _FIX_WORKS
|
|||
|
{
|
|||
|
int wkti=-1;
|
|||
|
int tis[BACKLOGNUM];
|
|||
|
newti = tcpstruct_work_accept( tis , 1);
|
|||
|
if( newti == 1 ) {
|
|||
|
log( "ͬ<EFBFBD><EFBFBD><EFBFBD>վ: %d\n" , newti );
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
for( i=0; i<MAXWORKCONNECTION; i++){
|
|||
|
// char buf6[CHARDATASIZE*16];
|
|||
|
char buf6[256];
|
|||
|
|
|||
|
if( MEMBuffer_getWkLineReadBuffer( i, buf6, sizeof(buf6), WK_R) <= 0 ){
|
|||
|
continue;
|
|||
|
}
|
|||
|
wkti = i;
|
|||
|
//#ifndef _TIMEOUTKICK
|
|||
|
{
|
|||
|
int j;
|
|||
|
for( j=0;; j++) {
|
|||
|
if( buf6[j] == '\n' ) buf6[j]= 0;
|
|||
|
if( buf6[j] == 0 )break;
|
|||
|
}
|
|||
|
}
|
|||
|
//#endif
|
|||
|
doWorker( wkti, buf6 );
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
for(i=0;i<MAXCONNECTION;i++){
|
|||
|
char buf[CHARDATASIZE*16];
|
|||
|
int l;
|
|||
|
l = tcpstruct_readline_chop( i , buf , sizeof( buf )- 1);
|
|||
|
if( isWorker( i ) ){
|
|||
|
#ifndef _FIX_WORKS
|
|||
|
if( l > 0 ){
|
|||
|
doWorker( i , buf );
|
|||
|
} else if( l == TCPSTRUCT_ETOOLONG || l < 0 ){
|
|||
|
checkWorkerClosed( i );
|
|||
|
tcpstruct_close( i );
|
|||
|
} else if( l == 0 ){
|
|||
|
;
|
|||
|
}
|
|||
|
#endif
|
|||
|
} else {
|
|||
|
if( !gs[i].use )continue;
|
|||
|
if( l > 0 ){
|
|||
|
char debugfun[256];
|
|||
|
buf[l]=0;
|
|||
|
if( saacproto_ServerDispatchMessage( i , buf, debugfun)<0){
|
|||
|
// Nuke start
|
|||
|
tcpstruct_close(i);// avoid the shutdown the gmsv ttom
|
|||
|
log( "GMSV(%s) <20><>Ϣ:%s\n", gs[i].name, debugfun);
|
|||
|
}
|
|||
|
} else if( l == TCPSTRUCT_ETOOLONG ){
|
|||
|
log( "<EFBFBD>ܳ<EFBFBD>:%d <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>::%s\n", i , gs[i].name );
|
|||
|
|
|||
|
#ifdef _AC_UNLOCK_GS_PLAYER // WON ADD <20>Զ<EFBFBD>UNLOCK
|
|||
|
DeleteMemLockServer(gs[i].name);
|
|||
|
log("\n<EFBFBD>û<EFBFBD>(%s) <20>dz<EFBFBD>! <20><><EFBFBD>ҽ<EFBFBD><D2BD><EFBFBD>!!\n", gs[i].name );
|
|||
|
#endif
|
|||
|
logout_game_server( i );
|
|||
|
} else if( l < 0 ){
|
|||
|
log( "<EFBFBD>ر<EFBFBD>:%d <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%s\n", i , gs[i].name );
|
|||
|
#ifdef _UNIVERSE_CHATROOM
|
|||
|
CHATROOM_GSClosedHandle( i);
|
|||
|
#endif
|
|||
|
#ifdef _AC_UNLOCK_GS_PLAYER // WON ADD <20>Զ<EFBFBD>UNLOCK
|
|||
|
DeleteMemLockServer(gs[i].name);
|
|||
|
log("\n<EFBFBD>û<EFBFBD>(%s) <20>dz<EFBFBD>! <20><><EFBFBD>ҽ<EFBFBD><D2BD><EFBFBD>!!\n", gs[i].name );
|
|||
|
#endif
|
|||
|
|
|||
|
|
|||
|
#ifdef _WORKER_AUTO_LOGOUT // WON ADD GS<47><53><EFBFBD><EFBFBD><EFBFBD>Զ<EFBFBD><D4B6><EFBFBD>LOGOUT<55><54>WORKER
|
|||
|
Worker_auto_logout( i, gs[i].name );
|
|||
|
#endif
|
|||
|
logout_game_server(i);
|
|||
|
} else if( l == 0 ){
|
|||
|
;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
{
|
|||
|
static struct timeval tv_loop_store ;
|
|||
|
struct timeval now;
|
|||
|
double dif;
|
|||
|
gettimeofday( &now , NULL );
|
|||
|
dif = time_diff( now, tv_loop_store );
|
|||
|
if( dif > 0.5 ){ // CoolFish 0.1 -> 0.5 2001/5/19
|
|||
|
//log( "Sl:%f" , dif );
|
|||
|
}
|
|||
|
tv_loop_store = now;
|
|||
|
}
|
|||
|
|
|||
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>С<EFBFBD><D0A1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ةʧ<D8A9><CAA7><EFBFBD><EFBFBD>ëƩ<C3AB><C6A9><EFBFBD>£<EFBFBD>
|
|||
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ةʧ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>շ<EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>С<EFBFBD>ëڽ<EFBFBD>ƻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
ƥ<EFBFBD>ء<EFBFBD>ة<EFBFBD>ӡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD>ζ<EFBFBD><EFBFBD>巴ɧ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
{
|
|||
|
int i;
|
|||
|
time_t thre = time(NULL) - WKTIMEOUT;
|
|||
|
for(i =0;i<MAXWK;i++){
|
|||
|
if( !wk[i].use )continue;
|
|||
|
if( wk[i].last_query &&
|
|||
|
wk[i].status == WKSTAT_WAITING &&
|
|||
|
wk[i].last_query < thre ){
|
|||
|
// Nuke start--
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>վ %d <20><>ʱ! <20>ر<EFBFBD><D8B1><EFBFBD>...\n", i );
|
|||
|
#ifdef _FIX_WORKS
|
|||
|
Work_close( wk[i].ti );
|
|||
|
wk[i].use = 0;
|
|||
|
wk[i].fd = -1;
|
|||
|
wk[i].status = WKSTAT_IDLE;
|
|||
|
#else
|
|||
|
tcpstruct_close( wk[i].ti );
|
|||
|
#endif
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>վ %d <20><>ʱ! uhmmm...\n", i);
|
|||
|
|
|||
|
if( wk[i].callback ){
|
|||
|
// Robin log
|
|||
|
//log(" wk[%d] c0:%s c1:%s c2:%s c3:%s c4:%s i0:%d i1:%d ",
|
|||
|
// wk[i].request_ti, wk[i].cparam[0], wk[i].cparam[1],
|
|||
|
// wk[i].cparam[2], wk[i].cparam[3], wk[i].cparam[4],
|
|||
|
// wk[i].iparam[0], wk[i].iparam[1]);
|
|||
|
|
|||
|
wk[i].callback( wk[i].request_ti , -1,
|
|||
|
wk[i].cparam[0] ,
|
|||
|
wk[i].cparam[1] ,
|
|||
|
wk[i].cparam[2] ,
|
|||
|
wk[i].cparam[3] ,
|
|||
|
wk[i].cparam[4] ,
|
|||
|
wk[i].iparam[0] ,
|
|||
|
wk[i].iparam[1] );
|
|||
|
wk[i].use = 0;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
#ifdef _SASQL
|
|||
|
sasql_close();
|
|||
|
#endif
|
|||
|
|
|||
|
return 0;
|
|||
|
}
|
|||
|
double
|
|||
|
time_diff(struct timeval subtrahend,
|
|||
|
struct timeval subtractor)
|
|||
|
{
|
|||
|
return( (subtrahend.tv_sec - subtractor.tv_sec)
|
|||
|
+ (subtrahend.tv_usec
|
|||
|
- subtractor.tv_usec ) / (double)1E6 );
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
/*
|
|||
|
<EFBFBD><EFBFBD><EFBFBD>뼰<EFBFBD><EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë <EFBFBD>£<EFBFBD>
|
|||
|
<EFBFBD><EFBFBD>ئԪ<EFBFBD><EFBFBD><EFBFBD>弰<EFBFBD>ּ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ͻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>̻ﻥ<EFBFBD><EFBFBD>ئԪ<EFBFBD><EFBFBD>ئ<EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>£<EFBFBD>
|
|||
|
|
|||
|
<EFBFBD><EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD>ٯ<EFBFBD><EFBFBD>覻<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>»<EFBFBD><EFBFBD><EFBFBD> ƥ<EFBFBD>̼<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë <EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><EFBFBD><EFBFBD>
|
|||
|
<EFBFBD><EFBFBD>ᨷ֣<EFBFBD>
|
|||
|
|
|||
|
*/
|
|||
|
int get_rotate_count(void )
|
|||
|
{
|
|||
|
int a;
|
|||
|
unsigned int t = (unsigned int ) time(NULL);
|
|||
|
|
|||
|
a = ( t / log_rotate_interval ) * log_rotate_interval;
|
|||
|
|
|||
|
return a;
|
|||
|
}
|
|||
|
|
|||
|
static int findregBlankMemBuf( void );
|
|||
|
static int unregMemBuf( int index );
|
|||
|
static int findregBlankCon( void );
|
|||
|
static int getFreeMem( void );
|
|||
|
|
|||
|
static int appendReadBuffer( int index, char *data, int len );
|
|||
|
static int appendWriteBuffer( int index , char *data, int len );
|
|||
|
static int appendMemBufList( int top, char *data, int len );
|
|||
|
static int consumeMemBufList( int top, char *out, int len, int flag, int copyflag );
|
|||
|
static int getLineReadBuffer( int index, char *buf, int len );
|
|||
|
|
|||
|
int tcpstruct_init( char *addr , int p , int timeout_ms , int mem_use , int db )
|
|||
|
{
|
|||
|
mbsize = mem_use / sizeof( struct membuf );
|
|||
|
mbuse =0;
|
|||
|
mb_finder = 0;
|
|||
|
mb = ( struct membuf * ) calloc( 1, mbsize * sizeof(struct membuf ));
|
|||
|
|
|||
|
if( mb == NULL ) return TCPSTRUCT_ENOMEM;
|
|||
|
bzero( mb , mbsize * sizeof( struct membuf ));
|
|||
|
|
|||
|
con = ( struct connection *) calloc( 1, MAXCONNECTION * sizeof( struct connection ));
|
|||
|
if( con == NULL ){
|
|||
|
free( mb );
|
|||
|
return TCPSTRUCT_ENOMEM;
|
|||
|
} else {
|
|||
|
int i;
|
|||
|
for(i=0;i<MAXCONNECTION;i++){
|
|||
|
con[i].use = 0;
|
|||
|
con[i].fd = -1;
|
|||
|
}
|
|||
|
}
|
|||
|
select_timeout.tv_sec = timeout_ms / 1000;
|
|||
|
select_timeout.tv_usec = (timeout_ms - ( timeout_ms/1000)*1000)*1000;
|
|||
|
|
|||
|
/* socket */
|
|||
|
mainsockfd = socket( AF_INET , SOCK_STREAM , 0 );
|
|||
|
if( mainsockfd < 0 ) return TCPSTRUCT_ESOCK;
|
|||
|
|
|||
|
/* bind */
|
|||
|
bzero( &localaddr ,sizeof( localaddr ));
|
|||
|
localaddr.sin_family = AF_INET;
|
|||
|
localaddr.sin_port = htons( p );
|
|||
|
|
|||
|
if( addr ){
|
|||
|
localaddr.sin_addr.s_addr = inet_addr( addr );
|
|||
|
} else {
|
|||
|
localaddr.sin_addr.s_addr = htonl( INADDR_ANY );
|
|||
|
}
|
|||
|
if( bind( mainsockfd , (struct sockaddr*) &localaddr ,
|
|||
|
sizeof( localaddr )) < 0 ) return TCPSTRUCT_EBIND;
|
|||
|
|
|||
|
/* listen */
|
|||
|
if( listen( mainsockfd , BACKLOGNUM )<0) return TCPSTRUCT_ELISTEN;
|
|||
|
|
|||
|
#ifdef _FIX_WORKS //for work
|
|||
|
MEMBuffer_Init();
|
|||
|
if( SetWorkConnectionInit( 1) <= 0 )
|
|||
|
return TCPSTRUCT_WORKERROR;
|
|||
|
|
|||
|
worksockfd = socket( AF_INET , SOCK_STREAM , 0 );
|
|||
|
log( "<EFBFBD><EFBFBD>ʼ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>: %d...\n" , worksockfd);
|
|||
|
if( worksockfd < 0 ) return TCPSTRUCT_ESOCK;
|
|||
|
bzero( &localaddr ,sizeof( localaddr ));
|
|||
|
localaddr.sin_family = AF_INET;
|
|||
|
localaddr.sin_port = htons( FORWORKPORT );
|
|||
|
localaddr.sin_addr.s_addr = /*htonl( INADDR_ANY );*/inet_addr( "127.0.0.1" );
|
|||
|
if( bind( worksockfd , (struct sockaddr*) &localaddr ,
|
|||
|
sizeof( localaddr )) < 0 ) return TCPSTRUCT_WORKEBIND;
|
|||
|
if( listen( worksockfd , BACKLOGNUM )<0) return TCPSTRUCT_ELISTEN;
|
|||
|
#endif
|
|||
|
return OK;
|
|||
|
}
|
|||
|
|
|||
|
int tcpstruct_accept1( void )
|
|||
|
{
|
|||
|
int tis[BACKLOGNUM];
|
|||
|
int ret;
|
|||
|
|
|||
|
ret = tcpstruct_accept( tis , 1 );
|
|||
|
if( ret < 0 ){
|
|||
|
return ret;
|
|||
|
} else if( ret == 1 ){
|
|||
|
return tis[0];
|
|||
|
} else {
|
|||
|
return TCPSTRUCT_EBUG ;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
int tcpstruct_accept( int *tis , int ticount )
|
|||
|
{
|
|||
|
int i;
|
|||
|
int sret;
|
|||
|
int accepted = 0;
|
|||
|
struct timeval t;
|
|||
|
fd_set rfds, wfds , efds;
|
|||
|
FD_ZERO( & rfds );
|
|||
|
FD_ZERO( & wfds );
|
|||
|
FD_ZERO( & efds );
|
|||
|
|
|||
|
for(i=0;i<MAXCONNECTION;i++){
|
|||
|
if( con[i].use &&
|
|||
|
con[i].fd >= 0 && con[i].closed_by_remote ==0 ){
|
|||
|
FD_SET( con[i].fd , & rfds );
|
|||
|
FD_SET( con[i].fd , & wfds );
|
|||
|
FD_SET( con[i].fd , & efds );
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
t = select_timeout;
|
|||
|
sret = select( 1024, & rfds , (fd_set*)NULL, & efds , &t);
|
|||
|
if( sret > 0 ) {
|
|||
|
for(i=0;i< MAXCONNECTION;i++){
|
|||
|
if( ( con[i].fd >= 0 ) && FD_ISSET( con[i].fd , &rfds ) ){
|
|||
|
int fr = getFreeMem( );
|
|||
|
int rr , readsize ;
|
|||
|
if( fr <= 0 ) continue;
|
|||
|
if( fr > sizeof(tmpbuf ) ){
|
|||
|
readsize = sizeof( tmpbuf);
|
|||
|
} else {
|
|||
|
readsize = fr;
|
|||
|
}
|
|||
|
rr = read( con[i].fd , tmpbuf , readsize );
|
|||
|
if( rr <= 0 ){
|
|||
|
con[i].closed_by_remote = 1;
|
|||
|
} else {
|
|||
|
appendReadBuffer( i , tmpbuf , rr );
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
/* write */
|
|||
|
t = select_timeout;
|
|||
|
sret = select( 1024, (fd_set*)NULL, &wfds, & efds , &t);
|
|||
|
if( sret > 0 ) {
|
|||
|
for(i=0;i<MAXCONNECTION;i++){
|
|||
|
if( ( con[i].fd >= 0 ) && FD_ISSET( con[i].fd , &wfds )){
|
|||
|
char send_buf[4096];
|
|||
|
int l , rr;
|
|||
|
memset( send_buf, 0, sizeof( send_buf));
|
|||
|
l = consumeMemBufList( con[i].mbtop_wi ,send_buf, sizeof(send_buf),0 , 1 );
|
|||
|
rr = write( con[i].fd , send_buf , l );
|
|||
|
if( rr < 0 ){
|
|||
|
con[i].closed_by_remote = 1;
|
|||
|
} else {
|
|||
|
consumeMemBufList( con[i].mbtop_wi , send_buf, l, 1 , 0 );
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
for( i=0; i<ticount; i++){
|
|||
|
int asret;
|
|||
|
struct timeval t;
|
|||
|
t.tv_sec =0;
|
|||
|
t.tv_usec =0;
|
|||
|
FD_ZERO( & rfds );
|
|||
|
FD_ZERO( & wfds );
|
|||
|
FD_ZERO( & efds );
|
|||
|
|
|||
|
FD_SET( mainsockfd , & rfds );
|
|||
|
FD_SET( mainsockfd , & wfds );
|
|||
|
FD_SET( mainsockfd , & efds );
|
|||
|
asret = select( 1024, &rfds , &wfds , &efds, &t );
|
|||
|
// Nuke 20040610: add asret>0 to avoid signal interrupt in select
|
|||
|
if( (asret>0) && FD_ISSET( mainsockfd , & rfds )){
|
|||
|
struct sockaddr_in c;
|
|||
|
int len , newsockfd;
|
|||
|
int newcon;
|
|||
|
bzero( &c , sizeof( c ));
|
|||
|
len = sizeof( c );
|
|||
|
fprintf( stderr, "i can accept " );
|
|||
|
newcon = findregBlankCon( );
|
|||
|
if( newcon < 0 ) continue;
|
|||
|
newsockfd = accept( mainsockfd, (struct sockaddr*)&c , &len );
|
|||
|
log( "ͬ<EFBFBD><EFBFBD>: %d\n" , newsockfd );
|
|||
|
if( newsockfd < 0 ){
|
|||
|
unregMemBuf( newcon );
|
|||
|
continue;
|
|||
|
}
|
|||
|
set_nodelay( newsockfd );
|
|||
|
con[newcon].fd = newsockfd;
|
|||
|
memcpy( &con[newcon].remoteaddr , &c ,sizeof(c));
|
|||
|
tis[accepted] = newcon;
|
|||
|
accepted ++;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return accepted;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
int tcpstruct_close( int ti )
|
|||
|
{
|
|||
|
|
|||
|
if( ti < 0 || ti >= MAXCONNECTION )return TCPSTRUCT_EINVCIND;
|
|||
|
if( con[ti].use == 0 ){
|
|||
|
return TCPSTRUCT_ECLOSEAGAIN;
|
|||
|
}
|
|||
|
close( con[ti].fd );
|
|||
|
con[ti].use = 0;
|
|||
|
con[ti].fd = -1;
|
|||
|
|
|||
|
/* <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><C3AB><EFBFBD><EFBFBD><EFBFBD>Ȼ<EFBFBD><C8BB><EFBFBD> ë<><C3AB><EFBFBD><EFBFBD>ʧ<EFBFBD><CAA7><EFBFBD><EFBFBD> */
|
|||
|
consumeMemBufList( con[ti].mbtop_ri , NULL,
|
|||
|
mbsize * sizeof( mb[0].buf ), 1, 0 );
|
|||
|
consumeMemBufList( con[ti].mbtop_wi , NULL,
|
|||
|
mbsize * sizeof( mb[0].buf ), 1, 0 );
|
|||
|
unregMemBuf( con[ti].mbtop_ri );
|
|||
|
unregMemBuf( con[ti].mbtop_wi );
|
|||
|
con[ti].mbtop_ri = -1;
|
|||
|
con[ti].mbtop_wi = -1;
|
|||
|
return OK;
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
<EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ּ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD>ئ<EFBFBD>ʻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƾ<EFBFBD><EFBFBD><EFBFBD> remoteclose <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> -1 ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
|||
|
*/
|
|||
|
int tcpstruct_read( int ti , char *buf , int len )
|
|||
|
{
|
|||
|
int l;
|
|||
|
|
|||
|
if( ti < 0 || ti >= MAXCONNECTION || con[ti].use == 0 )
|
|||
|
return TCPSTRUCT_EINVCIND;
|
|||
|
l = consumeMemBufList( con[ti].mbtop_ri , buf , len , 1 , 1);
|
|||
|
if( l == 0 && con[ti].closed_by_remote ) return TCPSTRUCT_EREADFIN;
|
|||
|
|
|||
|
return l;
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
1<EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
int kend : 1ئ<EFBFBD>յ<EFBFBD> <EFBFBD><EFBFBD> \n ëڽ<EFBFBD><EFBFBD>
|
|||
|
int kend_r : 1ئ<EFBFBD>յ<EFBFBD> <EFBFBD><EFBFBD> \r <EFBFBD><EFBFBD>ڽ<EFBFBD><EFBFBD>(ؤľ<EFBFBD><EFBFBD>)
|
|||
|
|
|||
|
<EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ּ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD>ئ<EFBFBD>ʻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> remote closed <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>-1ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
// Nuke
|
|||
|
Read 1 line
|
|||
|
if kend==1 then delete \n at the tail
|
|||
|
if kend_r== 1 then delete \r at the tail (if any)
|
|||
|
if no data read, it means 'remote closed' then return -1
|
|||
|
*/
|
|||
|
int tcpstruct_readline( int ti , char *buf , int len , int kend , int kend_r )
|
|||
|
{
|
|||
|
int l;
|
|||
|
int minus = 0;
|
|||
|
|
|||
|
if( ti < 0 || ti >= MAXCONNECTION || con[ti].use == 0 )
|
|||
|
return TCPSTRUCT_EINVCIND;
|
|||
|
|
|||
|
l = getLineReadBuffer( ti , buf , len );
|
|||
|
if( l == 0 ){
|
|||
|
if( con[ti].closed_by_remote ){
|
|||
|
return TCPSTRUCT_EREADFIN;
|
|||
|
} else {
|
|||
|
return 0;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if( kend ){
|
|||
|
if( buf[l-1]=='\n' ){
|
|||
|
buf[l-1] = 0; minus =-1;
|
|||
|
}
|
|||
|
}
|
|||
|
if( kend_r ){
|
|||
|
if( buf[l-1]=='\r' ){
|
|||
|
buf[l-1] = 0; minus = -1;
|
|||
|
}
|
|||
|
if( buf[l-2]=='\r' ){
|
|||
|
buf[l-2] = 0; minus = -2;
|
|||
|
}
|
|||
|
}
|
|||
|
return l + minus;
|
|||
|
}
|
|||
|
int tcpstruct_readline_chop( int ti , char *buf, int len )
|
|||
|
{
|
|||
|
return tcpstruct_readline( ti , buf , len , 1,1);
|
|||
|
}
|
|||
|
|
|||
|
int tcpstruct_write( int ti , char *buf , int len )
|
|||
|
{
|
|||
|
if( ti < 0 || ti >= MAXCONNECTION || con[ti].use == 0 )
|
|||
|
return TCPSTRUCT_EINVCIND;
|
|||
|
return appendWriteBuffer( ti , buf , len );
|
|||
|
}
|
|||
|
|
|||
|
int tcpstruct_connect( char *addr , int port )
|
|||
|
{
|
|||
|
int newti ;
|
|||
|
int s, r;
|
|||
|
struct sockaddr_in svaddr;
|
|||
|
struct hostent *he;
|
|||
|
|
|||
|
s = socket( AF_INET, SOCK_STREAM , 0 );
|
|||
|
if(s<0)return -2;
|
|||
|
|
|||
|
bzero( &svaddr , sizeof( svaddr ));
|
|||
|
svaddr.sin_family = AF_INET;
|
|||
|
svaddr.sin_port = htons( port );
|
|||
|
|
|||
|
if( inet_aton( addr, &svaddr.sin_addr ) == 0 ){
|
|||
|
he = gethostbyname( addr );
|
|||
|
if( he == NULL ){
|
|||
|
return TCPSTRUCT_EHOST;
|
|||
|
}
|
|||
|
memcpy( & svaddr.sin_addr.s_addr , he->h_addr ,
|
|||
|
sizeof( struct in_addr));
|
|||
|
}
|
|||
|
r = connect( s , ( struct sockaddr*)&svaddr,sizeof(svaddr));
|
|||
|
if( r < 0 ){
|
|||
|
return TCPSTRUCT_ECONNECT;
|
|||
|
}
|
|||
|
set_nodelay( s );
|
|||
|
newti = findregBlankCon( );
|
|||
|
if( newti < 0 ){
|
|||
|
fprintf( stderr , "<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʧ<EFBFBD><EFBFBD>: newti:%d\n", newti );
|
|||
|
return TCPSTRUCT_ECFULL;
|
|||
|
}
|
|||
|
con[newti].fd = s;
|
|||
|
memcpy( & con[newti].remoteaddr , &svaddr ,
|
|||
|
sizeof( struct sockaddr_in));
|
|||
|
return newti;
|
|||
|
}
|
|||
|
|
|||
|
static int appendReadBuffer( int index , char *data , int len )
|
|||
|
{
|
|||
|
int top;
|
|||
|
|
|||
|
top = con[index].mbtop_ri;
|
|||
|
for(;;){
|
|||
|
int nextind = mb[top].next;
|
|||
|
|
|||
|
if( nextind == -1 ) break;
|
|||
|
top = nextind;
|
|||
|
}
|
|||
|
return appendMemBufList( top , data , len );
|
|||
|
}
|
|||
|
|
|||
|
static int appendWriteBuffer( int index , char *data , int len )
|
|||
|
{
|
|||
|
int top;
|
|||
|
top = con[index].mbtop_wi;
|
|||
|
for(;;){
|
|||
|
int nextind = mb[top].next;
|
|||
|
if( nextind == -1 ) break;
|
|||
|
top = nextind;
|
|||
|
}
|
|||
|
return appendMemBufList( top , data , len );
|
|||
|
}
|
|||
|
static int appendMemBufList( int top , char *data , int len )
|
|||
|
{
|
|||
|
int fr = getFreeMem( );
|
|||
|
int rest = len;
|
|||
|
int data_topaddr = 0;
|
|||
|
|
|||
|
if( len >= fr ){
|
|||
|
FILE *fp;
|
|||
|
if( (fp=fopen( "badsysinfo.txt", "a+")) != NULL ){
|
|||
|
fprintf( fp, "appendMemBufList() len:%d / fr:%d err !! \n", len, fr);
|
|||
|
fclose( fp);
|
|||
|
}
|
|||
|
//andy_log
|
|||
|
log( "appendMemBufList() len:%d / fr:%d err !! \n", len, fr);
|
|||
|
return -1;
|
|||
|
}
|
|||
|
data[len] = 0;
|
|||
|
for(;;){
|
|||
|
int blanksize = sizeof( mb[0].buf ) - mb[top].len;
|
|||
|
int cpsize = ( rest <= blanksize ) ? rest : blanksize;
|
|||
|
memcpy( mb[top].buf + mb[top].len ,
|
|||
|
data + data_topaddr , cpsize );
|
|||
|
mb[top].len += cpsize;
|
|||
|
if( rest <= blanksize ){
|
|||
|
return len;
|
|||
|
} else {
|
|||
|
int newmb;
|
|||
|
rest -= cpsize;
|
|||
|
data_topaddr += cpsize;
|
|||
|
if( (newmb = findregBlankMemBuf( ) ) == TCPSTRUCT_EMBFULL ){
|
|||
|
FILE *fp;
|
|||
|
if( (fp=fopen( "badsysinfo.txt", "a+")) != NULL ){
|
|||
|
fprintf( fp, "find newmb == TCPSTRUCT_EMBFULL err data:%s !!\n", data);
|
|||
|
fclose( fp);
|
|||
|
}
|
|||
|
log( "find newmb == TCPSTRUCT_EMBFULL err data:%s !!\n", data);
|
|||
|
}
|
|||
|
mb[top].next = newmb;
|
|||
|
top = mb[top].next;
|
|||
|
}
|
|||
|
}
|
|||
|
return TCPSTRUCT_EBUG;
|
|||
|
}
|
|||
|
|
|||
|
static int consumeMemBufList( int top , char *out , int len ,
|
|||
|
int consumeflag , int copyflag )
|
|||
|
{
|
|||
|
int total = 0;
|
|||
|
int top_store = top;
|
|||
|
for(;;){
|
|||
|
int cpsize;
|
|||
|
if( top == -1 ) break;
|
|||
|
cpsize = ( mb[top].len <= ( len - total) ) ?
|
|||
|
mb[top].len : ( len - total );
|
|||
|
|
|||
|
if( copyflag ) memcpy( out + total , mb[top].buf , cpsize );
|
|||
|
total += cpsize;
|
|||
|
|
|||
|
if( consumeflag ){
|
|||
|
mb[top].len -= cpsize;
|
|||
|
if( mb[top].len > 0 ){
|
|||
|
/* <20><><EFBFBD><EFBFBD><EFBFBD>з<EFBFBD><D0B7><EFBFBD><EFBFBD>ƻ<EFBFBD>ئ<EFBFBD>м<EFBFBD>ƥmemmove */
|
|||
|
memmove( mb[top].buf , mb[top].buf + cpsize ,
|
|||
|
sizeof( mb[top].buf ) - cpsize );
|
|||
|
}
|
|||
|
}
|
|||
|
top = mb[top].next;
|
|||
|
if( total == len ){
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if( consumeflag ){
|
|||
|
/* ئ<><D8A6><EFBFBD><EFBFBD><EFBFBD><EFBFBD>0<EFBFBD><30>ئ<EFBFBD>Ȼ<EFBFBD><C8BB><EFBFBD>ئ<EFBFBD><D8A6>ݩ <20><>ƥ<EFBFBD><C6A5> <20>ټ<EFBFBD>֧<EFBFBD><D6A7><EFBFBD><EFBFBD>ݩ <20><>ئ<EFBFBD><D8A6><EFBFBD><EFBFBD> */
|
|||
|
top = mb[top_store].next;
|
|||
|
for(;;){
|
|||
|
if( top == -1 )break;
|
|||
|
if( mb[top].len == 0 ){
|
|||
|
int prev;
|
|||
|
mb[top_store].next = mb[top].next;
|
|||
|
prev = top;
|
|||
|
top = mb[top].next;
|
|||
|
unregMemBuf( prev );
|
|||
|
} else {
|
|||
|
top = mb[top].next;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
return total;
|
|||
|
}
|
|||
|
|
|||
|
static int getLineReadBuffer( int index , char *buf, int len )
|
|||
|
{
|
|||
|
|
|||
|
int top = con[index].mbtop_ri;
|
|||
|
int ti = 0 , breakflag = 0;
|
|||
|
|
|||
|
for(;;){
|
|||
|
int i;
|
|||
|
int l = mb[top].len;
|
|||
|
if( top == -1 )break;
|
|||
|
for( i=0 ; i < l ; i++){
|
|||
|
if( mb[top].buf[i] == '\n' ){
|
|||
|
breakflag = 1;
|
|||
|
break;
|
|||
|
}
|
|||
|
ti ++;
|
|||
|
}
|
|||
|
if( breakflag )break;
|
|||
|
top = mb[top].next;
|
|||
|
}
|
|||
|
if( ti > len ){
|
|||
|
/* 1<>滥ئ<E6BBA5><D8A6><EFBFBD>ʿ<EFBFBD><CABF>£<EFBFBD> ئ<>¡<DEB7>ë<EFBFBD><C3AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD> */
|
|||
|
return TCPSTRUCT_ETOOLONG;
|
|||
|
}
|
|||
|
/* <20>滥<EFBFBD><E6BBA5><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD>ئ<EFBFBD><D8A6> */
|
|||
|
if( breakflag == 0 ){
|
|||
|
return 0;
|
|||
|
}
|
|||
|
|
|||
|
return consumeMemBufList( con[index].mbtop_ri , buf , ti+1 , 1 , 1 );
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
/*
|
|||
|
<EFBFBD>ij<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> Ӯ<EFBFBD><EFBFBD>ë߯<EFBFBD><EFBFBD>
|
|||
|
int index : con index
|
|||
|
|
|||
|
return:
|
|||
|
<EFBFBD><EFBFBD><EFBFBD>¡<EFBFBD>
|
|||
|
0<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> read <EFBFBD>ƻ<EFBFBD><EFBFBD>ַ<EFBFBD><EFBFBD><EFBFBD>Ӯ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
|||
|
|
|||
|
mbsize <EFBFBD><EFBFBD><EFBFBD><EFBFBD>mbuse ë¦<EFBFBD>л<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ի<EFBFBD><EFBFBD><EFBFBD>з<EFBFBD> <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>£۹<EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>ƾ<EFBFBD><EFBFBD>а<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ִ<EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD>ʻ<EFBFBD><EFBFBD>ֵڣ<EFBFBD>
|
|||
|
|
|||
|
*/
|
|||
|
static int getFreeMem( void )
|
|||
|
{
|
|||
|
return ( mbsize - mbuse ) * sizeof( mb[0].buf );
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
|
|||
|
membuf <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ë<EFBFBD><EFBFBD><EFBFBD>Ʒ<EFBFBD><EFBFBD>ʣ<EFBFBD>
|
|||
|
|
|||
|
return : <EFBFBD>Ĺ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> >=0 ƥ index.
|
|||
|
<EFBFBD>Ĺ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
|||
|
<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>巴 mb_finder ë<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
<EFBFBD><EFBFBD>ľƥ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ƻ<EFBFBD><EFBFBD><EFBFBD> <EFBFBD><EFBFBD>reg<EFBFBD><EFBFBD><EFBFBD>£<EFBFBD>
|
|||
|
*/
|
|||
|
|
|||
|
static int findregBlankMemBuf( void )
|
|||
|
{
|
|||
|
int i;
|
|||
|
for(i=0;i<mbsize;i++){
|
|||
|
mb_finder ++;
|
|||
|
if( mb_finder >= mbsize || mb_finder < 0 ) mb_finder = 0;
|
|||
|
|
|||
|
if( mb[mb_finder].use == 0 ){
|
|||
|
mb[mb_finder].use = 1;
|
|||
|
mb[mb_finder].len = 0;
|
|||
|
mb[mb_finder].next = -1;
|
|||
|
mbuse ++;
|
|||
|
return mb_finder;
|
|||
|
}
|
|||
|
}
|
|||
|
return TCPSTRUCT_EMBFULL;
|
|||
|
}
|
|||
|
|
|||
|
/*
|
|||
|
mb ëݩ <EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
|
|||
|
*/
|
|||
|
static int unregMemBuf( int index )
|
|||
|
{
|
|||
|
mb[index].use=0;
|
|||
|
mb[index].next = -1;
|
|||
|
mb[index].len = 0;
|
|||
|
mbuse --;
|
|||
|
return OK;
|
|||
|
}
|
|||
|
|
|||
|
static int findregBlankCon( void )
|
|||
|
{
|
|||
|
int i;
|
|||
|
// Nuke changed 0->1
|
|||
|
//for(i=0;i<MAXCONNECTION;i++){
|
|||
|
for(i=1;i<MAXCONNECTION;i++){
|
|||
|
if( con[i].use == 0 ){
|
|||
|
con[i].use = 1;
|
|||
|
con[i].fd = -1;
|
|||
|
|
|||
|
con[i].mbtop_ri = findregBlankMemBuf();
|
|||
|
if( con[i].mbtop_ri < 0 ){
|
|||
|
fprintf( stderr , "EMBFULL\n" );
|
|||
|
return TCPSTRUCT_EMBFULL;
|
|||
|
}
|
|||
|
|
|||
|
con[i].mbtop_wi = findregBlankMemBuf();
|
|||
|
if( con[i].mbtop_wi < 0 ){
|
|||
|
unregMemBuf( con[i].mbtop_ri );
|
|||
|
fprintf( stderr , "EMBFULL\n" );
|
|||
|
return TCPSTRUCT_EMBFULL;
|
|||
|
}
|
|||
|
bzero( & con[i].remoteaddr , sizeof( struct sockaddr_in));
|
|||
|
con[i].closed_by_remote = 0;
|
|||
|
return i;
|
|||
|
}
|
|||
|
}
|
|||
|
return TCPSTRUCT_ECFULL;
|
|||
|
}
|
|||
|
|
|||
|
int tcpstruct_countmbuse( void )
|
|||
|
{
|
|||
|
int i,c=0;
|
|||
|
for(i=0;i<mbsize;i++){
|
|||
|
if( mb[i].use )c++;
|
|||
|
}
|
|||
|
return c;
|
|||
|
}
|
|||
|
|
|||
|
char * getGSName( int i )
|
|||
|
{
|
|||
|
return gs[i].name;
|
|||
|
}
|
|||
|
|
|||
|
void checkGSUCheck( char *id )
|
|||
|
{
|
|||
|
int i;
|
|||
|
char gname[256];
|
|||
|
if(!id[0]) return;
|
|||
|
memset( gname, 0, sizeof( gname) );
|
|||
|
if( LockNode_getGname( (getHash(id) & 0xff), id, gname) <= 0 ){
|
|||
|
log("Can't find gname from id:%x/%s err !!\n", getHash( id), id);
|
|||
|
return;
|
|||
|
}
|
|||
|
log("\n");
|
|||
|
for(i=0; i < MAXCONNECTION; i++ ){
|
|||
|
if( gs[i].name[0] && strcmp( gs[i].name , gname )==0){
|
|||
|
log("sending UCheck[%s] to %d.%x/%s fd:%d !!\n", id, i, getHash( id), gname, gs[i].fd);
|
|||
|
saacproto_ACUCheck_send( gs[i].fd , id );
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
log("Can't find gname:%s sending err !!\n", gname);
|
|||
|
}
|
|||
|
|
|||
|
void set_nodelay( int sock )
|
|||
|
{
|
|||
|
int flag = 1;
|
|||
|
int result = setsockopt( sock, IPPROTO_TCP, TCP_NODELAY,
|
|||
|
(char*)&flag, sizeof(int));
|
|||
|
if( result < 0 ){
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD>.\n" );
|
|||
|
} else {
|
|||
|
log( "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ӳ<EFBFBD>: fd:%d\n", sock );
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
/*
|
|||
|
<EFBFBD><EFBFBD><EFBFBD>ͻ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ء<EFBFBD>ة<EFBFBD>ӡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> ˪<EFBFBD><EFBFBD>
|
|||
|
|
|||
|
int flag : 1<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>˪<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>巴<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ئ<EFBFBD><EFBFBD>
|
|||
|
|
|||
|
*/
|
|||
|
void gmsvBroadcast( int fd, char *p1, char *p2, char *p3 , int flag )
|
|||
|
{
|
|||
|
int i,c=0;
|
|||
|
|
|||
|
for(i=0;i<MAXCONNECTION;i++){
|
|||
|
if( ( flag == 1 ) && ( i == fd ) )continue;
|
|||
|
if( gs[i].use && gs[i].name[0] ){
|
|||
|
saacproto_Broadcast_send( i, p1,p2,p3);
|
|||
|
c++;
|
|||
|
}
|
|||
|
}
|
|||
|
/*
|
|||
|
#if 1
|
|||
|
{
|
|||
|
char fn[1000];
|
|||
|
FILE *fp;
|
|||
|
snprintf( fn, sizeof(fn), "%s/broadcast.log" , logdir );
|
|||
|
fp = fopen( fn,"a" );
|
|||
|
if(fp){
|
|||
|
fprintf( fp, "From %s(%d) Id:[%s] Char:[%s] Mesg:[%s]\n",
|
|||
|
gs[fd].name, fd, p1,p2,p3 );
|
|||
|
fclose(fp);
|
|||
|
}
|
|||
|
}
|
|||
|
#endif
|
|||
|
*/
|
|||
|
}
|
|||
|
|
|||
|
// <20><>ϵ<EFBFBD><CFB5><EFBFBD><EFBFBD>
|
|||
|
void sigusr2(int a)
|
|||
|
{
|
|||
|
|
|||
|
FILE *listfile;
|
|||
|
char databuf[1024];
|
|||
|
//char fname[1024];
|
|||
|
//char new_fname[1024];
|
|||
|
char backup_movelist[1024];
|
|||
|
//char playerinfo[1024], frominfo[1024], toinfo[1024];
|
|||
|
char *playerinfo;
|
|||
|
int frominfo, toinfo;
|
|||
|
int i, j;
|
|||
|
|
|||
|
char servername[16][20] =
|
|||
|
{
|
|||
|
"<EFBFBD><EFBFBD>Ů", // 0
|
|||
|
"̫<EFBFBD><EFBFBD>", // 1
|
|||
|
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // 2
|
|||
|
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // 3
|
|||
|
"<EFBFBD><EFBFBD>", // 4
|
|||
|
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // 5
|
|||
|
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ϵ", // 6
|
|||
|
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // 7
|
|||
|
"<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", // 8
|
|||
|
"<EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>ͥ", // 9
|
|||
|
"ʥ<EFBFBD><EFBFBD>", // 10
|
|||
|
"<EFBFBD><EFBFBD>ӥ", // 11
|
|||
|
"<EFBFBD>½<EFBFBD>", // 12
|
|||
|
"<EFBFBD><EFBFBD>Ů1", // 13
|
|||
|
"<EFBFBD><EFBFBD>Ů2", // 14
|
|||
|
"<EFBFBD><EFBFBD>Ů3" // 15
|
|||
|
};
|
|||
|
|
|||
|
|
|||
|
log("\n %s Change_Galaxies.......\n", saacname);
|
|||
|
|
|||
|
// <20><><EFBFBD><EFBFBD>ȫ<EFBFBD><C8AB><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
DeleteGalaxyChangeLock(0);
|
|||
|
|
|||
|
for( j=1; j<=12; j++) {
|
|||
|
|
|||
|
char listfilename[1024];
|
|||
|
|
|||
|
// <20><>ȡ<EFBFBD><C8A1><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD>
|
|||
|
sprintf( listfilename, "StaMove_%d.txt", j);
|
|||
|
listfile = fopen( listfilename, "r");
|
|||
|
if( listfile == NULL)
|
|||
|
{
|
|||
|
continue;
|
|||
|
}
|
|||
|
log("<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><EFBFBD>ļ<EFBFBD>:%s\n", listfilename);
|
|||
|
|
|||
|
|
|||
|
while(1)
|
|||
|
{
|
|||
|
if( fgets( databuf, sizeof(databuf), listfile) == NULL )
|
|||
|
break;
|
|||
|
|
|||
|
if( databuf[0] == '#')
|
|||
|
continue;
|
|||
|
|
|||
|
// <20><>һ<EFBFBD><D2BB><EFBFBD><EFBFBD><EFBFBD><EFBFBD> (<28>ʺ<EFBFBD> <20><>Դ<EFBFBD><D4B4>ϵ Ŀ<><C4BF><EFBFBD><EFBFBD>ϵ)
|
|||
|
//if( sscanf( databuf, "%s,%s,%s", playerinfo, frominfo, toinfo) != 3)
|
|||
|
// continue;
|
|||
|
playerinfo = strtok( databuf, ",");
|
|||
|
if( playerinfo == NULL) continue;
|
|||
|
frominfo = atoi( strtok( NULL, ","));
|
|||
|
toinfo = atoi( strtok( NULL, ","));
|
|||
|
|
|||
|
log("\n %s,%d,%d ", playerinfo, frominfo, toinfo);
|
|||
|
|
|||
|
if( (frominfo <0) || ( frominfo >15) || (toinfo <0) || ( toinfo >15))
|
|||
|
continue;
|
|||
|
|
|||
|
// <20>Ƿ<EFBFBD>Ҫ<EFBFBD><D2AA><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȥ<EFBFBD><C8A5><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
if( !strcmp( servername[frominfo], saacname) || !strcmp( servername[toinfo], saacname) )
|
|||
|
{
|
|||
|
|
|||
|
log(" from:%s to:%s ", servername[frominfo], servername[toinfo]);
|
|||
|
|
|||
|
// <20><><EFBFBD>ʺ<EFBFBD>
|
|||
|
#ifdef _LOCK_ADD_NAME
|
|||
|
InsertMemLock( getHash(playerinfo) & 0xff, playerinfo, "", "", "<EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", 0, "0");
|
|||
|
#else
|
|||
|
InsertMemLock( getHash(playerinfo) & 0xff, playerinfo, "", "<EFBFBD><EFBFBD>ϵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>", 0, "0");
|
|||
|
#endif
|
|||
|
|
|||
|
// <20><><EFBFBD><EFBFBD>
|
|||
|
log("<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ǰ<EFBFBD><EFBFBD><EFBFBD><EFBFBD> ");
|
|||
|
for(i=0;i<MAXCONNECTION;i++) {
|
|||
|
if( is_game_server_login(i) ){
|
|||
|
saacproto_ACKick_send( i , 1 , playerinfo , -2/*mesgid*/ );
|
|||
|
log(" %d->%s->%s", i, gs[i].name, playerinfo);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
//else
|
|||
|
//{
|
|||
|
// continue;
|
|||
|
//}
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
// <20>б<EFBFBD><D0B1><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
|
|||
|
//sprintf( backup_movelist, "%s.old", listfilename);
|
|||
|
//rename( listfilename, backup_movelist);
|
|||
|
|
|||
|
fclose( listfile);
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
signal(SIGUSR2, sighandle);
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
#ifdef _ANGEL_SUMMON
|
|||
|
|
|||
|
#define MISSIONFILE "db/missiontable.txt"
|
|||
|
|
|||
|
static int initMissionTable( void )
|
|||
|
{
|
|||
|
FILE *fp;
|
|||
|
char onedata[1024];
|
|||
|
char buf[1024];
|
|||
|
int index =0;
|
|||
|
|
|||
|
memset( missiontable, 0, sizeof(missiontable));
|
|||
|
fp = fopen( MISSIONFILE, "r");
|
|||
|
if( !fp ) {
|
|||
|
log("\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!!!! \n");
|
|||
|
//return false;
|
|||
|
}
|
|||
|
log("\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...");
|
|||
|
while(1) {
|
|||
|
//
|
|||
|
if( fgets( onedata, sizeof(onedata), fp) == NULL)
|
|||
|
break;
|
|||
|
if( onedata[0] == NULL || onedata[0] == '#' )
|
|||
|
continue;
|
|||
|
//easyGetTokenFromBuf( onedata, ',', 1, buf, sizeof( buf));
|
|||
|
//index = atoi( buf);
|
|||
|
easyGetTokenFromBuf( onedata, ',', 1, buf, sizeof( buf));
|
|||
|
if( buf[0] == NULL ) continue;
|
|||
|
strcpy( missiontable[index].angelinfo, buf);
|
|||
|
easyGetTokenFromBuf( onedata, ',', 2, buf, sizeof( buf));
|
|||
|
if( buf[0] == NULL ) continue;
|
|||
|
strcpy( missiontable[index].heroinfo, buf);
|
|||
|
easyGetTokenFromBuf( onedata, ',', 3, buf, sizeof( buf));
|
|||
|
if( buf[0] == NULL ) continue;
|
|||
|
missiontable[index].mission = atoi( buf);
|
|||
|
easyGetTokenFromBuf( onedata, ',', 4, buf, sizeof( buf));
|
|||
|
if( buf[0] == NULL ) continue;
|
|||
|
missiontable[index].flag = atoi( buf);
|
|||
|
easyGetTokenFromBuf( onedata, ',', 5, buf, sizeof( buf));
|
|||
|
if( buf[0] == NULL ) continue;
|
|||
|
missiontable[index].time = atoi( buf);
|
|||
|
easyGetTokenFromBuf( onedata, ',', 6, buf, sizeof( buf));
|
|||
|
if( buf[0] == NULL ) continue;
|
|||
|
missiontable[index].limittime = atoi( buf);
|
|||
|
|
|||
|
log(" %d=%s,%s,%d,%d,%d,%d \n", index,
|
|||
|
missiontable[index].angelinfo,
|
|||
|
missiontable[index].heroinfo,
|
|||
|
missiontable[index].mission,
|
|||
|
missiontable[index].flag,
|
|||
|
missiontable[index].time,
|
|||
|
missiontable[index].limittime );
|
|||
|
|
|||
|
index++;
|
|||
|
if( index >= MAXMISSIONTABLE) break;
|
|||
|
}
|
|||
|
fclose( fp);
|
|||
|
log("..<2E>ɹ<EFBFBD>! \n");
|
|||
|
//return true;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
int saveMissionTable( void )
|
|||
|
{
|
|||
|
FILE *fp;
|
|||
|
char onedata[1024];
|
|||
|
char buf[1024];
|
|||
|
int index =0;
|
|||
|
|
|||
|
fp = fopen( MISSIONFILE, "w");
|
|||
|
if( !fp ) {
|
|||
|
log("\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>!!!! \n");
|
|||
|
//return false;
|
|||
|
}
|
|||
|
log("\n\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>...");
|
|||
|
for( index =0; index < MAXMISSIONTABLE; index++) {
|
|||
|
|
|||
|
if( missiontable[index].angelinfo[0] == NULL )
|
|||
|
continue;
|
|||
|
sprintf( onedata, "%s,%s,%d,%d,%d,%d\n",
|
|||
|
missiontable[index].angelinfo,
|
|||
|
missiontable[index].heroinfo,
|
|||
|
missiontable[index].mission,
|
|||
|
missiontable[index].flag,
|
|||
|
missiontable[index].time,
|
|||
|
missiontable[index].limittime );
|
|||
|
fputs( onedata, fp);
|
|||
|
}
|
|||
|
fclose( fp);
|
|||
|
log("..<2E>ɹ<EFBFBD>! \n");
|
|||
|
//return true;
|
|||
|
}
|
|||
|
|
|||
|
void delMissionTableOnedata( int index)
|
|||
|
{
|
|||
|
int gi;
|
|||
|
|
|||
|
log("\nɾ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d:%s:%s \n", index, missiontable[index].angelinfo, missiontable[index].heroinfo);
|
|||
|
|
|||
|
if( index <0 || index >=MAXMISSIONTABLE) return;
|
|||
|
strcpy( missiontable[index].angelinfo, "");
|
|||
|
strcpy( missiontable[index].heroinfo, "");
|
|||
|
missiontable[index].mission = 0;
|
|||
|
missiontable[index].flag = MISSION_NONE;
|
|||
|
missiontable[index].time = 0;
|
|||
|
missiontable[index].limittime = 0;
|
|||
|
|
|||
|
for( gi=0; gi<MAXCONNECTION; gi++) {
|
|||
|
if (gs[gi].use && gs[gi].name[0]) {
|
|||
|
saacproto_ACMissionTable_send( gi, index, 3, "", "");
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
#define ANSWERTIME 1 // <20>ȴ<EFBFBD><C8B4>ش<EFBFBD>ʱ<EFBFBD><CAB1>(Сʱ)
|
|||
|
//#define DOINGTIME 3*24 // <20><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>(Сʱ)
|
|||
|
#define BOUNDSTIME 1*24 // <20><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1>(Сʱ)
|
|||
|
|
|||
|
void checkMissionTimelimit( void)
|
|||
|
{
|
|||
|
int index;
|
|||
|
static time_t lastcheck =0;
|
|||
|
|
|||
|
if( sys_time < lastcheck + 5*60 )
|
|||
|
return;
|
|||
|
|
|||
|
log("\n<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>:%d \n", sys_time);
|
|||
|
for( index =0; index < MAXMISSIONTABLE; index++) {
|
|||
|
if( missiontable[index].flag == MISSION_NONE) {
|
|||
|
continue;
|
|||
|
}
|
|||
|
// <20>ȴ<EFBFBD>ʹ<EFBFBD><EFBFBD>Ӧ1Сʱ
|
|||
|
else if( missiontable[index].flag == MISSION_WAIT_ANSWER
|
|||
|
&& sys_time > missiontable[index].time + ANSWERTIME*60*60 ) {
|
|||
|
|
|||
|
delMissionTableOnedata( index);// ɾ
|
|||
|
}
|
|||
|
// <20>ȴ<EFBFBD><C8B4>콱<EFBFBD><ECBDB1><EFBFBD><EFBFBD> limittimeСʱ
|
|||
|
else if( ( missiontable[index].flag == MISSION_DOING || missiontable[index].flag == MISSION_HERO_COMPLETE )
|
|||
|
&& ( sys_time > (missiontable[index].time + missiontable[index].limittime*60*60)) ) {
|
|||
|
|
|||
|
char buf[1024];
|
|||
|
int gi;
|
|||
|
// <20><>TIMEOVER
|
|||
|
log(" <20><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>콱ʱ<ECBDB1><CAB1><EFBFBD><EFBFBD>:%d ", index);
|
|||
|
missiontable[index].flag = MISSION_TIMEOVER;
|
|||
|
missiontable[index].time = time(NULL);
|
|||
|
missiontable[index].limittime = BOUNDSTIME;
|
|||
|
|
|||
|
sprintf( buf, "%d|%s|%s|%d|%d|%d|%d ", index,
|
|||
|
missiontable[index].angelinfo,
|
|||
|
missiontable[index].heroinfo,
|
|||
|
missiontable[index].mission,
|
|||
|
missiontable[index].flag,
|
|||
|
missiontable[index].time,
|
|||
|
missiontable[index].limittime );
|
|||
|
for( gi=0; gi<MAXCONNECTION; gi++) {
|
|||
|
if (gs[gi].use && gs[gi].name[0]) {
|
|||
|
saacproto_ACMissionTable_send( gi, 1, 1, buf, "");
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
continue;
|
|||
|
}
|
|||
|
//else if( missiontable[index].flag == MISSION_HERO_COMPLETE
|
|||
|
// && sys_time > missiontable[index].time + BOUNDSTIME*60*60 ) {
|
|||
|
// log(" <20>콱ʱ<ECBDB1><CAB1><EFBFBD><EFBFBD>:%d ", index);
|
|||
|
// delMissionTableOnedata( index);// ɾ
|
|||
|
//}
|
|||
|
|
|||
|
// <20><><EFBFBD>ϱ<EFBFBD><CFB1><EFBFBD>ʱ<EFBFBD><CAB1>(BOUNDSTIMEСʱ)
|
|||
|
else if( missiontable[index].flag == MISSION_TIMEOVER
|
|||
|
&& sys_time > missiontable[index].time + BOUNDSTIME*60*60 ) {
|
|||
|
log(" <20><><EFBFBD><EFBFBD>ʱ<EFBFBD><CAB1><EFBFBD><EFBFBD>:%d ", index);
|
|||
|
delMissionTableOnedata( index);// ɾ
|
|||
|
}
|
|||
|
|
|||
|
}
|
|||
|
saveMissionTable();
|
|||
|
|
|||
|
lastcheck = sys_time;
|
|||
|
}
|
|||
|
|
|||
|
#endif
|
|||
|
|
|||
|
#ifdef _RACEMAN
|
|||
|
//#define RANKFILE "race/ranktable.txt"
|
|||
|
struct RankTable ranktable[DEFMAXRANK];
|
|||
|
|
|||
|
static int initRankTable( void )
|
|||
|
{
|
|||
|
//FILE *fp;
|
|||
|
memset( ranktable, 0, sizeof(ranktable));
|
|||
|
/*
|
|||
|
fp = fopen( RANKFILE, "r");
|
|||
|
if( !fp ) {
|
|||
|
log("\n\n Load RankTable ERROR!!!! \n\n");
|
|||
|
}
|
|||
|
log("\n\n Load RankTable... \n");
|
|||
|
*/
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
#endif
|