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

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

?? parse.cpp

?? 編譯原理學習使用的代碼 內容有從詞法分析到中間代碼生成的代碼 并且含有注釋
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
/* 功  能 函數聲明中參數聲明部分的處理函數	        	        	*/
/* 產生式 < paramDecList > ::=  param  paramMore                    */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * paramDecList(void)
{
	TreeNode * t = param();
	TreeNode * p = paramMore();
	if (p!=NULL)
	{
		t->sibling = p;
	}
	return t;
}

/********************************************************************/
/* 函數名 paramMore		 			    	                        */
/* 功  能 函數聲明中參數聲明部分的處理函數	        	        	*/
/* 產生式 < paramMore > ::=  ε | ; paramDecList                     */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * paramMore(void)
{
	TreeNode * t = NULL;
	switch(token.Lex)
	{
	case RPAREN:   break;
	case SEMI:
		match(SEMI);
		t = paramDecList();
		if (t==NULL)
			syntaxError("a param declaration is request!");
		break;
    default:
		ReadNextToken(&token);
		syntaxError("unexpected token is here!");
		break;
	}
	return t;
}

/********************************************************************/
/* 函數名 param		 			    	                            */
/* 功  能 函數聲明中參數聲明部分的處理函數	        	        	*/
/* 產生式 < param > ::=  typeName formList | VAR typeName formList  */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * param(void)
{
	TreeNode * t = newDecNode();
	if (t!=NULL)
	{
		t->lineno = line0;
		switch(token.Lex)
		{
	     case INTEGER:
	     case CHAR:
	     case ARRAY:
	     case RECORD:
	     case ID:
	    	 t->attr.ProcAttr.paramt = valparamType;
			 typeName(t);
	    	 formList(t);
			 break;
		 case VAR:
			 match(VAR);
			 t->attr.ProcAttr.paramt = varparamType;
			 typeName(t);
			 formList(t);
			 break;
         default:
			 ReadNextToken(&token);
			 syntaxError("unexpected token is here!");
		     break;
		}
	}
	return t;
}

/********************************************************************/
/* 函數名 formList		 			    	                        */
/* 功  能 函數聲明中參數聲明部分的處理函數	        	        	*/
/* 產生式 < formList > ::=  id  fidMore                             */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
void formList(TreeNode * t)
{
	if (token.Lex==ID)
	{
		strcpy(t->name[(t->idnum)] ,token.Sem);
		t->idnum = (t->idnum) + 1;
		match(ID);
	}
	fidMore(t);   
}
		

/********************************************************************/
/* 函數名 fidMore		 			    	                        */
/* 功  能 函數聲明中參數聲明部分的處理函數	        	        	*/
/* 產生式 < fidMore > ::=   ε |  , formList                        */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
void fidMore(TreeNode * t)
{
	switch(token.Lex)
	{
	case SEMI:
	case RPAREN:   break;
	case COMMA:
		match(COMMA);
		formList(t);
		break;
	default:
		ReadNextToken(&token);
		syntaxError("unexpected token is here!");
		break;
	}
}
			
/********************************************************************/
/* 函數名 procDecPart		 			  	                        */
/* 功  能 函數中的聲明部分的處理函數	             	        	*/
/* 產生式 < procDecPart > ::=  declarePart                          */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * procDecPart(void)
{
     TreeNode * t = declarePart();
	 return t;
}

/********************************************************************/
/* 函數名 procBody		 			  	                            */
/* 功  能 函數體部分的處理函數	                    	        	*/
/* 產生式 < procBody > ::=  programBody                             */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * procBody(void)
{
	TreeNode * t = programBody();
	if (t==NULL)
		syntaxError("a program body is requested!");
	return t;
}

/********************************************************************/
/* 函數名 programBody		 			  	                        */
/* 功  能 程序體部分的處理函數	                    	        	*/
/* 產生式 < programBody > ::=  BEGIN  stmList   END                 */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * programBody(void)
{
	TreeNode * t = newStmlNode();
    match(BEGIN);
	if(t!=NULL)
	{
		t->lineno = 0;
		t->child[0] = stmList();
	}
    match(END);
    return t;
}


/********************************************************************/
/* 函數名 stmList		 			  	                            */
/* 功  能 語句部分的處理函數	                    	        	*/
/* 產生式 < stmList > ::=  stm    stmMore                           */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * stmList(void)
{
	TreeNode * t = stm();
    TreeNode * p = stmMore();
	if(t!=NULL)
		if ( p!= NULL)
			t->sibling = p;
	return t;
}

/********************************************************************/
/* 函數名 stmMore		 			  	                            */
/* 功  能 語句部分的處理函數	                    	        	*/
/* 產生式 < stmMore > ::=   ε |  ; stmList                         */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * stmMore(void)
{
	TreeNode * t = NULL;
	switch(token.Lex)
	{
	case ELSE:
	case FI:
	case END:
	case ENDWH:	break;
	case SEMI:
		match(SEMI);
		t = stmList();
		break;
	default:
		ReadNextToken(&token);
		syntaxError("unexpected token is here!");
		break;
	}
	return t;
}

/********************************************************************/
/* 函數名 stm   		 			  	                            */
/* 功  能 語句部分的處理函數	                    	        	*/
/* 產生式 < stm > ::=   conditionalStm   {IF}                       */
/*                    | loopStm          {WHILE}                    */
/*                    | inputStm         {READ}                     */
/*                    | outputStm        {WRITE}                    */
/*                    | returnStm        {RETURN}                   */
/*                    | id  assCall      {id}                       */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * stm(void)
{
	
	TreeNode * t = NULL;
	switch(token.Lex)
	{
	case IF:  
		t = conditionalStm();
		break;
	case WHILE:
		t = loopStm();
		break;
	case READ:
		t = inputStm();
		break;
	case WRITE:
		t = outputStm();
		break;
	case RETURN:
		t = returnStm();
		break;
	case ID:
		temp_name = copyString(token.Sem);
		match(ID);              
        t = assCall();
		break;
	default:
		ReadNextToken(&token);
		syntaxError("unexpected token is here!");
		break;
	}
	return t;
}

/********************************************************************/
/* 函數名 assCall		 			  	                            */
/* 功  能 語句部分的處理函數	                    	        	*/
/* 產生式 < assCall > ::=   assignmentRest   {:=,LMIDPAREN,DOT}     */
/*                        | callStmRest      {(}                    */  
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * assCall(void)
{
	TreeNode * t = NULL;
	switch(token.Lex)
	{
	case ASSIGN:
	case LMIDPAREN:
	case DOT:
		t = assignmentRest();
		break;
	case LPAREN:
		t = callStmRest();
		break;
	default:
		ReadNextToken(&token);
		syntaxError("unexpected token is here!");
		break;
	}
	return t;
}

/********************************************************************/
/* 函數名 assignmentRest		 			                        */
/* 功  能 賦值語句部分的處理函數	                    	        */
/* 產生式 < assignmentRest > ::=  variMore : = exp                  */ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * assignmentRest(void)
{
	TreeNode * t = newStmtNode(AssignK);
	
	/* 賦值語句節點的第一個兒子節點記錄賦值語句的左側變量名,*
	/* 第二個兒子結點記錄賦值語句的右側表達式*/
	if(t!=NULL)
    {
		t->lineno = line0;
		
		/*處理第一個兒子結點,為變量表達式類型節點*/
		TreeNode * child1 = newExpNode(VariK);
		if(child1!=NULL)
		{
			child1->lineno = line0;
			strcpy(child1->name[0],temp_name);
			(child1->idnum)++;
			variMore(child1);
			t->child[0] = child1;
		}
		
		/*賦值號匹配*/
		match(ASSIGN);
	  
		/*處理第二個兒子節點*/
		t->child[1] = exp(); 
				
	}
	return t;
}

/********************************************************************/
/* 函數名 conditionalStm		 			                        */
/* 功  能 條件語句部分的處理函數	                    	        */
/* 產生式 < conditionalStm > ::= IF exp THEN stmList ELSE stmList FI*/ 
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * conditionalStm(void)
{
	TreeNode * t = newStmtNode(IfK);
	match(IF);
	if(t!=NULL)  
	{
		t->lineno = line0;
		t->child[0] = exp();
	}
	match(THEN);
	if(t!=NULL)  t->child[1] = stmList();
	if(token.Lex==ELSE)
	{
		match(ELSE);
		if(t!=NULL)   
			t->child[2] = stmList();
	}
	match(FI);
	return t;
}


/********************************************************************/
/* 函數名 loopStm          		 			                        */
/* 功  能 循環語句部分的處理函數	                    	        */
/* 產生式 < loopStm > ::=      WHILE exp DO stmList ENDWH           */
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * loopStm(void)
{
	TreeNode * t = newStmtNode(WhileK);
	match(WHILE);
	if (t!=NULL)  
	{
		t->lineno = line0;
		t->child[0] = exp();
	    match(DO);
	    t->child[1] = stmList();
	    match(ENDWH);
	}
	return t;
}

/********************************************************************/
/* 函數名 inputStm          		     	                        */
/* 功  能 輸入語句部分的處理函數	                    	        */
/* 產生式 < inputStm > ::=    READ(id)                              */
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * inputStm(void)
{
	TreeNode * t = newStmtNode(ReadK);
	match(READ);
	match(LPAREN);
	if((t!=NULL)&&(token.Lex==ID))	
	{
		t->lineno = line0;
		strcpy(t->name[0] ,token.Sem);
        (t->idnum)++;
	}
	match(ID);
	match(RPAREN);
	return t;
}

/********************************************************************/
/* 函數名 outputStm          		     	                        */
/* 功  能 輸出語句部分的處理函數	                    	        */
/* 產生式 < outputStm > ::=   WRITE(exp)                            */
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * outputStm(void)
{
	TreeNode * t = newStmtNode(WriteK);
	match(WRITE);
	match(LPAREN);
	if(t!=NULL)  
	{
		t->lineno = line0;
		t->child[0] = exp();
	}
	match(RPAREN);
	return t;
}

/********************************************************************/
/* 函數名 returnStm          		     	                        */
/* 功  能 返回語句部分的處理函數	                    	        */
/* 產生式 < returnStm > ::=   RETURN                                */
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * returnStm(void)
{
	TreeNode * t = newStmtNode(ReturnK);
	match(RETURN);
	if(t!=NULL)
		t->lineno = line0;
	return t;
}

/********************************************************************/
/* 函數名 callStmRest          		     	                        */
/* 功  能 函數調用語句部分的處理函數	                  	        */
/* 產生式 < callStmRest > ::=  (actParamList)                       */
/* 說  明 函數根據文法產生式,調用相應的遞歸處理函數,生成語法樹節點  */
/********************************************************************/
TreeNode * callStmRest(void)
{
	TreeNode * t=newStmtNode(CallK);
	match(LPAREN);
	/*函數調用時,其子節點指向實參*/
	if(t!=NULL)  
	{
		t->lineno = line0;		

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产香蕉久久精品综合网| 久久久无码精品亚洲日韩按摩| 久久精品久久99精品久久| 国产精品进线69影院| 日韩一区二区麻豆国产| av一区二区三区在线| 美女在线视频一区| 一区二区三区中文字幕| 国产欧美一区二区精品忘忧草 | 欧美巨大另类极品videosbest| 国产一区视频在线看| 婷婷丁香久久五月婷婷| 亚洲免费观看在线视频| 国产偷国产偷亚洲高清人白洁| 欧美丰满少妇xxxbbb| 97se狠狠狠综合亚洲狠狠| 国产激情偷乱视频一区二区三区| 日韩av午夜在线观看| 一区二区三区免费看视频| 中文av字幕一区| 日韩欧美成人激情| 91精品国产乱| 91 com成人网| 欧美二区三区91| 欧美日韩国产高清一区二区三区 | 一区二区三区四区精品在线视频| 国产日产欧美精品一区二区三区| 欧美r级在线观看| 91精品久久久久久久久99蜜臂| 欧美亚洲动漫精品| 色婷婷综合久久久久中文| 不卡电影一区二区三区| 国产精品456露脸| 国产一区二区三区电影在线观看| 精品一区二区三区久久久| 麻豆高清免费国产一区| 久久精品国产精品亚洲红杏| 日本中文在线一区| 亚洲va天堂va国产va久| 午夜精品免费在线观看| 亚洲国产综合91精品麻豆| 亚洲午夜电影在线| 亚洲成a人在线观看| 亚洲123区在线观看| 婷婷成人激情在线网| 蜜桃视频在线一区| 美女视频第一区二区三区免费观看网站| 亚洲成人免费影院| 日韩精品久久理论片| 免费不卡在线观看| 激情久久久久久久久久久久久久久久| 韩国v欧美v日本v亚洲v| 成人丝袜视频网| 99久久国产综合色|国产精品| 99国产精品久久久| 欧美制服丝袜第一页| 在线综合+亚洲+欧美中文字幕| 91精品国产综合久久精品性色| 日韩精品一区二区三区在线 | 国产精品乱人伦一区二区| 国产精品乱人伦| 亚洲综合久久av| 午夜视频在线观看一区二区| 日本三级韩国三级欧美三级| 国内欧美视频一区二区| 成人高清免费在线播放| 欧美午夜精品免费| 欧美电影免费观看高清完整版在线 | 美女被吸乳得到大胸91| 国产一区二区三区精品欧美日韩一区二区三区 | 国产片一区二区三区| 自拍偷拍国产亚洲| 日韩精彩视频在线观看| 韩国理伦片一区二区三区在线播放| 成人性生交大片免费| 欧美日韩成人综合天天影院| 精品捆绑美女sm三区| 中文字幕在线一区二区三区| 亚洲一线二线三线视频| 蓝色福利精品导航| hitomi一区二区三区精品| 欧美日韩国产片| 国产偷国产偷亚洲高清人白洁| 一区二区三区av电影| 精品在线你懂的| 91久久人澡人人添人人爽欧美| 欧美一区二区三区在线看| 国产精品网站导航| 日本欧美一区二区在线观看| 成人免费的视频| 日韩一区二区三区观看| 亚洲免费高清视频在线| 国产在线精品一区在线观看麻豆| 日本伦理一区二区| 欧美经典一区二区| 日韩高清不卡一区二区三区| 成人高清av在线| 精品国产髙清在线看国产毛片| 一区二区三区四区国产精品| 国产一区 二区| 欧美一区二区三区影视| 亚洲精品日日夜夜| 国产老肥熟一区二区三区| 欧美另类高清zo欧美| 亚洲色图欧美在线| 激情欧美日韩一区二区| 678五月天丁香亚洲综合网| 亚洲天堂福利av| 国产不卡一区视频| 日韩精品一区二区三区三区免费| 亚洲国产一区二区三区青草影视| 不卡一区二区三区四区| 久久这里都是精品| 麻豆高清免费国产一区| 欧美精品v国产精品v日韩精品| 亚洲女同一区二区| 成人av电影在线| 国产午夜精品久久久久久久| 国产在线视视频有精品| 日韩三级中文字幕| 午夜亚洲福利老司机| 欧美在线观看18| 亚洲欧美视频在线观看| 91污在线观看| 一区精品在线播放| 成人午夜激情影院| 中文字幕精品一区二区精品绿巨人| 国内精品国产三级国产a久久| 欧美一级午夜免费电影| 午夜精品久久久久久| 欧美三级电影在线看| 亚洲成人精品在线观看| 欧美日韩国产另类一区| 亚洲成人先锋电影| 69堂精品视频| 麻豆精品国产传媒mv男同| 日韩你懂的电影在线观看| 久久国内精品视频| xnxx国产精品| 国产精品123区| 国产精品久久久久久久久免费相片| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 看电视剧不卡顿的网站| 日韩欧美一级二级三级| 久久99精品国产91久久来源| 精品国产亚洲在线| 国产sm精品调教视频网站| 亚洲国产精品精华液2区45| 成人免费观看男女羞羞视频| 亚洲欧美国产77777| 欧美日韩国产不卡| 久久精品噜噜噜成人av农村| 精品国产不卡一区二区三区| 国产99久久久国产精品免费看| 国产精品久久久久久久久搜平片| 色乱码一区二区三区88| 午夜欧美在线一二页| 欧美成人一区二区三区在线观看| 国内欧美视频一区二区| 成人免费一区二区三区在线观看| 色屁屁一区二区| 男男视频亚洲欧美| 中文字幕国产一区| 欧美色视频一区| 国产一区三区三区| 亚洲欧美一区二区三区久本道91| 欧美精品少妇一区二区三区| 激情综合网av| 亚洲婷婷综合久久一本伊一区| 欧美日产在线观看| 国产乱码精品一品二品| 亚洲欧美日韩人成在线播放| 在线不卡一区二区| 国产成人午夜精品影院观看视频| 亚洲黄色小视频| 亚洲精品一区二区在线观看| www.日韩在线| 日韩精品一区第一页| 中文字幕高清不卡| 欧美美女bb生活片| 不卡影院免费观看| 久久精品国产精品亚洲精品| 亚洲欧美一区二区在线观看| 91精品一区二区三区久久久久久 | 国产乱码精品一区二区三区忘忧草| 亚洲女爱视频在线| 精品国产91乱码一区二区三区| 99久久国产综合色|国产精品| 伦理电影国产精品| 一区二区三区四区av| 精品国产一区二区国模嫣然| 欧美亚洲尤物久久| 高清国产一区二区| 日本不卡在线视频| 亚洲美女精品一区| 国产人伦精品一区二区| 日韩一区二区三区高清免费看看| 色综合久久天天| 国产99久久久久| 另类成人小视频在线|