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

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

?? parser.cpp

?? 一個簡單的圖形解釋語言編譯程序,使用visual C++ 6.0開發
?? CPP
字號:
// Parser.cpp: implementation of the CParser class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "Parser.h"
#include <stdio.h>
#include <stdarg.h>
#include <windows.h>
#include <wingdi.h>


#define enter(x) 
#define back(x)  
#define Tree_trace(x)  
#define call_match(x)  
#define color RGB(0,0,0) 
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CParser::CParser()
{

}

CParser::~CParser()
{

}
void CParser::Parser(char *FileName,HDC hDC)
{
	hdc = hDC;
	enter("Parser");
	if(!mylex.InitLex(FileName))
	{
		MessageBox(NULL,"Cannot Open Source File!\n","Wrong!",MB_OK);
		return;
	}
	FetchToken();
	Program();
	mylex.CloseLex();
	back("Parser");
}
void CParser::FetchToken()
{
	m_token = mylex.GetToken();
	if(m_token.type == ERRTOKEN)
		SyntaxError(1);
}
void CParser::SyntaxError(int caseof)
{
	switch(caseof)
	{
	case 1:ErrMsg(mylex.m_LineNo,"錯誤記號:",m_token.lexeme);break;
	case 2:ErrMsg(mylex.m_LineNo,"不是預期記號:",m_token.lexeme);break;
	}
}
void CParser::ErrMsg(int LineNo,char *descrip,char *str)
{

	char msg[256];
	memset(msg,0,256);
	sprintf(msg,"Line No %5d:%s %s!",LineNo,descrip,str);

	MessageBox(NULL,msg,"error",MB_OK);

	mylex.CloseLex();
	
}

void CParser::Program()
{
	enter("Program");
	while(m_token.type != NONTOKEN)
	{
		Statement();
		MatchToken(SEMICO);
	}
	back("Program");
}

void CParser::Statement()
{
	enter("Statement");
	switch(m_token.type)
	{
	case ORIGIN:OrignStatement();break;
	case SCALE:ScaleStatement();break;
	case ROT:RotStatement();break;
	case FOR:ForStatement();break;
	default:SyntaxError(2);break;
	}
	back("Statement");
}
void CParser::MatchToken(enum Token_Type tokentype)
{
	if(m_token.type != tokentype)
		SyntaxError(2);
	FetchToken();
}

void CParser::OrignStatement()
{
	struct  ExprNode * tmp;
	enter("OrignStatement");
	MatchToken(ORIGIN);
	MatchToken(IS);
	MatchToken(L_BRACKET);
	tmp = Expression();
	

	Origin_x = GetExprValue(tmp);
	DelExprTree(tmp);


	MatchToken(COMMA);
	tmp = Expression();


	Origin_y = GetExprValue(tmp);
	DelExprTree(tmp);

	MatchToken(R_BRACKET);
	back("OrignStatement");

}

ExprNode *CParser::Expression()
{
	struct ExprNode *left,*right;
	Token_Type token_tmp;
	enter("Expression");
	left = Term();
	while((m_token.type == PLUS) || (m_token.type == MINUS))
	{
		token_tmp = m_token.type;
		MatchToken(token_tmp);
		right = Term();
		left = MakeExprNode(token_tmp,left,right);
	}
	Tree_trace(left);
	back("Exprssion");
	return left;
}
ExprNode *CParser::Term()
{
	struct ExprNode *left,*right;
	Token_Type token_tmp;
	left = Factor();
	while((m_token.type == MUL) || (m_token.type == DIV))
	{
		token_tmp = m_token.type;
		MatchToken(token_tmp);
		right = Factor();
		left = MakeExprNode(token_tmp,left,right);
	}

	return left;

}
ExprNode * CParser::Factor()
{
	struct ExprNode *left,*right;
	if(m_token.type == PLUS)
	{
		MatchToken(PLUS);
		right = Factor();
	}
	else if(m_token.type == MINUS)
	{
		MatchToken(MINUS);
		right = Factor();
		left = new ExprNode;
		left->OpCode = CONST_ID;
		left->Content.CaseConst = 0.0;
		right = MakeExprNode(MINUS,left,right);
	}
	else right = Comp();
	return right;
}

ExprNode* CParser::Comp()
{
	struct ExprNode *left,*right;
	left = AtomComp();
	if(m_token.type == POWER)
	{
		MatchToken(POWER);
		right = Comp();
		left = MakeExprNode(POWER,left,right);

	}
	return left;
}

struct ExprNode * CParser::AtomComp()
{
	struct Token t = m_token;
	struct ExprNode *address,*tmp;
	switch(t.type)
	{
	case CONST_ID:
		MatchToken(CONST_ID);
		address = MakeExprNode(CONST_ID,t.value);
		break;
	case L_BRACKET:
		MatchToken(L_BRACKET);
		address = Expression();
		MatchToken(R_BRACKET);
		break;
	case T:
		MatchToken(T);
		address = MakeExprNode(T);
		break;
	case FUNC:
		MatchToken(FUNC);
		MatchToken(L_BRACKET);
		tmp = Expression();
		address = MakeExprNode(FUNC,t.FuncPtr,tmp);
		MatchToken(R_BRACKET);
		break;
	default:
		SyntaxError(2);
		break;

	}
	return address;
}

struct ExprNode * CParser::MakeExprNode(enum Token_Type opcode,...)
{
	struct ExprNode*ExprPtr = new ExprNode;
	ExprPtr->OpCode = opcode;
	va_list ArgPtr;
	va_start(ArgPtr,opcode);
	switch(opcode)
	{
	case CONST_ID:
		ExprPtr->Content.CaseConst = (double)va_arg(ArgPtr,double);
		break;
	case T:
		ExprPtr->Content.CaseParmPtr = &Parameter;
		break;
	case FUNC:
		ExprPtr->Content.CaseFunc.MathFuncPtr = (FuncPtr)va_arg(ArgPtr,FuncPtr);
		ExprPtr->Content.CaseFunc.Child = (ExprNode*)va_arg(ArgPtr,ExprNode *) ;
		break;
	default:
		ExprPtr->Content.CaseOperator.Left = (ExprNode*)va_arg(ArgPtr,ExprNode*);
		ExprPtr->Content.CaseOperator.Right = (ExprNode*)va_arg(ArgPtr,ExprNode*);
		
		break;
	}
	va_end(ArgPtr);
	return ExprPtr;
}

void CParser::PrintSyntaxTree(ExprNode*root,int indent)
{
	int tmp;
	for(tmp = 1;tmp <= indent;tmp++)
	{
		printf("\t");
	}
	switch(root->OpCode)
	{
	case PLUS:printf("%s\n","+");break;
	case MINUS:printf("%s\n","-");break;
	case MUL:printf("%s\n","*");break;
	case DIV:printf("%s\n","/");break;
	case POWER:printf("%s\n","**");break;
	case FUNC:printf("%x\n",root->Content.CaseFunc.MathFuncPtr);
		break;
	case CONST_ID:printf("%f\n",root->Content.CaseConst);break;
	case T:printf("%s\n","T");break;
	default:printf("Error Tree Node!\n");break;
	}
	if(root->OpCode == CONST_ID || root->OpCode == T)
		return;
	if(root->OpCode == FUNC)
		PrintSyntaxTree(root->Content.CaseFunc.Child,indent+1);
	else
	{
		PrintSyntaxTree(root->Content.CaseOperator.Left,indent+1);
		PrintSyntaxTree(root->Content.CaseOperator.Right,indent+1);
	}
}

void CParser::DelExprTree(ExprNode*root)
{
	if(root)
	{
		switch(root->OpCode)
		{
		case PLUS:
		case MUL:
		case MINUS:
		case DIV:
		case POWER:
			DelExprTree(root->Content.CaseOperator.Left);
			DelExprTree(root->Content.CaseOperator.Right);
			break;
		case FUNC:
			DelExprTree(root->Content.CaseFunc.Child);
			break;
		default:break;
		}
		delete(root);
	}
}

double CParser::GetExprValue(ExprNode *root)
{
	if(NULL == root)
		return 0.0;
	switch(root->OpCode)
	{
	case PLUS:
		return GetExprValue(root->Content.CaseOperator.Left) + 
			GetExprValue(root->Content.CaseOperator.Right);
		break;
	case MINUS:
		return GetExprValue(root->Content.CaseOperator.Left) - 
			GetExprValue(root->Content.CaseOperator.Right);
		break;
	case MUL:
		return GetExprValue(root->Content.CaseOperator.Left) * 
			GetExprValue(root->Content.CaseOperator.Right);
		break;
	case DIV:
		return GetExprValue(root->Content.CaseOperator.Left) / 
			GetExprValue(root->Content.CaseOperator.Right);
		break;
	case POWER:
		return pow(GetExprValue(root->Content.CaseOperator.Left),
			GetExprValue(root->Content.CaseOperator.Right));
		break;
	case FUNC:
		return (*(root->Content.CaseFunc.MathFuncPtr))(GetExprValue(root->Content.CaseFunc.Child));
		break;
	case CONST_ID:
		return root->Content.CaseConst;
		break;
	case T:
		return *(root->Content.CaseParmPtr);
		break;
	default :return 0.0;
	
	}
}

void CParser::ScaleStatement(void)
{
	struct ExprNode*tmp;
	enter("ScaleStatement");
	MatchToken(SCALE);
	MatchToken(IS);
	MatchToken(L_BRACKET);
	tmp = Expression();
	Scale_x = GetExprValue(tmp);
	DelExprTree(tmp);
	MatchToken(COMMA);
	tmp = Expression();
	Scale_y = GetExprValue(tmp);
	DelExprTree(tmp);
	MatchToken(R_BRACKET);
	back("ScaleStatement");

}

void CParser::RotStatement(void)
{
	struct ExprNode*tmp;
	enter("RotStatement");
	MatchToken(ROT);
	MatchToken(IS);
	tmp = Expression();
	Rot_angle = GetExprValue(tmp);
	DelExprTree(tmp);
	back("RotStatement");
}

void CParser::ForStatement(void)
{
	double Start,End,Step;
	struct ExprNode *start_ptr,*end_ptr,*step_ptr,*x_ptr,*y_ptr;
	enter("ForStatement");
	MatchToken(FOR);call_match("FOR");
	MatchToken(T);call_match("T");
	MatchToken(FROM);call_match("FROM");
	start_ptr = Expression();
	Start = GetExprValue(start_ptr);
	DelExprTree(start_ptr);
	MatchToken(TO);call_match("TO");
	end_ptr = Expression();
	End = GetExprValue(end_ptr);
	DelExprTree(end_ptr);
	MatchToken(STEP);call_match("STEP");
	step_ptr = Expression();
	Step = GetExprValue(step_ptr);
	DelExprTree(step_ptr);
	MatchToken(DRAW);call_match("DRAW");
	MatchToken(L_BRACKET);call_match("(");
	x_ptr = Expression();
	MatchToken(COMMA);call_match(",");
	y_ptr = Expression();
	MatchToken(R_BRACKET);call_match(")");
	DrawLoop(Start,End,Step,x_ptr,y_ptr);
	DelExprTree(x_ptr);
	DelExprTree(y_ptr);
	back("ForStatement");
}

void CParser::DrawLoop(double Start,double End,double Step,
					   ExprNode*HorPtr,ExprNode*VerPtr)
{
	
	for(Parameter = Start;Parameter <= End;Parameter += Step)
	{
		
		CalcCoord(HorPtr,VerPtr);
		DrawPixel();
	}
}

void CParser::CalcCoord(ExprNode*Hor_Exp,ExprNode*Ver_Exp)
{
	double HorCord,VerCord,tmp;
	double cx,cy;
	HorCord = GetExprValue(Hor_Exp);
	VerCord =GetExprValue(Ver_Exp);
	HorCord *= Scale_x;
	VerCord *= Scale_y;
	tmp = HorCord*cos(Rot_angle) + VerCord * sin(Rot_angle);
	VerCord = VerCord*cos(Rot_angle) - HorCord*sin(Rot_angle);
	HorCord = tmp;
	cx = 2*HorCord + Origin_x;
	cy = 2*VerCord + Origin_y;
	x = cx;
	y = cy;
	

}

void CParser::DrawPixel()
{
	SetPixel(hdc,(int)x,(int)y,color);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀精品一区二区三区在线观看 | 日本中文一区二区三区| www.av亚洲| 亚洲少妇屁股交4| 日本韩国一区二区三区视频| 亚洲乱码国产乱码精品精的特点 | 日韩一级完整毛片| 久久国产精品第一页| 精品久久久久99| 国产福利一区二区三区视频在线| 国产视频一区二区在线| 国产99精品国产| 亚洲日本欧美天堂| 精品污污网站免费看| 免费成人在线视频观看| 国产亚洲人成网站| 91麻豆自制传媒国产之光| 亚洲高清久久久| 精品入口麻豆88视频| 国产凹凸在线观看一区二区| 综合激情网...| 欧美日韩成人高清| 国产在线看一区| 亚洲视频香蕉人妖| 欧美一区二区视频网站| 国产v综合v亚洲欧| 亚洲成人中文在线| 久久久蜜臀国产一区二区| 99久久国产综合精品麻豆| 婷婷开心久久网| 无吗不卡中文字幕| 久久久久久久久久美女| 色88888久久久久久影院按摩| 视频精品一区二区| 国产精品久久久久国产精品日日| 欧美日韩欧美一区二区| 国产精品一区二区在线观看不卡| 亚洲欧美在线另类| 日韩精品自拍偷拍| 一本大道av一区二区在线播放| 免费在线观看一区二区三区| 国产精品国产三级国产a| 91精品久久久久久久91蜜桃| 成人午夜精品在线| 美女免费视频一区二区| 一区二区三区精品视频| 日本一区二区三区电影| 制服丝袜中文字幕一区| 99久久精品国产毛片| 老汉av免费一区二区三区| 亚洲毛片av在线| 久久理论电影网| 欧美一区二区啪啪| 在线精品亚洲一区二区不卡| 国产69精品久久久久毛片| 青青草精品视频| 亚洲女同ⅹxx女同tv| 日本一区免费视频| 精品国产青草久久久久福利| 欧美猛男男办公室激情| 99精品欧美一区二区蜜桃免费| 另类小说色综合网站| 天天亚洲美女在线视频| 一区二区三区在线视频免费| 中文字幕av一区二区三区高 | 日韩电影在线看| 精品一区二区在线播放| 亚洲成人手机在线| 一区二区三区在线免费观看| 国产精品国产成人国产三级| 国产日产欧产精品推荐色 | 国产一区二区在线观看视频| 美女一区二区久久| 日本三级亚洲精品| 日本女优在线视频一区二区| 日韩中文字幕一区二区三区| 亚洲.国产.中文慕字在线| 亚洲一区二区在线免费看| 亚洲乱码日产精品bd| 亚洲精品五月天| 亚洲精品欧美二区三区中文字幕| 中文字幕在线观看一区二区| 中文字幕av资源一区| 国产精品天美传媒| 亚洲四区在线观看| 亚洲精品国产第一综合99久久| 亚洲乱码日产精品bd| 亚洲一区二区3| 亚洲成人精品影院| 日本不卡视频在线| 久久精品国内一区二区三区| 九一久久久久久| 国产一区二区美女| 成人久久久精品乱码一区二区三区| 国产91丝袜在线播放| aaa欧美色吧激情视频| 在线免费不卡电影| 91.麻豆视频| 精品久久久久一区| 中文字幕精品综合| 国产黄色成人av| 成人av电影在线| 色婷婷av久久久久久久| 欧美无人高清视频在线观看| 欧美日韩国产中文| 亚洲精品在线观看网站| 国产精品入口麻豆原神| 一区av在线播放| 日韩国产精品大片| 国产精品亚洲成人| 色呦呦日韩精品| 日韩一区国产二区欧美三区| 久久久久9999亚洲精品| 亚洲桃色在线一区| 蜜桃视频一区二区三区| 成人免费高清在线观看| 欧美三级蜜桃2在线观看| 精品国产乱码久久久久久图片| 中文字幕中文在线不卡住| 午夜精品福利一区二区三区蜜桃| 狠狠狠色丁香婷婷综合久久五月| 99久久精品国产精品久久| 欧美一区二区三区男人的天堂 | 国产亚洲精品7777| 一区二区三区国产精华| 国产在线精品免费av| 91一区二区在线| 欧美成人欧美edvon| 亚洲六月丁香色婷婷综合久久| 久久国产精品露脸对白| 日本道免费精品一区二区三区| 日韩欧美你懂的| 一区二区成人在线视频| 国产乱码一区二区三区| 欧美日韩1区2区| 成人欧美一区二区三区视频网页| 蜜桃精品在线观看| 91国偷自产一区二区使用方法| 精品久久99ma| 亚洲国产精品一区二区久久| 国产成人精品亚洲日本在线桃色| 欧美日韩国产精品成人| 国产精品国产三级国产普通话蜜臀 | 欧美一区二区精品在线| √…a在线天堂一区| 久久se这里有精品| 欧美日韩午夜在线| 亚洲色图视频网| 国产精品99久久久| 欧美妇女性影城| 一区二区免费视频| 91在线免费播放| 国产日韩欧美精品综合| 久久超碰97中文字幕| 欧美精品一卡两卡| 亚洲一区二区免费视频| 97久久精品人人做人人爽| 欧美精品一区二| 久久精品国产亚洲高清剧情介绍 | 国产精品1区2区| 亚洲日本免费电影| 成人av网站在线观看| 国产欧美日韩精品一区| 国产一区二区三区精品欧美日韩一区二区三区 | 国产高清无密码一区二区三区| 欧美一区二区三区播放老司机 | 亚洲va欧美va天堂v国产综合| av网站免费线看精品| 国产亚洲美州欧州综合国| 精品一区二区免费视频| 欧美xxxxxxxxx| 久国产精品韩国三级视频| 欧美本精品男人aⅴ天堂| 日本v片在线高清不卡在线观看| 欧美午夜宅男影院| 亚洲国产日韩一区二区| 欧美日韩在线播放一区| 亚洲成在人线免费| 在线不卡一区二区| 欧美a级理论片| 精品久久久久99| 国产麻豆精品视频| 国产欧美视频一区二区| 成人黄色在线视频| 亚洲精品一二三| 欧美日韩在线三级| 奇米精品一区二区三区在线观看一| 欧美一级在线免费| 国内精品在线播放| 国产清纯美女被跳蛋高潮一区二区久久w| 国内精品不卡在线| 国产精品视频你懂的| 精品美女被调教视频大全网站| 精品一区二区三区久久| 国产女主播一区| 色综合久久综合网97色综合| 亚洲综合小说图片| 7777精品伊人久久久大香线蕉的| 蜜臀久久99精品久久久久久9| 国产亚洲综合av|