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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? complier.cpp

?? SIMPLE語言編譯器
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
	{
	case 14://integer
	case 15://real
	case 5://procedure
		if (!r_ShuoMingChuan()) return FALSE;
		switch (GetCurSym()->type)
		{
		case 30://;
			break;
		default:
			m_nErrorNum=5;
			m_nErrorAddress=m_pCurSym;
			return FALSE;
		}
		NextSym();
		break;
	case 6://begin
		break;
	default:
		m_nErrorNum=7;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	switch (GetCurSym()->type)
	{
	case 6://begin
		break;
	default:
		m_nErrorNum=8;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_YuJuChuan()) return FALSE;
	switch (GetCurSym()->type)
	{
	case 7://end
		break;
	default:
		m_nErrorNum=10;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	return TRUE;
}

int CComplier::r_ShuoMingChuan()
{
	if (!r_ShuoMing()) return FALSE;
	while (GetCurSym()->type==30 
		&& GetNextSym()->type!=6)//; begin
	{
		NextSym();
		if (!r_ShuoMing()) return FALSE;
	}
	return TRUE;
}

int CComplier::r_ShuoMing()
{
	switch (GetCurSym()->type)
	{
	case 14://integer
	case 15://real
		if (!r_JianBianShuoMing()) return FALSE;
		break;
	case 5://procedure
		if (!r_GuoChengShuoMing()) return FALSE;
		break;
	default:
		m_nErrorNum=11;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	return TRUE;
}

int CComplier::r_JianBianShuoMing()
{
	int typ;//yy
	switch (GetCurSym()->type)
	{
	case 14://integer
		typ=1;//yy
		break;
	case 15://real
		typ=2;//yy
		break;
	default:
		m_nErrorNum=12;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	switch (GetCurSym()->type)
	{
	case 1://id
		break;
	default:
		m_nErrorNum=14;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy
	switch (lookupv(GetCurSym()->text,yuyivar.currbl))
	{
	case -1:
		m_nErrorNum=31;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	case 0:
		addid(GetCurSym()->text,typ,1,leveltab[yuyivar.currbl].recl);
		leveltab[yuyivar.currbl].varnum++;
		leveltab[yuyivar.currbl].recl+=typ;
		break;
	default:
		m_nErrorNum=32;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy end
	NextSym();
	while (GetCurSym()->type==32) //,
	{
		NextSym();
		switch (GetCurSym()->type)
		{
		case 1://id
			break;
		default:
			m_nErrorNum=14;
			m_nErrorAddress=m_pCurSym;
			return FALSE;
		}
//yy
		switch (lookupv(GetCurSym()->text,yuyivar.currbl))
		{
		case -1:
			m_nErrorNum=31;
			m_nErrorAddress=m_pCurSym;
			return FALSE;
		case 0:
			addid(GetCurSym()->text,typ,1,leveltab[yuyivar.currbl].recl);
			leveltab[yuyivar.currbl].varnum++;
			leveltab[yuyivar.currbl].recl+=typ;
			break;
		default:
			m_nErrorNum=32;
			m_nErrorAddress=m_pCurSym;
			return FALSE;
		}
//yy end
		NextSym();
	}
	return TRUE;
}

int CComplier::r_GuoChengShuoMing()
{
	switch (GetCurSym()->type)
	{
	case 5://procedure
		break;
	default:
		m_nErrorNum=15;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	switch (GetCurSym()->type)
	{
	case 1://id
		break;
	default:
		m_nErrorNum=13;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy
	int link1=yuyivar.nxq;
	gen("j",0,0,0,0,0,0);
	leveltab[yuyivar.lastbl].lnp=yuyivar.nxq;
	leveltab[yuyivar.lastbl].lnum=yuyivar.lastbl;
	::strcpy(leveltab[yuyivar.lastbl].name,GetCurSym()->text);
	leveltab[yuyivar.lastbl].outern=yuyivar.currbl;
	leveltab[yuyivar.lastbl].parnum=0;
	leveltab[yuyivar.lastbl].pointer=yuyivar.lasent;
	leveltab[yuyivar.lastbl].recl=4;
	leveltab[yuyivar.lastbl].temp=yuyivar.tempp;
	leveltab[yuyivar.lastbl].varnum=0;
	yuyivar.currbl=yuyivar.lastbl;
	int v=lookupp(GetCurSym()->text);
	yuyivar.lastbl++;
	if (v!=-1)
	{
		m_nErrorNum=32;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	int link2=yuyivar.nxq;
	gen("in",0,0,0,0,0,0);
//yy end
	NextSym();
	switch (GetCurSym()->type)
	{
	case 33://(
		if (!r_XingChanBuFeng()) return FALSE;
		break;
	default:
		;
	}
	switch (GetCurSym()->type)
	{
	case 30://;
		break;
	default:
		m_nErrorNum=5;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_ChengXuTi()) return FALSE;
//yy
	backpatch(link2,2,2,leveltab[yuyivar.currbl].recl);
	gen("out",0,0,0,0,0,0);
	gen("ret",0,0,0,0,0,0);
	backpatch(link1,4,2,yuyivar.nxq);
	yuyivar.currbl=leveltab[yuyivar.currbl].outern;
	yuyivar.tempp=leveltab[yuyivar.currbl].temp;
//yy end
	return TRUE;
}

int CComplier::r_XingChanBuFeng()
{
	switch (GetCurSym()->type)
	{
	case 33://(
		break;
	default:
		m_nErrorNum=16;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_XingChan()) return FALSE;
	while (GetCurSym()->type==30)
	{
		NextSym();
		if (!r_XingChan()) return FALSE;
	}
	switch (GetCurSym()->type)
	{
	case 34://)
		break;
	default:
		m_nErrorNum=17;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	return TRUE;
}

int CComplier::r_XingChan()
{
	int parn;//yy
	if (GetCurSym()->type==4)//var
	{
		NextSym();parn=1;//yy
	}
	else parn=0;//yy
	switch (GetCurSym()->type)
	{
	case 1://id
		break;
	default:
		m_nErrorNum=18;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy
	if (lookupv(GetCurSym()->text,yuyivar.currbl)!=0)
	{
		m_nErrorNum=32;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	int link=yuyivar.lasent;
	addid(GetCurSym()->text,0,3+parn,0);
	leveltab[yuyivar.currbl].parnum++;
//yy end
	NextSym();
	while (GetCurSym()->type==32)//,
	{
		NextSym();
		switch (GetCurSym()->type)
		{
		case 1://id
			break;
		default:
			m_nErrorNum=18;
			m_nErrorAddress=m_pCurSym;
			return FALSE;
		}
//yy
		if (lookupv(GetCurSym()->text,yuyivar.currbl)!=0)
		{
			m_nErrorNum=32;
			m_nErrorAddress=m_pCurSym;
			return FALSE;
		}
		addid(GetCurSym()->text,0,3+parn,0);
		leveltab[yuyivar.currbl].parnum++;
//yy end
		NextSym();
	}
	switch (GetCurSym()->type)
	{
	case 35://:
		break;
	default:
		m_nErrorNum=19;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	int typ;//yy
	switch (GetCurSym()->type)
	{
	case 14://integer
		typ=1;//yy
		break;
	case 15://real
		typ=2;//yy
		break;
	default:
		m_nErrorNum=12;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
//yy
	for (int i=link;i<yuyivar.lasent;i++)
	{
		idtab[i].typ=typ;
		idtab[i].addr=leveltab[yuyivar.currbl].recl;
		leveltab[yuyivar.currbl].recl+=typ;
		if (parn) gen("addr",1,i-link+1,0,0,0,0);
		else if (typ==1) gen("valueI",1,i-link+1,0,0,0,0);
		else gen("valueR",1,i-link+1,0,0,0,0);
	}
	leveltab[yuyivar.currbl].recl+=leveltab[yuyivar.currbl].lnum;
//yy end
	return TRUE;
}

int CComplier::r_YuJuChuan()
{
	if (!r_YuJu()) return FALSE;
	while (GetCurSym()->type==30)//;
	{
		NextSym();
		if (!r_YuJu()) return FALSE;
	}
	return TRUE;
}

int CComplier::r_YuJu()
{
	switch (GetCurSym()->type)
	{
	case 6://begin
		if (!r_FuHeYuJu()) return FALSE;
		break;
	case 1://id
		if (!r_FuZhiYuJu()) return FALSE;
		break;
	case 8://if
		if (!r_TiaoJianYuJu()) return FALSE;
		break;
	case 11://while
		if (!r_XunHuanYuJu()) return FALSE;
		break;
	case 13://call
		if (!r_GuoChengYuJu()) return FALSE;
		break;
	default:
		m_nErrorNum=9;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	return TRUE;
}

int CComplier::r_FuHeYuJu()
{
	switch (GetCurSym()->type)
	{
	case 6://begin
		break;
	default:
		m_nErrorNum=8;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_YuJuChuan()) return FALSE;
	switch (GetCurSym()->type)
	{
	case 7://end
		break;
	default:
		m_nErrorNum=10;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	return TRUE;
}

int CComplier::r_FuZhiYuJu()
{
	switch (GetCurSym()->type)
	{
	case 1://id
		break;
	default:
		m_nErrorNum=20;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy
	int idlevel=yuyivar.currbl;
	int idpoint=lookupv2(GetCurSym()->text,idlevel);
	if (idpoint==0)
	{
		m_nErrorNum=33;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	if (idpoint==-1)
	{
		m_nErrorNum=34;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	int t1=idtab[idpoint].typ;
	int k1=idtab[idpoint].addr;
	int i1;
	if (idlevel==yuyivar.currbl)
	{
		if (idtab[idpoint].kind==4) i1=5;
		else i1=4;
	}
	else
	{
		i1=idlevel+6;
	}
//yy end
	NextSym();
	switch (GetCurSym()->type)
	{
	case 29://:=
		break;
	default:
		m_nErrorNum=21;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_BiaoDaShi()) return FALSE;
//yy
	int t2;
	int k2;
	int i2=yuyivalue.Etyp;
	int j2=yuyivalue.Evalue;
	if (i2==1)
	{
		k2=j2;
		t2=1;
	}
	else if (i2==2)
	{
		k2=temptab[j2].taddr;
		t2=temptab[j2].typ;
		i2=3;
	}
	else
	{
		k2=idtab[j2].addr;
		t2=idtab[j2].typ;
		i2+=1;
	}
	if (t1<t2)
	{
		m_nErrorNum=35;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	if (t1==1) gen(":=I",i1,k1,i2,k2,0,0);
	else gen(":=R",i1,k1,i2,k2,0,0);
	if (i2==3) temptab[j2].used=FALSE;
//yy end
	return TRUE;
}

int CComplier::r_TiaoJianYuJu()
{
	switch (GetCurSym()->type)
	{
	case 8://if
		break;
	default:
		m_nErrorNum=22;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_BuErBiaoDaShi()) return FALSE;
//yy
	int TCexit=yuyivalue.TC;
	int FCexit=yuyivalue.FC;
	backpatch(TCexit,4,2,yuyivar.nxq);
//yy end
	switch (GetCurSym()->type)
	{
	case 9://then
		break;
	default:
		m_nErrorNum=23;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_YuJu()) return FALSE;
//yy
	int link=yuyivar.nxq;
	gen("j",0,0,0,0,0,0);
//yy end
	switch (GetCurSym()->type)
	{
	case 10://else
		NextSym();
		backpatch(FCexit,4,2,yuyivar.nxq);//yy
		if (!r_YuJu()) return FALSE;
		break;
	default:
		backpatch(FCexit,4,2,yuyivar.nxq);//yy
	}
	backpatch(link,4,2,yuyivar.nxq);//yy
	return TRUE;
}

int CComplier::r_XunHuanYuJu()
{
	switch (GetCurSym()->type)
	{
	case 11://while
		break;
	default:
		m_nErrorNum=24;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	int p=yuyivar.nxq;//yy
	if (!r_BuErBiaoDaShi()) return FALSE;
//yy
	int TCexit=yuyivalue.TC;
	int FCexit=yuyivalue.FC;
	backpatch(TCexit,4,2,yuyivar.nxq);
//yy end
	switch (GetCurSym()->type)
	{
	case 12://do
		break;
	default:
		m_nErrorNum=25;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	if (!r_YuJu()) return FALSE;
//yy
	gen("j",0,0,0,0,2,p);
	backpatch(FCexit,4,2,yuyivar.nxq);
//yy end
	return TRUE;
}

int CComplier::r_GuoChengYuJu()
{
	switch (GetCurSym()->type)
	{
	case 13://call
		break;
	default:
		m_nErrorNum=26;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
	NextSym();
	switch (GetCurSym()->type)
	{
	case 1://id
		break;
	default:
		m_nErrorNum=27;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy
	int level=lookupp(GetCurSym()->text);
	yuyivalue.disp=level;
	if (level>yuyivar.currbl+1)
	{
		m_nErrorNum=40;
		m_nErrorAddress=m_pCurSym;
		return FALSE;
	}
//yy end
	NextSym();
	switch (GetCurSym()->type)
	{
	case 33://(
		break;
	default:
		return TRUE;
	}
	if (!r_ShiChanBiao()) return FALSE;
//yy

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91对白在线观看九色| 亚洲高清中文字幕| 亚洲黄一区二区三区| 日韩高清在线不卡| 国产精品一区二区在线观看网站| 972aa.com艺术欧美| 欧美久久久一区| 国产日韩欧美a| 亚洲日本电影在线| 美女视频黄免费的久久| av中文字幕在线不卡| 69堂精品视频| 国产精品国模大尺度视频| 亚洲高清视频的网址| 国产美女娇喘av呻吟久久| 色婷婷久久一区二区三区麻豆| 欧美一级片免费看| 中文字幕一区二区三| 毛片一区二区三区| 91美女在线看| 国产亚洲精品中文字幕| 亚洲国产综合人成综合网站| 国产精品77777| 91精品婷婷国产综合久久| 国产精品网站在线播放| 免费看黄色91| 在线观看精品一区| 国产日韩欧美精品电影三级在线| 亚洲一区二区欧美日韩| 国产成都精品91一区二区三| 制服丝袜亚洲播放| 综合精品久久久| 国产精品一区免费视频| 欧美日韩国产免费| 国产精品久久久爽爽爽麻豆色哟哟| 日韩精品91亚洲二区在线观看| 成人毛片在线观看| 日韩欧美成人一区| 亚洲永久免费av| 99精品视频一区二区| 精品日韩在线一区| 亚洲一区二区三区视频在线 | 欧美日韩成人在线一区| 亚洲天堂福利av| 国产一区二区精品久久91| 欧美高清视频一二三区 | 欧美日韩免费观看一区三区| 国产精品久久毛片a| 麻豆91在线播放免费| 欧美在线视频你懂得| 欧美国产精品专区| 韩国av一区二区三区四区| 制服丝袜日韩国产| 亚洲综合图片区| 色哟哟亚洲精品| 国产精品人人做人人爽人人添| 黄色资源网久久资源365| 欧美精品精品一区| 亚洲国产视频一区二区| 色偷偷88欧美精品久久久| 综合精品久久久| av高清不卡在线| 欧美极品少妇xxxxⅹ高跟鞋| 国产一区二区网址| 精品嫩草影院久久| 久久精品国产精品亚洲红杏 | 蜜桃91丨九色丨蝌蚪91桃色| 欧美性色欧美a在线播放| 亚洲婷婷在线视频| 成人av在线影院| 国产精品久久久久影院| 成人精品免费看| 国产精品国产成人国产三级 | 亚洲国产美女搞黄色| 欧美在线观看一区二区| 一区二区免费在线| 一本大道av一区二区在线播放| 亚洲精品中文字幕在线观看| 色噜噜狠狠色综合中国| 一区二区三区四区不卡在线 | 亚洲综合自拍偷拍| 在线视频欧美精品| 天天综合天天综合色| 日韩三级视频在线看| 国产一区二三区好的| 国产亚洲成av人在线观看导航 | 综合久久一区二区三区| 91女人视频在线观看| 亚洲美女免费在线| 在线观看一区日韩| 性欧美疯狂xxxxbbbb| 亚洲图片你懂的| 97精品国产97久久久久久久久久久久 | 午夜电影一区二区三区| 日韩一卡二卡三卡| 国产一区二区三区美女| 国产精品久久久久久久久果冻传媒| 99精品久久99久久久久| 一区二区三区四区视频精品免费 | 日韩vs国产vs欧美| 26uuu久久综合| 成人av免费在线| 午夜精品免费在线观看| 精品久久久久香蕉网| 成人一区二区三区中文字幕| 亚洲视频综合在线| 日韩写真欧美这视频| 国产一区二区导航在线播放| 亚洲视频一区二区免费在线观看| 欧美伦理影视网| 国产一区二区在线视频| 亚洲激情欧美激情| 久久综合精品国产一区二区三区| 99re这里只有精品视频首页| 日韩电影在线一区二区| 国产日韩精品一区二区浪潮av | 免费在线看一区| 国产精品免费av| 欧美男同性恋视频网站| 国产99精品国产| 亚洲风情在线资源站| 久久久亚洲高清| 91九色最新地址| 国产一区二区三区在线观看免费视频| 亚洲欧美自拍偷拍| 日韩欧美亚洲国产精品字幕久久久| 波多野结衣中文一区| 日韩高清不卡一区二区| 国产精品对白交换视频| 欧美岛国在线观看| 在线亚洲一区观看| 国产高清视频一区| 日韩电影免费在线看| 国产精品不卡在线| 欧美成人a∨高清免费观看| 色欧美片视频在线观看在线视频| 精品在线免费视频| 亚洲成a人片综合在线| 国产欧美日韩三级| 精品美女在线观看| 欧美日韩一级二级| 99久久er热在这里只有精品66| 国产一区二区在线视频| 视频一区二区欧美| 亚洲综合小说图片| 国产精品国产三级国产普通话蜜臀 | 亚洲欧美日韩国产一区二区三区 | 成人午夜激情视频| 精品制服美女久久| 天堂午夜影视日韩欧美一区二区| 中文字幕制服丝袜一区二区三区| 精品久久人人做人人爱| 欧美日韩一区二区在线视频| 91网站最新地址| 国产成人精品影视| 九一九一国产精品| 日韩在线一二三区| 亚洲一级片在线观看| 亚洲欧美综合色| 国产精品少妇自拍| 国产三级一区二区三区| 精品国产乱码久久久久久图片| 在线免费一区三区| 色呦呦网站一区| 波多野结衣中文字幕一区二区三区| 国产一区二区三区电影在线观看| 免费视频一区二区| 视频在线在亚洲| 亚洲国产精品尤物yw在线观看| 亚洲精品国产品国语在线app| 国产精品伦一区二区三级视频| 2017欧美狠狠色| 精品国产乱子伦一区| 久久综合狠狠综合久久综合88| 日韩女优电影在线观看| 欧美一区二区视频网站| 欧美精品tushy高清| 欧美男生操女生| 69久久99精品久久久久婷婷| 欧美美女激情18p| 91精品国产综合久久久久久漫画 | 国内国产精品久久| 国产一区二区伦理| 大胆欧美人体老妇| 97aⅴ精品视频一二三区| 色婷婷综合久久久中文字幕| 91亚洲午夜精品久久久久久| 色一情一乱一乱一91av| 欧美综合视频在线观看| 欧美日韩免费在线视频| 日韩一区二区三区高清免费看看| 欧美一级日韩免费不卡| 精品国一区二区三区| 久久亚洲精品国产精品紫薇| 国产欧美日韩麻豆91| 亚洲婷婷综合久久一本伊一区 | 欧美一三区三区四区免费在线看| 日韩精品一区二区三区视频播放 | 97se狠狠狠综合亚洲狠狠| 欧美性生交片4|