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

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

?? 20080817.cpp

?? 清華大學編譯原理的PL0源代碼
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
//A.2     C      版   本

/*編譯和運行環境:
*1Visual C++6.0,VisualC++.NET and Visual C++.NET 2003
*WinNT, Win 200, WinXP and  Win2003 
*2 gcc version 3.3.2  20031022(Red Hat Linux 3.3.2-1)
*Redhat Fedora core 1
*Intel 32 platform
*使用方法:
*運行后輸入PL/0 源程序文件名
*回答是否輸出虛擬機代碼
*回答是否輸出名字表
*fa.tmp 輸出虛擬機代碼
*fa1.tmp  輸出源文件及其各行對應的首地址
*fa2.tmp  輸出結果 
*fas.tmp  輸出名字表
*/
#include<stdio.h>
#include"pl0.h"
#include"string.h"
/*解釋執行時使用的棧*/
#define stacksize 500
int main()
{
	bool nxtlev[symnum];
	printf("Input pl/0 file ?");
	scanf("%s",fname);                                     /*輸入文件名*/
	fin=fopen(fname,"r");
	if(fin)
	{
		printf("List object code ?(Y/N)");                /*是否輸出虛擬機代碼*/
		scanf("%s",fname);
		listswitch=(fname[0]=='y'||fname[0]=='Y');
		printf("List symbol table ? (Y/N)");             /*是否輸出名字表*/
		scanf("%s",fname);
		tableswitch=(fname[0]=='y'||fname[0]=='Y');
		fa1=fopen("fa1.tmp","w");
		fprintf(fa1,"Iput pl/0 file ?");
		fprintf(fa1,"%s\n", fname);
		init();                                          /*初始化*/
		err=0;
		cc=cx=ll=0;
		ch=' ';
		if(-1!=getsym())
		{
			fa=fopen("fa.tmp","w");
			fas=fopen("fas.tmp","w");
			addset(nxtlev,declbegsys,statbegsys,symnum);
			nxtlev[period]=true;    
			if(-1==block(0,0,nxtlev))			/*調用編譯程序*/
			{
				fclose(fa);
				fclose(fa1);
				fclose(fas);
				fclose(fin);
				printf("\n");
				return 0;
			}
			fclose(fa);
			fclose(fa1);
			fclose(fas);
			if(sym!=period)
			{
				error(9);
			}
			if(err==0)
			{
				fa2=fopen("fa2.tmp", "w");
				interpret();
				fclose(fa2);
			}
			else
			{
				printf("Errors in pl/0 program");
			}
		}
		fclose(fin);
	}
	else
	{
		printf("Can't open file! \n");
	}
	printf("\n");
	return 0;
}
/*
*初始化
*/
void init()
{
	int i;
	for(i=0;i<=255;i++)
	{
		ssym[i]=nul;
	}
	ssym['+']=plus;
	ssym['-']=minus;
	ssym['*']=times;
	ssym['/']=slash;
	ssym['(']=lparen;
	ssym[')']=rparen;
	ssym['=']=eql;
	ssym[',']=comma;
	ssym['.']=period;
	ssym['#']=neq;
	ssym[';']=semicolon;
	/*設置保留字名字,按照字母順序,便于折半查找*/
	strcpy(&(word[0][0]),"begin");
	strcpy(&(word[1][0]),"call");
    strcpy(&(word[2][0]),"charcst");
    strcpy(&(word[3][0]),"charvar");
	strcpy(&(word[4][0]),"const");
	strcpy(&(word[5][0]),"do");
	strcpy(&(word[6][0]),"downto");
	strcpy(&(word[7][0]),"else");
	strcpy(&(word[8][0]),"end");
	strcpy(&(word[9][0]),"for");
	strcpy(&(word[10][0]),"if");
	strcpy(&(word[11][0]),"odd");
	strcpy(&(word[12][0]),"procedure");
	strcpy(&(word[13][0]),"read");
	strcpy(&(word[14][0]),"then");
	strcpy(&(word[15][0]),"to");
	strcpy(&(word[16][0]),"var");
	strcpy(&(word[17][0]),"while");
	strcpy(&(word[18][0]),"write");
	/*設置保留字符號*/
	wsym[0]=beginsym;
	wsym[1]=callsym;
    wsym[2]=charcstsym;
	wsym[3]=charvarsym;
    wsym[4]=constsym;
	wsym[5]=dosym;
    wsym[6]=downtosym;
    wsym[7]=elsesym;
	wsym[8]=endsym;
	wsym[9]=forsym;
	wsym[10]=ifsym;
	wsym[11]=oddsym;
	wsym[12]=procsym;
	wsym[13]=readsym;
	wsym[14]=thensym;
    wsym[15]=tosym;
	wsym[16]=varsym;
	wsym[17]=whilesym;
	wsym[18]=writesym;

	/*設置指令名稱*/
	strcpy(&(mnemonic[lit][0]),"lit");
	strcpy(&(mnemonic[opr][0]),"opr");
	strcpy(&(mnemonic[lod][0]),"lod");
	strcpy(&(mnemonic[sto][0]),"sto");
	strcpy(&(mnemonic[cal][0]),"cal");
	strcpy(&(mnemonic[inte][0]),"int");
	strcpy(&(mnemonic[jmp][0]),"jmp");
	strcpy(&(mnemonic[jpc][0]),"jpc");

	/*設置符號集*/
	for(i=0;i<symnum;i++)
	{
		declbegsys[i]=false;
		statbegsys[i]=false;
		facbegsys[i]=false;
	}

	/*設置聲明開始符號集*/
	declbegsys[constsym]=true;
	declbegsys[varsym]=true;
	declbegsys[procsym]=true;
	declbegsys[charcst]=true;
	declbegsys[charvar]=true;
	/*設置語句開始符號集*/
	statbegsys[beginsym]=true;
	statbegsys[callsym]=true;
	statbegsys[ifsym]=true;
	statbegsys[whilesym]=true;
	/*設置因子開始符號集*/
	facbegsys[ident]=true;
	facbegsys[number]=true;
	facbegsys[character]=true;
	facbegsys[lparen]=true;
}
 /*
  *用數組實現集合的集合運算
  */
int inset(int e,bool* s)
{
    return s[e];
}
int addset(bool* sr,bool* s1,bool* s2,int n)
{
    int i;
    for(i=0;i<n;i++)
    {
       sr[i]=s1[i]||s2[i];  
    }
    return 0;
}
int subset(bool* sr,bool* s1,bool* s2,int n)
{
    int i;
    for(i=0;i<n;i++)
    {
       sr[i]=s1[i]&&(!s2[i]);
    }
    return 0; 
}
int mulset(bool* sr,bool* s1,bool* s2,int n)
{
    int i;
    for(i=0;i<n;i++)
    {
       sr[i]=s1[i]&&s2[i];  
    } 
    return 0;
}
/*
 *出錯處理,打印出錯位置和錯誤編碼
 */
void error(int n)
 
{
	char space[81];
	memset(space,32,81); printf("-------%c\n",ch);
	space[cc-1]=0;//出錯時當前符號已經讀完,所以cc-1
	printf("****%s!%d\n",space,n);
	err++;
}
/*
 *  漏掉空格,讀取一個字符
 *
 *  每次讀一行,存入line緩沖區,line被getsym取空后再讀一行
 *
 *  被函數getsym調用
 */
int getch()
{
	if(cc==ll)
    {
		if(feof(fin))
		{
			printf("program incomplete");
			return -1;
		}
		ll=0;
		cc=0;
		printf("%d ",cx );
		fprintf(fa1,"%d ",cx);
		ch=' ';
		while(ch!=10)
		{
			//fscanf(fin,"%c",&ch)
            if(EOF==fscanf(fin,"%c",&ch))
			{
				line[ll]=0;
				break;
			}
			printf("%c",ch);
			fprintf(fa1,"%c",ch);
			line[ll]=ch;
			ll++;
		}
		printf("\n");
		fprintf(fa1,"\n");
	}
	ch=line[cc];
	cc++;
	return 0;
}
 /*詞法分析,獲取一個符號
 */

int getsym()
{
	int i,j,k;
	while( ch==' '||ch==10||ch==9)
	{
		getchdo;
	}
	if(ch>='a'&&ch<='z')
	{ 
		k=0;
		do{
			if(k<al)
			{ 
				a[k]=ch;
				k++;
			}
			getchdo; 
		}while(ch>='a'&&ch<='z'||ch>='0'&&ch<='9');
		a[k]=0;
		strcpy(id,a);
		i=0;
		j=norw-1;
		do{
			k=(i+j)/2;
			if(strcmp(id,word[k])<=0)
			{
				j=k-1;
			}
			if(strcmp(id,word[k])>=0)
			{
				i=k+1;
			}

		}while(i<=j);
		if(i-1>j)
		{
			sym=wsym[k];
		}
		else
		{
			sym=ident;
		}
	}
	else
	{
		if(ch>='0'&&ch<='9')
		{
			k=0;
			num=0;
			sym=number;
			do{
				num=10*num+ch-'0';
				k++;
				getchdo;
			}while(ch>='0'&&ch<='9'); /*獲取數字的值*/
			k--;
			if(k>nmax)
			{
				error(30);
			}
		}
		else
		{
			if(ch==':')             /*檢測賦值符號*/
			{
				getchdo;
				if(ch=='=')
				{
					sym=becomes;
					getchdo;
				}
				else
				{
					sym=nul;            /*不能識別的符號*/
				}
			}

            else if(ch=='\'')
			{
		     sym=character;
             getchdo;
		     chartmp=ch;
             getchdo;
		     if(ch!='\'')
			 {
		          error(34);
			 }
	 		 getchdo;
			}

else if(ch=='+')
			{
			     getchdo;
				 if(ch=='=')
				 {
				     sym=xplus;
					 getchdo;
				 }
				 else if(ch=='+')
				 {
				     sym=splus;
					 getchdo;
				 }
				 else 
				 {
				   sym=plus;
				 }
			}
            else if(ch=='-')
			{
			     getchdo;
				 if(ch=='=')
				 {
				     sym=xminus;
					 getchdo;
				 }
				 else if(ch=='-')
				 {
				     sym=sminus;
					 getchdo;
				 }
				 else
				 {
				      sym=minus;
				 } 
			}
			else
			{
				if(ch=='<')         /*檢測小于或小于等于符號*/
				{
					getchdo;
					if(ch=='=')
					{
						sym=leq;
						getchdo;
					}
					else
					{ 
						sym=lss;
					}
				}
				else
				{
					if(ch=='>')          /*檢測大于或大于等于符號*/
					{
						getchdo;
						if(ch=='=')
						{
							sym=geq;
							getchdo;
						}
						else
						{
						    sym=gtr;
						}
					}
					else
					{
						sym=ssym[ch];/* 當符號不滿足上述條件時,全部按照單字符號處理*/
						//getchdo;
						//richard
						if(sym!=period)
						{
							getchdo;
						}
						//end richard
					}
				}
			}
		}
	}
	return 0;
}
/*
*生成虛擬機代碼
*
*x:instruction.f;
*y:instruction.l;
*z:instruction.a;
*/
int gen(enum fct x,int y,int z)
{
	if(cx>=cxmax)
	{
		printf("Program too long"); /*程序過長*/
		return -1;
	}
	code[cx].f=x;
	code[cx].l=y;
	code[cx].a=z;
	cx++;
	return 0;
}
/*
*測試當前符號是否合法
*
*在某一部分(如一條語句,一個表達式)將要結束時時我們希望下一個符號屬于某集合
*(該部分的后跟符號) test 負責這項檢測,并且負責當檢測不通過時的補救措施
*程序在需要檢測時指定當前需要的符號集合和補救用的集合(如之前未完成部分的后跟
*符號),以及不通過時的錯誤號
*
*S1:我們需要的符號
*s2:如果不是我們需要的,則需要一個補救用的集合
*n:錯誤號
*/


int test(bool* s1,bool* s2,int n)
{
    if(! inset(sym,s1))
    {
		error(n);
		/*當檢測不通過時,不停獲取符號,直到它屬于需要的集合或補救的集合*/
		while((! inset(sym,s1))&&(! inset(sym,s2)))
		{
			getsymdo; 
		}
    }
    return 0;
}
/*
 *編譯程序主體
 *
 *lev:當前分程序所在層
 *tx:名字表當前尾指針
 *fsys:當前模塊后跟符號集合
 */
int block(int lev,int tx,bool* fsys)
{
    int i;
    int dx;                         /*名字分配到的相對地址*/
    int tx0;                        /*保留初始tx*/
    int cx0;                        /*保留初始cx*/
    bool nxtlev[symnum];            /*在下級函數的參數中,符號集合均為值參,但由于使用數組
                                      實現,傳遞進來的是指針,為防止下級函數改變上級函數的
                                      集合,開辟新的空間傳遞給下級函數*/
    dx=3;
    tx0=tx;                         /*記錄本層名字的初始位置*/
    table[tx].adr=cx;
    gendo(jmp,0,0);
    if(lev > levmax)
    {
		error(32);                                                                                                                                         
    }
    do{
        if(sym==constsym)         /*收到常量聲明符號,開始處理常量聲明*/
        {
			getsymdo;
			do{
                constdeclarationdo(&tx,lev,&dx);   /*dx的值會被constdeclaration改變,使用
                                                     指針*/
                while(sym==comma)
                {
                   getsymdo;
                   constdeclarationdo(&tx,lev,&dx);
                }
                if(sym==semicolon)
                {
                  getsymdo;
				}
				else
				{
					error(5); /*漏掉了逗號或者分號*/
				}
			}while(sym==ident);
		}
		if(sym==varsym)/*收到變量聲名符號,開始處理變量聲名*/
		{
			getsymdo;
			do{
				vardeclarationdo(&tx,lev,&dx);
				while(sym==comma)

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩www| 欧美剧情片在线观看| 成人视屏免费看| xf在线a精品一区二区视频网站| 91在线你懂得| 欧美国产精品一区| 成人国产精品免费观看动漫| 亚洲国产日产av| 国产精品对白交换视频| 26uuu精品一区二区| 91麻豆精品久久久久蜜臀| 99在线精品观看| 成人在线视频一区二区| 久久丁香综合五月国产三级网站| 欧美国产丝袜视频| 久久精品噜噜噜成人88aⅴ| 精品美女一区二区| 99国产精品久久久久久久久久久 | 国产精品久久久久影院色老大| 亚洲成在线观看| 3d成人动漫网站| 国产精品99久久久久久似苏梦涵| 久久你懂得1024| 色婷婷综合久久久久中文一区二区 | 欧美性高清videossexo| 亚洲免费视频成人| 精品久久久久香蕉网| av成人免费在线观看| 亚洲一区二区三区视频在线 | 亚洲成av人片在www色猫咪| 欧美精品一级二级| 成人三级伦理片| 亚洲va欧美va人人爽| 亚洲男人的天堂网| 99精品国产视频| 成人丝袜高跟foot| 色悠久久久久综合欧美99| 裸体健美xxxx欧美裸体表演| 成人激情黄色小说| 不卡欧美aaaaa| 国产亚洲美州欧州综合国| av一区二区三区| 欧美一区二区三区四区五区| 午夜视黄欧洲亚洲| 经典三级一区二区| 久久爱www久久做| 久久国产欧美日韩精品| 美腿丝袜亚洲色图| 国产精品一线二线三线精华| 国产麻豆成人精品| 99天天综合性| 欧美日韩一区二区不卡| 91精品国模一区二区三区| 色狠狠桃花综合| 波多野结衣一区二区三区 | 欧美一区二区三区思思人| 99国产精品久久久| 国产精品18久久久久久久久| 日韩专区欧美专区| 夜夜操天天操亚洲| 午夜精品久久久久久不卡8050| 中文字幕一区二区三区在线观看| 精品福利一二区| 久久久久久久久一| 日本一区二区高清| 亚洲图片激情小说| 自拍视频在线观看一区二区| 国产精品女同互慰在线看| 国产农村妇女精品| 亚洲欧美日韩小说| 亚洲6080在线| 极品少妇xxxx精品少妇偷拍| 国产揄拍国内精品对白| www.在线成人| 制服丝袜亚洲色图| 欧美成人bangbros| 亚洲一区在线观看免费| 亚洲精品ww久久久久久p站 | 国产经典欧美精品| 国产三级久久久| 麻豆91在线观看| 国产一区二区美女诱惑| 三级在线观看一区二区| 成人深夜在线观看| 调教+趴+乳夹+国产+精品| 精品国产成人系列| 欧美熟乱第一页| 久久婷婷综合激情| 亚洲18色成人| eeuss鲁一区二区三区| 日韩欧美一区二区不卡| 亚洲欧美精品午睡沙发| 国产黄色精品视频| 欧美精品在线视频| 亚洲乱码中文字幕| 国产盗摄精品一区二区三区在线| 欧美tk—视频vk| 亚洲一区二区三区视频在线| 国产福利不卡视频| 91精品国产欧美一区二区18| 综合av第一页| 国产福利视频一区二区三区| 欧美日韩在线播| 91麻豆精品国产综合久久久久久 | 亚洲欧美二区三区| 高清在线不卡av| 亚洲风情在线资源站| 欧美激情一区二区三区蜜桃视频 | 91久久线看在观草草青青 | 国产欧美日产一区| 777精品伊人久久久久大香线蕉| 国产一本一道久久香蕉| 亚洲成人黄色小说| 亚洲与欧洲av电影| 中文字幕一区三区| 久久久影院官网| 日韩欧美一级二级三级久久久| 欧美日韩中字一区| 精品一区中文字幕| 欧美一区二区三区男人的天堂| 日本中文字幕一区二区有限公司| 精品视频在线视频| 日本欧美一区二区| 亚洲免费伊人电影| 91精品国产色综合久久久蜜香臀| 色八戒一区二区三区| 91成人国产精品| 亚洲精品久久久久久国产精华液| 不卡一区二区中文字幕| 国产欧美一区二区精品久导航 | 午夜精品福利一区二区三区蜜桃| 99久久精品免费| 1区2区3区国产精品| 国产99久久久久| 国产精品嫩草影院av蜜臀| 丁香六月综合激情| 中文字幕亚洲视频| 一本到一区二区三区| 亚洲一区二区视频| 欧美日韩你懂的| 秋霞电影一区二区| 精品日韩在线观看| 国产成人精品亚洲午夜麻豆| 久久精品人人做人人综合| 成人午夜激情在线| 樱桃视频在线观看一区| 欧美日韩免费观看一区三区| 天天影视涩香欲综合网 | 日韩视频123| 国内精品国产成人| 国产精品情趣视频| 日本乱码高清不卡字幕| 午夜电影一区二区三区| 欧美mv日韩mv亚洲| 成人国产一区二区三区精品| 亚洲麻豆国产自偷在线| 欧美日韩黄视频| 国产精品一区二区在线播放| 欧美激情一区二区三区蜜桃视频 | 6080日韩午夜伦伦午夜伦| 久久99精品国产麻豆婷婷| 国产欧美一区视频| 欧亚一区二区三区| 精品系列免费在线观看| 国产精品另类一区| 欧美色综合天天久久综合精品| 免费人成在线不卡| 中文一区二区完整视频在线观看| 色激情天天射综合网| 久草在线在线精品观看| 中文幕一区二区三区久久蜜桃| 在线亚洲+欧美+日本专区| 精品在线你懂的| 亚洲免费av观看| 日韩午夜av一区| 93久久精品日日躁夜夜躁欧美| 午夜久久久久久久久| 国产丝袜欧美中文另类| 欧美日韩国产美女| 成人h精品动漫一区二区三区| 亚洲国产精品久久久久婷婷884| 欧美成人在线直播| 色婷婷久久久久swag精品 | 亚洲免费大片在线观看| 精品久久人人做人人爱| 一本一道综合狠狠老| 国产一二精品视频| 性做久久久久久久久| 亚洲欧美在线视频观看| 精品区一区二区| 欧美视频在线观看一区| 成人午夜在线视频| 麻豆中文一区二区| 亚洲一区二区高清| 国产精品国产三级国产aⅴ无密码| 欧美一区欧美二区| 日本道在线观看一区二区| 国产成人丝袜美腿| 蜜桃视频第一区免费观看| 一区二区三区四区在线免费观看|