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

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

?? executable.cpp

?? Basic語言的解釋器 由于本人沒有學過《編譯原理》所以做的不好,等我學完《編譯原理》后再做個好的. 我正在看《編譯原理及實踐》,所以把老師寫的demo附上.
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// Executable.cpp: implementation of the CExecutable class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "Executable.h"

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////


CExecutable::CExecutable(vector <CSub> Subs)
{
	m_Subs=Subs;
}

CExecutable::~CExecutable()
{
	m_intArray.clear();
	m_tokens.clear();
	m_Subs.clear();
}

void CExecutable::Run(char *SubName,vector <CToken> Subarg)
{
	register int i;
	if(!Ai_GetSubNo(SubName,&i))
		return;
	// m_tokens=m_Subs.at(i).m_tokens;  先處理參數,再將找到的過程Sub里的tokens賦給CExecutable里的m_tokens
	m_argtokens=m_Subs.at(i).m_argtokens;
	// 先將參數定義argtoken裝在m_token里當代碼運行,然后在將Sub里m_token傳到m_token
	if(m_argtokens.size()>=1) // 如果此過程有參數
	{
		m_tokens=m_argtokens;
		for(int l=0;l<=m_tokens.size()-1;l++)
		{
			if(m_tokens.at(l).token_type==COMMAND) // 如果是Basic命令
			{
				switch(m_tokens.at(l).tok) // tok表示是什么命令
				{
				case DIM:  Run_Dim(&l);
					break;
				default:   break; 
				}
				continue;
			}
		}
	}
	// 傳遞參數 參數值在CToken::token里,類型在CToken::tok里
	if(Subarg.size()>=1)
	{
		// 對應Subarg里的由小到大地直接賦到m_iniArray 或 變量堆棧 里
		int var_int_i=0; // 參數對應在m_intArray里的指針
		for(int l=0;l<=Subarg.size()-1;l++)
			switch(Subarg.at(l).tok)
		{
		   case INTEGER:
			   memcpy(&m_intArray.at(var_int_i).value,Subarg.at(l).token,sizeof(int));
			   var_int_i++;
			   break;
		   default: break;
		}
	}
	
	
	if(strcmp(m_Subs.at(i).name,SubName)==0)
		m_tokens=m_Subs.at(i).m_tokens;
	if(m_tokens.size()<=0)  // 如果找不到SubName的過程或過程中的token沒有
		return;
	
	for(i=0;i<=m_tokens.size()-1;i++)// 注意:i是個十分重要的讀取指針
	{
		//Debug(i);
		//////////////// COMMAND ////////////////////////////////
		if(m_tokens.at(i).token_type==COMMAND) // 如果是Basic命令
		{
			switch(m_tokens.at(i).tok) // tok表示是什么命令
			{
			case PRINT: Run_Print(&i);
				break;
			case DIM:   Run_Dim(&i);
				break;
			case IF:    Run_If(&i);
				break;
			case WHILE: Run_While(&i);
				break;
			case LOOP:  Run_Loop(&i);
				break;
			case EXIT:  Run_Exit(&i);
				break;
			case CALL:  Run_CallSub(&i);
			default:   break; 
			}
			continue;
		}
		
		//////////////////// Call Sub ////////////////////////////////
		if(m_tokens.at(i).token_type==STRING &&
			*m_tokens.at(i+1).token!='=') // 如果是未知String而且不是賦值語句,則當自定義的過程處理
		{
			Run_CallSub(&i);
			continue;
		}
		
		//////////////////// Assignment賦值語句 ///////////////////////
		//賦值語句一定要在最后來判斷,因為這樣如果是if后的條件判斷就可以在
		//前面的if命令中跳過
		if(*m_tokens.at(i).token=='=') // 如果是賦值語句
			Run_Assignment(&i);
	}
}

void CExecutable::Run_If(int *index) // 條件判斷 Run_While Run_If中都要用到它
{
	if(*index>=m_tokens.size()-1)
		return;
	if(m_tokens.at(*index-1).tok==END) // 避免是End If 中的If
		return;
	(*index)++;
	int result;
	if(!Ai_GetNextIfValue(&result,index)) // 判斷下個條件語句的真假
	{
		serror(0);
		return;
	}
	(*index)++;
	int thenIndex=*index;
	int endifIndex=*index;
	if(!Ai_GetNextThen(&thenIndex,index))
	{
		serror(8);
		return;
	}
	if(!Ai_GetNextEndIf(&endifIndex,index))
	{
		serror(0);
		return;
	}
	if(result)  // 為真
		*index=thenIndex;
	else        // 為假
		*index=endifIndex;
	return;
}

void CExecutable::Run_While(int *index) //此時index都是指到While語句的
{
	if(*index>=m_tokens.size()-1) 
		return;
	int lastcommand=*index-1; // lastcommand是指到While前面一個Command
	while(m_tokens.at(lastcommand).token_type==ENTER)
		lastcommand--;
	if(m_tokens.at(lastcommand).tok==DO) // 如果是:  Do While [command] 形式
	{
		int loopindex,ifresult;
		(*index)++; // -> While 下一個token
		if(!Ai_GetNextLoop(&loopindex,index)) // 找到匹配的Loop語舉引索
			return;
		if(!Ai_GetNextIfValue(&ifresult,index)) // 得到循環調件的真假
		{
			serror(0);
			return;
		}
		
		if(ifresult)
		{
			return;
		}
		else
		{
			*index=loopindex;
			return;
		}
	}
	else
		serror(14);
	
}

void CExecutable::Run_Loop(int *index)
{
	if(*index<m_tokens.size()-1)   
	{
		int nextcommand=(*index)+1;
		while(m_tokens.at(nextcommand).token_type==ENTER) // 跳過換行符
		{
			if(nextcommand<m_tokens.size()-1) // 如果下面一個nextcommand未出界
				nextcommand++;
			else // 如果這個token就是下界線了
				 break; /* 此時的token_type肯定是ENTER 所以下面將跳到
			Do While [command] Loop 中的Loop形式的處理中*/
		}
		
		// 如果是這種循環: Do [command] Loop While [command]
		if(m_tokens.at(nextcommand).tok==WHILE)
		{
			(*index)--;    // -> Do 前一個token
			int lastDo,ifresult;
			if(!Ai_GetLastDo(&lastDo,index)) // 找到匹配的Do語舉引索
				return;
			(*index)=nextcommand+1;  // -> While后一個
			
			if(!Ai_GetNextIfValue(&ifresult,index)) // 得到循環調件的真假
			{
				serror(0);
				return;
			}
			if(ifresult)
			{
				*index=lastDo;
				return;				
			}
			else
			{
				return;
			}
			return;
		}
	}
	
	// 否則就是Do While [command] Loop 中的Loop形式
	int lastDo;
	(*index)--; // -> Do 前一個
	if(!Ai_GetLastDo(&lastDo,index))
		return;
	*index=lastDo;
	return;
}

void CExecutable::Run_Exit(int *index)
{
	if(*index>=m_tokens.size()-1) //如果超出范圍
		return;
	(*index)++;
    switch(m_tokens.at(*index).tok)
	{
	case DO:
		{
			int loopindex;
			(*index)++;
			if(!Ai_GetNextLoop(&loopindex,index))
			{
				serror(15);
				return;
			}
			int nextcommand=loopindex+1;
			while(m_tokens.at(nextcommand).token_type==ENTER)
				nextcommand++;
			if(m_tokens.at(nextcommand).tok==WHILE) // Loop 后面的Command是While
			{
				*(index)=nextcommand+1;
				Ai_GetNextIfValue(&nextcommand,index);
				// 讓index移到條件判斷式最后一個token
				return;
			}
			*index=nextcommand-1;
			return;
		}
	default: break;
	}
}

void CExecutable::Run_Print(int *index) //*index是m_tokens里的指針
{
	if(*index<m_tokens.size()-1) // 如果下面還有token
	{   
		if(m_tokens.at((*index)+1).token_type==ENTER) //如果接下來是換行符
		{
			printf("\n");
			return;
		}
		(*index)++;			
		int token_type=m_tokens.at(*index).token_type;
		if(Isvar(m_tokens.at(*index).token)) //如果接下來是變量
			token_type=VARIABLE; 
        
		switch(token_type)
		{
		case QUOTE: // 如果是要打印字符串
			{
				printf(m_tokens.at(*index).token);
				return;
			}
		case VARIABLE:  // 打印代數式 type只要不是COMMAND就是可以當代數式處理
		case NUMBER:
		case DELIMITER:     
			{
				int result;
				Ai_GetNextValue(&result,INTEGER,index);
				printf("%d",result);
				return;
			}
		default: printf("\n");
			return;
		}
	}
	printf("\n");	
	
}

void CExecutable::Run_Dim(int *index) //~~
{
	int i=*index;
	if(i<m_tokens.size()-1)//~~
		if(m_tokens.at(i+1).token_type==STRING)
		{
			if(i<m_tokens.size()-3) //如果下面還應該有 變量名,As,類型 三個tokens
			{
				CintMember member;
				if(m_tokens.at(i+2).token_type==COMMAND && 
					m_tokens.at(i+2).tok==AS) //如果接下來的token是As
				{
					if(m_tokens.at(i+3).token_type==COMMAND)//接下來是變量類型
						switch(m_tokens.at(i+3).tok) //看看是什么變量類型
					{
					  case INTEGER: // 如果是Integer類型
						  strcpy(member.name,m_tokens.at(i+1).token);
						  member.value=0;
						  m_intArray.push_back(member);
						  (*index)+=3; // 將m_tokens里的指針跳3個
						  break;
					  default:     
						  break;
					}
				}
			}
		}
}

void CExecutable::Run_Assignment(int *index) //index必須指到'='的token
{
	int var_type=Isvar(m_tokens.at(*index - 1).token);
	if(!var_type) // 如果等號前面不是個變量
	{
		serror(0);
		return;
	}
	switch(var_type)
	{
	case INTEGER:
		{
			int Var_No,value;
			if(!Ai_GetVarNo(m_tokens.at(*index-1).token,&Var_No,INTEGER))
				break;
			(*index)++;
            if(!Ai_GetNextValue(&value,INTEGER,index))
				break;
			m_intArray.at(Var_No).value=value;
			break;
		}
	default: break;
	}
}

void CExecutable::Run_CallSub(int *index)
{
	CExecutable m_call(m_Subs); // 另外創建一個CExetutable類,使用嵌套
	vector <CToken> Subarg; // 創建空白參數表
	if(m_tokens.at(*index).tok==CALL) // 如果用 Call Sub 形式的調用
		(*index)++;
    int Oldindex=*index;
	if(!Ai_GetNextSubarg(Subarg,index))
		return;
	m_call.Run(m_tokens.at(Oldindex).token,Subarg);
}

int CExecutable::Ai_GetNextValue(void *result,int type,int *index) //index指到代數式的第一個token
{
	switch(type)
	{
	case INTEGER: get_exp((int*)result,index);
		(*index)--;
		return 1;
	default:    return 0;
	}
	
}

//調用此函數后,index指到代數式最后一個token
int CExecutable::Ai_GetNextIfValue(int *result,int *index) // index必須指到要判斷的代數式第一個token的引索
{
	int result1,result2; // e.g: If result1 > result2 // op='>' 
	char op[2];
	if(!Ai_GetNextValue(&result1,INTEGER,index))
	{	
		serror(0);
		return 0;
	}
	(*index)++;
    op[0]=*m_tokens.at(*index).token;
	op[1]='\0';
	(*index)++;
	if(!Ai_GetNextValue(&result2,INTEGER,index))
	{	
		serror(0);
		return 0;
	}
	switch(op[0])
	{
	case '>':
		{
			if(result1 > result2)
				*result=1;
			else
				*result=0;
			return 1;
		}
	case '=' :
        {
			if(result1 == result2)
				*result=1;
			else
				*result=0;
			return 1;
		}
	case '<':
		{
			if(result1 < result2)
				*result=1;
			else
				*result=0;
			return 1;
		}
	default:  break;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
www.日韩精品| 日韩欧美在线影院| 正在播放亚洲一区| 国产欧美日韩久久| 亚洲mv在线观看| 国产精品一二三四| 欧美高清视频不卡网| 国产精品久久久99| 国产在线麻豆精品观看| 欧美精品久久一区| 成人免费一区二区三区视频 | 欧美一级二级在线观看| 亚洲欧美一区二区视频| 九色porny丨国产精品| 在线观看视频一区| 国产精品免费丝袜| 韩国v欧美v日本v亚洲v| 欧美日韩成人综合| 亚洲视频中文字幕| 成人一区二区在线观看| 精品国产91洋老外米糕| 日本系列欧美系列| 欧美日韩高清一区| 亚洲成av人片| 91成人看片片| 亚洲免费观看高清完整版在线观看 | 国产在线精品视频| 欧美另类久久久品| 午夜亚洲国产au精品一区二区| 色综合天天天天做夜夜夜夜做| 久久久午夜精品| 韩国av一区二区三区| 日韩一级成人av| 美国av一区二区| 欧美一卡二卡在线观看| 日韩黄色一级片| 欧美一区二区三区四区在线观看| 亚洲一区二区三区激情| 在线看不卡av| 午夜久久久影院| 日韩视频一区在线观看| 激情国产一区二区| 国产亚洲污的网站| 成人国产精品免费| 亚洲私人黄色宅男| 欧美视频一区二区三区| 日韩中文字幕不卡| 精品国产露脸精彩对白 | 久久久无码精品亚洲日韩按摩| 久久国产日韩欧美精品| 精品欧美一区二区久久| 国产成a人亚洲精品| 亚洲女女做受ⅹxx高潮| 91精品福利在线| 日本美女视频一区二区| 日韩亚洲欧美在线| 国产经典欧美精品| 亚洲三级小视频| 欧美在线视频全部完| 日韩电影一区二区三区四区| www久久久久| 99久久精品一区| 日韩高清在线电影| 中文字幕 久热精品 视频在线| 色综合久久天天| 日本视频一区二区| 国产精品成人免费| 欧美日本在线观看| 国产成人亚洲综合a∨猫咪| 亚洲桃色在线一区| 精品日韩99亚洲| 一本一本久久a久久精品综合麻豆| 婷婷开心激情综合| 国产欧美一区二区精品仙草咪| 91热门视频在线观看| 老司机免费视频一区二区| 国产精品视频免费| 3atv在线一区二区三区| 白白色 亚洲乱淫| 美女性感视频久久| 亚洲女爱视频在线| 久久久不卡网国产精品二区| 欧美丝袜丝nylons| 99久久精品国产网站| 久久疯狂做爰流白浆xx| 亚洲精品美国一| 欧美激情一区二区三区蜜桃视频| 欧美三级午夜理伦三级中视频| 国产精品1区二区.| 美国av一区二区| 亚洲一区二区三区国产| 国产欧美日韩在线| 精品三级在线看| 欧美日本一区二区| 一本到三区不卡视频| 国产成人自拍网| 激情久久五月天| 美女一区二区久久| 日日摸夜夜添夜夜添亚洲女人| 中文字幕日韩欧美一区二区三区| 欧美精品一区二区三| 欧美精品777| 欧美日韩电影在线| 欧美亚洲国产一区二区三区 | 国产精品青草久久| 国产欧美视频在线观看| 久久综合色天天久久综合图片| 91精品国产一区二区| 欧美日韩国产综合一区二区| 一本大道久久精品懂色aⅴ| 成人午夜av影视| 成人午夜电影网站| 成人精品免费网站| 成人免费毛片高清视频| 国产精品99久| 国产成人日日夜夜| 国产成人av一区二区三区在线观看| 麻豆精品一区二区综合av| 日本欧美一区二区三区| 日本sm残虐另类| 免费欧美日韩国产三级电影| 亚洲成人免费看| 亚洲综合激情另类小说区| 亚洲一卡二卡三卡四卡五卡| 亚洲综合色噜噜狠狠| 一区二区三区蜜桃| 亚洲一级二级三级| 免费观看成人av| 精品一区二区三区av| 国产美女娇喘av呻吟久久| 国产激情偷乱视频一区二区三区| 国产高清久久久| www..com久久爱| 欧美中文字幕一二三区视频| 7777精品久久久大香线蕉| 精品剧情在线观看| 国产精品福利av| 亚洲国产综合在线| 开心九九激情九九欧美日韩精美视频电影| 另类人妖一区二区av| 国产成人h网站| 91精品福利视频| 日韩精品一区二区三区视频在线观看| 久久综合九色综合97婷婷| 国产精品乱码一区二三区小蝌蚪| 亚洲免费毛片网站| 日韩av午夜在线观看| 国产成人综合精品三级| 欧美日韩亚洲另类| 国产亚洲人成网站| 一区二区三区四区av| 裸体歌舞表演一区二区| 99久久精品国产网站| 欧美一级在线观看| 成人免费在线视频观看| 裸体健美xxxx欧美裸体表演| 成人黄色在线视频| 91精品在线观看入口| 国产精品萝li| 日本sm残虐另类| 色狠狠一区二区三区香蕉| 精品精品国产高清一毛片一天堂| 亚洲欧洲精品一区二区三区| 日本aⅴ亚洲精品中文乱码| 99在线热播精品免费| 精品日本一线二线三线不卡| 亚洲女厕所小便bbb| 国产激情一区二区三区桃花岛亚洲| 欧美日韩一级二级三级| 中文幕一区二区三区久久蜜桃| 亚洲1区2区3区4区| 成人av午夜影院| 精品久久久久久久久久久久久久久| 亚洲人成亚洲人成在线观看图片| 久久www免费人成看片高清| 在线视频欧美精品| 国产精品卡一卡二卡三| 精品一区二区三区影院在线午夜 | 亚洲精品在线三区| 亚洲国产日韩一区二区| av电影在线观看一区| 久久日韩粉嫩一区二区三区| 天天影视涩香欲综合网| 色香蕉成人二区免费| 欧美激情中文字幕| 国产传媒一区在线| 日韩精品一区二| 欧美aaa在线| 欧美精三区欧美精三区| 亚洲激情在线播放| 色综合久久久久综合体桃花网| 国产精品美女久久久久高潮| 国精产品一区一区三区mba视频| 91精品国产美女浴室洗澡无遮挡| 亚洲成人一区在线| 欧美高清性hdvideosex| 丝袜美腿亚洲综合| 91精品在线免费观看| 日韩精品久久理论片| 5566中文字幕一区二区电影|