亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? script.c

?? 最新的仙鏡傳說服務(wù)器C語言源碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
	add_scriptb(a&0x3f);
}

/*==========================================
 * 僗僋儕僾僩僶僢僼傽偵惍悢傪彂偒崬傓
 *------------------------------------------
 */
static void add_scripti(int a)
{
	while(a>=0x40){
		add_scriptb(a|0xc0);
		a=(a-0x40)>>6;
	}
	add_scriptb(a|0x80);
}

/*==========================================
 * 僗僋儕僾僩僶僢僼傽偵儔儀儖/曄悢/娭悢傪彂偒崬傓
 *------------------------------------------
 */
// 嵟戝16M傑偱
static void add_scriptl(int l)
{
	int backpatch = str_data[l].backpatch;

	switch(str_data[l].type){
	case C_POS:
		add_scriptc(C_POS);
		add_scriptb(str_data[l].label);
		add_scriptb(str_data[l].label>>8);
		add_scriptb(str_data[l].label>>16);
		break;
	case C_NOP:
		// 儔儀儖偺壜擻惈偑偁傞偺偱backpatch梡僨乕僞杽傔崬傒
		add_scriptc(C_NAME);
		str_data[l].backpatch=script_pos;
		add_scriptb(backpatch);
		add_scriptb(backpatch>>8);
		add_scriptb(backpatch>>16);
		break;
	case C_INT:
		add_scripti(str_data[l].val);
		break;
	default:
		// 傕偆懠偺梡搑偲妋掕偟偰傞偺偱悢帤傪偦偺傑傑
		add_scriptc(C_NAME);
		add_scriptb(l);
		add_scriptb(l>>8);
		add_scriptb(l>>16);
		break;
	}
}

/*==========================================
 * 儔儀儖傪夝寛偡傞
 *------------------------------------------
 */
void set_label(int l,int pos)
{
	int i,next;

	str_data[l].type=C_POS;
	str_data[l].label=pos;
	for(i=str_data[l].backpatch;i>=0 && i!=0x00ffffff;){
		next=(*(int*)(script_buf+i)) & 0x00ffffff;
		script_buf[i-1]=C_POS;
		script_buf[i]=pos;
		script_buf[i+1]=pos>>8;
		script_buf[i+2]=pos>>16;
		i=next;
	}
}

/*==========================================
 * 僗儁乕僗/僐儊儞僩撉傒旘偽偟
 *------------------------------------------
 */
static unsigned char *skip_space(unsigned char *p)
{
	while(1){
		while(isspace(*p))
			p++;
		if(p[0]=='/' && p[1]=='/'){
			while(*p && *p!='\n')
				p++;
		} else if(p[0]=='/' && p[1]=='*'){
			p++;
			while(*p && (p[-1]!='*' || p[0]!='/'))
				p++;
			if(*p) p++;
		} else
			break;
	}
	return p;
}

/*==========================================
 * 侾扨岅僗僉僢僾
 *------------------------------------------
 */
static unsigned char *skip_word(unsigned char *p)
{
	// prefix
	if(*p=='$') p++;	// MAP嶪撪嫟桳曄悢梡
	if(*p=='@') p++;	// 堦帪揑曄悢梡(like weiss)
	if(*p=='#') p++;	// account曄悢梡
	if(*p=='#') p++;	// 儚乕儖僪account曄悢梡
	
	while(isalnum(*p)||*p=='_'|| *p>=0x81)
		if(*p>=0x81 && p[1]){
			p+=2;
		} else
			p++;

	// postfix
	if(*p=='$') p++;	// 暥帤楍曄悢
	
	return p;
}

static unsigned char *startptr;
static int startline;

/*==========================================
 * 僄儔乕儊僢僙乕僕弌椡
 *------------------------------------------
 */
static void disp_error_message(const char *mes,const unsigned char *pos)
{
	int line,c=0,i;
	unsigned char *p,*linestart,*lineend;

	for(line=startline,p=startptr;p && *p;line++){
		linestart=p;
		lineend=strchr(p,'\n');
		if(lineend){
			c=*lineend;
			*lineend=0;
		}
		if(lineend==NULL || pos<lineend){
			printf("%s line %d : ",mes,line);
			for(i=0;linestart[i];i++){
				if(linestart+i!=pos)
					printf("%c",linestart[i]);
				else
					printf("\'%c\'",linestart[i]);
			}
			printf("\n");
			if(lineend)
				*lineend=c;
			return;
		}
		*lineend=c;
		p=lineend+1;
	}
}

/*==========================================
 * 崁偺夝愅
 *------------------------------------------
 */
unsigned char* parse_simpleexpr(unsigned char *p)
{
	int i;
	p=skip_space(p);

#ifdef DEBUG_FUNCIN
	if(battle_config.etc_log)
		printf("parse_simpleexpr %s\n",p);
#endif
	if(*p==';' || *p==','){
		disp_error_message("unexpected expr end",p);
		exit(1);
	}
	if(*p=='('){

		p=parse_subexpr(p+1,-1);
		p=skip_space(p);
		if((*p++)!=')'){
			disp_error_message("unmatch ')'",p);
			exit(1);
		}
	} else if(isdigit(*p) || ((*p=='-' || *p=='+') && isdigit(p[1]))){
		char *np;
		i=strtoul(p,&np,0);
		add_scripti(i);
		p=np;
	} else if(*p=='"'){
		add_scriptc(C_STR);
		p++;
		while(*p && *p!='"'){
			if(p[-1]<=0x7e && *p=='\\')
				p++;
			else if(*p=='\n'){
				disp_error_message("unexpected newline @ string",p);
				exit(1);
			}
			add_scriptb(*p++);
		}
		if(!*p){
			disp_error_message("unexpected eof @ string",p);
			exit(1);
		}
		add_scriptb(0);
		p++;	//'"'
	} else {
		int c,l;
		char *p2;
		// label , register , function etc
		if(skip_word(p)==p){
			disp_error_message("unexpected charactor",p);
			exit(1);
		}
		p2=skip_word(p);
		c=*p2;	*p2=0;	// 柤慜傪add_str偡傞
		l=add_str(p);
		
		parse_cmd=l;	// warn_*_mismatch_paramnum偺偨傔偵昁梫
		if(l==search_str("if"))	// warn_cmd_no_comma偺偨傔偵昁梫
			parse_cmd_if++;

		// 攑巭梊掕偺l14/l15,偍傛?zhèn)褍v儗僼傿僢僋僗倢偺寈崘
		if(	strcmp(str_buf+str_data[l].str,"l14")==0 ||
			strcmp(str_buf+str_data[l].str,"l15")==0 ){
			disp_error_message("l14 and l15 is DEPRECATED. use @menu instead of l15.",p);
		}else if(str_buf[str_data[l].str]=='l'){
			disp_error_message("prefix 'l' is DEPRECATED. use prefix '@' instead.",p2);
		}

		*p2=c;	p=p2;
		
		
		if(str_data[l].type!=C_FUNC && c=='['){
			// array(name[i] => getelementofarray(name,i) )
			add_scriptl(search_str("getelementofarray"));
			add_scriptc(C_ARG);
			add_scriptl(l);
			p=parse_subexpr(p+1,-1);
			p=skip_space(p);
			if((*p++)!=']'){
				disp_error_message("unmatch ']'",p);
				exit(1);
			}
			add_scriptc(C_FUNC);
		}else
			add_scriptl(l);

	}

#ifdef DEBUG_FUNCIN
	if(battle_config.etc_log)
		printf("parse_simpleexpr end %s\n",p);
#endif
	return p;
}

/*==========================================
 * 幃偺夝愅
 *------------------------------------------
 */
unsigned char* parse_subexpr(unsigned char *p,int limit)
{
	int op,opl,len;
	char *tmpp;

#ifdef DEBUG_FUNCIN
	if(battle_config.etc_log)
		printf("parse_subexpr %s\n",p);
#endif
	p=skip_space(p);

	if(*p=='-'){
		tmpp=skip_space(p+1);
		if(*tmpp==';' || *tmpp==','){
			add_scriptl(LABEL_NEXTLINE);
			p++;
			return p;
		}
	}
	tmpp=p;
	if((op=C_NEG,*p=='-') || (op=C_LNOT,*p=='!') || (op=C_NOT,*p=='~')){
		p=parse_subexpr(p+1,100);
		add_scriptc(op);
	} else
		p=parse_simpleexpr(p);
	p=skip_space(p);
	while(((op=C_ADD,opl=6,len=1,*p=='+') ||
		   (op=C_SUB,opl=6,len=1,*p=='-') ||
		   (op=C_MUL,opl=7,len=1,*p=='*') ||
		   (op=C_DIV,opl=7,len=1,*p=='/') ||
		   (op=C_MOD,opl=7,len=1,*p=='%') ||
		   (op=C_FUNC,opl=8,len=1,*p=='(') ||
		   (op=C_LAND,opl=1,len=2,*p=='&' && p[1]=='&') ||
		   (op=C_AND,opl=5,len=1,*p=='&') ||
		   (op=C_LOR,opl=0,len=2,*p=='|' && p[1]=='|') ||
		   (op=C_OR,opl=4,len=1,*p=='|') ||
		   (op=C_XOR,opl=3,len=1,*p=='^') ||
		   (op=C_EQ,opl=2,len=2,*p=='=' && p[1]=='=') ||
		   (op=C_NE,opl=2,len=2,*p=='!' && p[1]=='=') ||
		   (op=C_GE,opl=2,len=2,*p=='>' && p[1]=='=') ||
		   (op=C_GT,opl=2,len=1,*p=='>') ||
		   (op=C_LE,opl=2,len=2,*p=='<' && p[1]=='=') ||
		   (op=C_LT,opl=2,len=1,*p=='<')) && opl>limit){
		p+=len;
		if(op==C_FUNC){
			int i=0,func=parse_cmd;
			const char *plist[128];
			
			if( str_data[func].type!=C_FUNC ){
				disp_error_message("expect function",tmpp);
				exit(0);
			}
			
			add_scriptc(C_ARG);
			do {
				plist[i]=p;
				p=parse_subexpr(p,-1);
				p=skip_space(p);
				if(*p==',') p++;
				else if(*p!=')' && script_config.warn_func_no_comma){
					disp_error_message("expect ',' or ')' at func params",p);
				}
				p=skip_space(p);
				i++;
			} while(*p && *p!=')' && i<128);
			plist[i]=p;
			if(*(p++)!=')'){
				disp_error_message("func request '(' ')'",p);
				exit(1);
			}
			
			if( str_data[func].type==C_FUNC && script_config.warn_func_mismatch_paramnum){
				const char *arg=buildin_func[str_data[func].val].arg;
				int j=0;
				for(j=0;arg[j];j++) if(arg[j]=='*')break;
				if( (arg[j]==0 && i!=j) || (arg[j]=='*' && i<j) ){
					disp_error_message("illeagal number of parameters",plist[(i<j)?i:j]);
				}
			}
		} else {
			p=parse_subexpr(p,opl);
		}
		add_scriptc(op);
		p=skip_space(p);
	}
#ifdef DEBUG_FUNCIN
	if(battle_config.etc_log)
		printf("parse_subexpr end %s\n",p);
#endif
	return p;  /* return first untreated operator */
}

/*==========================================
 * 幃偺昡壙
 *------------------------------------------
 */
unsigned char* parse_expr(unsigned char *p)
{
#ifdef DEBUG_FUNCIN
	if(battle_config.etc_log)
		printf("parse_expr %s\n",p);
#endif
	switch(*p){
	case ')': case ';': case ':': case '[': case ']':
	case '}':
		disp_error_message("unexpected char",p);
		exit(1);
	}
	p=parse_subexpr(p,-1);
#ifdef DEBUG_FUNCIN
	if(battle_config.etc_log)
		printf("parse_expr end %s\n",p);
#endif
	return p;
}

/*==========================================
 * 峴偺夝愅
 *------------------------------------------
 */
unsigned char* parse_line(unsigned char *p)
{
	int i=0,cmd;
	const char *plist[128];
	char *p2;

	p=skip_space(p);
	if(*p==';')
		return p;

	parse_cmd_if=0;	// warn_cmd_no_comma偺偨傔偵昁梫

	// 嵟弶偼娭悢柤
	p2=p;
	p=parse_simpleexpr(p);
	p=skip_space(p);

	cmd=parse_cmd;
	if( str_data[cmd].type!=C_FUNC ){
		disp_error_message("expect command",p2);
		exit(0);
	}
	
	add_scriptc(C_ARG);
	while(p && *p && *p!=';' && i<128){
		plist[i]=p;
		
		p=parse_expr(p);
		p=skip_space(p);
		// 堷悢嬫愗傝偺,張棟
		if(*p==',') p++;
		else if(*p!=';' && script_config.warn_cmd_no_comma && parse_cmd_if*2<=i ){
			disp_error_message("expect ',' or ';' at cmd params",p);
		}
		p=skip_space(p);
		i++;
	}
	plist[i]=p;
	if(!p || *(p++)!=';'){
		disp_error_message("need ';'",p);
		exit(1);
	}	
	add_scriptc(C_FUNC);

	if( str_data[cmd].type==C_FUNC && script_config.warn_cmd_mismatch_paramnum){
		const char *arg=buildin_func[str_data[cmd].val].arg;
		int j=0;
		for(j=0;arg[j];j++) if(arg[j]=='*')break;
		if( (arg[j]==0 && i!=j) || (arg[j]=='*' && i<j) ){
			disp_error_message("illeagal number of parameters",plist[(i<j)?i:j]);
		}
	}


	return p;
}

/*==========================================
 * 慻傒崬傒娭悢偺捛壛
 *------------------------------------------
 */
static void add_buildin_func(void)
{
	int i,n;
	for(i=0;buildin_func[i].func;i++){
		n=add_str(buildin_func[i].name);
		str_data[n].type=C_FUNC;
		str_data[n].val=i;
		str_data[n].func=buildin_func[i].func;
	}
}

/*==========================================
 * 掕悢僨乕僞儀乕僗偺撉傒崬傒
 *------------------------------------------
 */
static void read_constdb(void)
{
	FILE *fp;
	char line[1024],name[1024];
	int val,n,i,type;

	fp=fopen("db/const.txt","r");
	if(fp==NULL){
		printf("can't read db/const.txt\n");
		return ;
	}
	while(fgets(line,1020,fp)){
		if(line[0]=='/' && line[1]=='/')
			continue;
		type=0;
		if(sscanf(line,"%[A-Za-z0-9_],%d,%d",name,&val,&type)>=2 ||
		   sscanf(line,"%[A-Za-z0-9_] %d %d",name,&val,&type)>=2){
			for(i=0;name[i];i++)
				name[i]=tolower(name[i]);
			n=add_str(name);
			if(type==0)
				str_data[n].type=C_INT;
			else
				str_data[n].type=C_PARAM;
			str_data[n].val=val;
		}
	}
	fclose(fp);
}

/*==========================================
 * 僗僋儕僾僩偺夝愅

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
777奇米四色成人影色区| 国产一区二区主播在线| 色综合天天综合网天天狠天天 | 国产拍揄自揄精品视频麻豆| 精品一区二区三区影院在线午夜| 日韩欧美三级在线| 国产一区二区三区最好精华液| 337p粉嫩大胆噜噜噜噜噜91av| 国产精品影音先锋| 国产精品久久久久久久久免费相片 | ●精品国产综合乱码久久久久| 92国产精品观看| 亚洲影院久久精品| 欧美一级二级在线观看| 国产精品一品二品| 一区二区三区中文免费| 91精品国模一区二区三区| 国产美女精品在线| 亚洲乱码中文字幕| 欧美一区二区观看视频| 国产精品66部| 婷婷开心激情综合| 日本一区二区三区dvd视频在线| 色哟哟亚洲精品| 精品一区二区三区免费| 亚洲欧洲三级电影| 日韩视频一区在线观看| 成人激情免费视频| 日韩精品91亚洲二区在线观看 | 成人免费视频caoporn| 夜夜夜精品看看| 精品国产91乱码一区二区三区| 99精品视频在线观看免费| 视频一区在线播放| 国产精品久久久久久久久免费相片| 欧美男女性生活在线直播观看| 国产91露脸合集magnet| 天天av天天翘天天综合网色鬼国产| 久久精品在线免费观看| 精品视频123区在线观看| 国产成人精品免费| 日韩国产在线观看| 亚洲另类色综合网站| 欧美精品一区二区蜜臀亚洲| 欧美主播一区二区三区| 国产老肥熟一区二区三区| 午夜欧美大尺度福利影院在线看| 国产精品乱人伦一区二区| 欧美大片拔萝卜| 欧美日韩第一区日日骚| 91在线观看免费视频| 国产精品99久久久久久有的能看| 午夜精品久久一牛影视| 亚洲欧美激情小说另类| 国产丝袜在线精品| ww亚洲ww在线观看国产| 欧美日韩另类国产亚洲欧美一级| 99久久免费视频.com| 国产麻豆精品一区二区| 美女www一区二区| 亚瑟在线精品视频| 亚洲乱码国产乱码精品精小说 | 国产精品国产自产拍高清av| 日韩免费高清av| 91精品国产一区二区三区香蕉| 欧美在线999| 色综合中文字幕| 91蜜桃在线免费视频| 成a人片国产精品| 99久久婷婷国产综合精品| 成人a免费在线看| 大尺度一区二区| 成人性色生活片| gogogo免费视频观看亚洲一| 国产精品亚洲视频| 国产精一品亚洲二区在线视频| 极品少妇一区二区| 精品一区二区影视| 国产精品综合二区| 高清av一区二区| 成人黄色在线网站| 99精品视频免费在线观看| 91丝袜国产在线播放| 91女厕偷拍女厕偷拍高清| 色欧美乱欧美15图片| 色老头久久综合| 欧美日韩精品免费观看视频| 制服丝袜亚洲播放| 欧美变态口味重另类| 精品国内片67194| 日本一区二区视频在线| 欧美国产激情一区二区三区蜜月| 国产精品蜜臀av| 亚洲欧洲av一区二区三区久久| 亚洲精品免费在线| 天堂成人国产精品一区| 经典三级在线一区| 国产成人在线观看免费网站| 成人黄色777网| 欧美综合在线视频| 日韩欧美成人一区| 欧美激情一区二区三区四区| 中文字幕一区二区在线播放| 亚洲自拍另类综合| 蜜臀久久久99精品久久久久久| 国产精品一线二线三线精华| 成人黄色片在线观看| 欧美日韩黄色一区二区| 欧美成人一区二区三区在线观看| 国产欧美综合在线| 无吗不卡中文字幕| 国产一区日韩二区欧美三区| 91麻豆国产福利在线观看| 4438x亚洲最大成人网| 久久综合网色—综合色88| 一区二区三区四区在线播放 | 国产欧美一区二区精品婷婷| 亚洲欧美偷拍卡通变态| 日本亚洲天堂网| 9l国产精品久久久久麻豆| 欧美另类高清zo欧美| 国产亚洲精品aa| 丝袜美腿亚洲综合| 国产91综合一区在线观看| 欧美日韩久久不卡| 国产精品免费网站在线观看| 日本亚洲最大的色成网站www| av成人免费在线观看| 日韩一区二区影院| 一区二区三区在线视频免费 | 国产精品2024| 欧美一区二区三区思思人| 亚洲色图都市小说| 国产自产高清不卡| 91麻豆精品91久久久久久清纯| 国产欧美日韩亚州综合| 日本亚洲视频在线| 欧洲精品一区二区三区在线观看| 久久亚洲一区二区三区四区| 亚洲高清视频中文字幕| 成人高清视频免费观看| 日韩精品一区在线观看| 亚洲高清在线精品| 91网址在线看| 国产精品久久久久7777按摩| 国产最新精品精品你懂的| 91精品久久久久久久91蜜桃| 伊人性伊人情综合网| 成人美女视频在线观看| 久久综合一区二区| 精品一区二区三区免费视频| 欧美一区2区视频在线观看| 亚洲午夜羞羞片| 色8久久人人97超碰香蕉987| 国产精品白丝在线| 国产99久久精品| 国产欧美日韩视频一区二区 | 视频在线观看一区二区三区| 一本大道av一区二区在线播放| 国产日韩欧美激情| 国产激情91久久精品导航 | 中文字幕欧美一区| 丁香六月久久综合狠狠色| 国产日韩欧美亚洲| 成人高清av在线| 中文字幕的久久| www.日韩av| 亚洲特黄一级片| 色综合天天综合狠狠| 亚洲综合久久久久| 欧美视频你懂的| 亚洲国产另类av| 3d动漫精品啪啪1区2区免费 | 久久久亚洲国产美女国产盗摄| 国产在线不卡视频| 久久精品男人天堂av| 国产大陆a不卡| 国产精品国产三级国产aⅴ无密码| 丁香五精品蜜臀久久久久99网站| 中文字幕+乱码+中文字幕一区| 丁香啪啪综合成人亚洲小说| 国产精品福利av | 欧美亚洲综合一区| 日韩av中文字幕一区二区三区| 欧美女孩性生活视频| 蜜桃av一区二区三区电影| 亚洲精品一区二区精华| 国产精品一线二线三线精华| 中文字幕一区二区在线播放 | 国产精品一线二线三线精华| 国产精品国产三级国产aⅴ中文| 91丨九色丨蝌蚪丨老版| 天天色天天操综合| 精品久久久久久久久久久久久久久 | 99国产精品久久久久久久久久 | 欧美不卡一区二区三区四区| 久久蜜桃av一区精品变态类天堂| 国产99精品国产| 亚洲制服欧美中文字幕中文字幕| 日韩一区二区在线播放|