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

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

?? compiler.cpp

?? 編譯原理的作業 編譯器
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "compiler.h"

FILE* Compiler::_outExe = NULL;

Compiler::Compiler()
:_cerrs(0), _maxError(50), _listFile(FileList::GetInstance())
{
	_outExe = fopen("source.exf", "wb");
	_dumpFile = fopen("List.txt", "w");
}

Compiler::~Compiler()
{
	fclose(_outExe);
	fclose(_dumpFile);
}

void Compiler::Compile(File& file)
{
	file.GetLine(_curLine);
	Lexer lexer(file, _curLine);
	_lexer = &lexer;
	Program();
	CodeGen();
}

void Compiler::Program()
{
	_lexer ->GetNextToken(_tok);
	while (_tok.type != TOK_EOF)		//should see EOF after Functions; 
	{									//Program Consists of Functions;
		Function();
		_lexer ->GetNextToken(_tok);
	}

	_fileHeader._nMethods = _metaData._methods.Size();
	_fileHeader._nFields = _metaData._fields.Size();
	_fileHeader._cbinstr = _instrs.Size();
	_fileHeader._cbStrPool = _strPool.Size();
}

void Compiler::Function()
{
	Attribute();
	_curMethod._retType = Type();
	FunctionName();
	ArgumentList();
	if (!Lexer::Match(_lexer ->GetNextToken(), TOK_LP_B))
	{
		OutputError(_curLine, ER_ELF0014);
	}
	_metaData.AddMethod(_curMethod);
	_curMethod._isEntry = false;
	_curMethod._retType = Void;
	_curMethod._params.Clear();
	//Method should be added here because the address of the method 
	//Will increase in ILEmit preparing for the next method;
	ILEmit();
	if (!Lexer::Match(_lexer ->GetNextToken(), TOK_RP_B))
	{
		OutputError(_curLine, ER_ELF0015);
	}
}

//Attribute*, should be aware that if there is no attribute with the Method,
//the token is passed along to the next phase, otherwise, the next token is passed
//to the next phase. This is true for all eps closure parsing.
void Compiler::Attribute()
{
	if (Lexer::Match(_tok, TOK_DIRECTIVE))
	{
		if (strcmp(_tok.text, "entry") == 0)
		{
			_curMethod._isEntry = true;
		}
		else
		{
			//TODO: To be added;
		}
		_lexer ->GetNextToken(_tok);
	}
}

ValueType Compiler::Type()
{
	Token tok = _tok;

	if (Lexer::Match(_tok, TOK_KEYWORD))
	{
		_lexer ->GetNextToken(_tok);

		if (strcmp(tok.text, "void") == 0)
		{
			return  Void;
		}
		else if (strcmp(tok.text, "s8") == 0)
		{
			return  Int8;
		}
		else if (strcmp(tok.text, "u8") == 0)
		{
			return  UInt8;
		}
		else if (strcmp(tok.text, "s16") == 0)
		{
			return  Int16;
		}
		else if (strcmp(tok.text, "u16") == 0)
		{
			return  UInt16;
		}
		else if (strcmp(tok.text, "s32") == 0)
		{
			return  Int32;
		}
		else if (strcmp(tok.text, "u32") == 0)
		{
			return  UInt32;
		}
		else if (strcmp(tok.text, "s64") == 0)
		{
			return  Int64;
		}
		else if (strcmp(tok.text, "u64") == 0)
		{
			return  UInt64;
		}
		else if (strcmp(tok.text, "f32") == 0)
		{
			return  Float32;
		}
		else if (strcmp(tok.text, "f64") == 0)
		{
			return  Float64;
		}
		else
		{
			OutputError(_curLine, ER_ELF0016);
			return Void;
		}
	}
	return Void;
}

int Compiler::Identifier()
{
	if (Lexer::Match(_tok, TOK_IDENTIFIER))
	{
		return _strPool.Add(_tok.text);
	}
	return -1; 
}

void Compiler::FunctionName()
{
	int i = Identifier();
	if (i != -1)
	{
		_curMethod._name = i;
	}
	else
	{
		OutputError(_curLine, ER_ELF0008);
	}
}

void Compiler::Argument()
{
	_curField._type = Type();
	if (_curField._type == Void)
	{
		OutputError(_curLine, ER_ELF0018);
	}

	int i = Identifier();
	if (i != -1)
	{
		_curField._name = i;
	}
	else
	{
		OutputError(_curLine, ER_ELF0019);
	}
}

void Compiler::ArgumentList()
{
	if (!Lexer::Match(_lexer ->GetNextToken(), TOK_LP_S))
	{
		OutputError(_curLine, ER_ELF0010);  
	}

	_lexer ->GetNextToken(_tok);
	if (Lexer::Match(_tok, TOK_RP_S))
	{
		return;
	}
	
	while (true)
	{
		Argument();
		_metaData._fields.PushBack(_curField);
		_curMethod._params.PushBack(_metaData._fields.Size() - 1);
		_lexer ->GetNextToken(_tok);

		if (!Lexer::Match(_tok, TOK_COMMA))
		{
			break;
		}
		_lexer ->GetNextToken(_tok);

		if (Lexer::Match(_tok, TOK_RP_S))
		{
			OutputError(_curLine, ER_ELF0023);
			return;					//For continue compiling;
		}
	}

	if (Lexer::Match(_tok, TOK_RP_S))
	{
		return;
	}
	else
	{
		OutputError(_curLine, ER_ELF0017);
	}
}

void Compiler::ILEmit()
{
	int errorNo = -1;
	Instr instr;
	bool eoi = false;

	while (!eoi)
	{
		_lexer ->GetNextToken(_tok);
		if (_tok.type == TOK_EOF)
		{
			return;
		}

		if (_tok.type == TOK_IDENTIFIER)
		{
			switch (_tok.text[0])
			{
			case 'a':
				if (strcmp(_tok.text, "add") == 0)
				{
					instr.opcode = ADD;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else if (strcmp(_tok.text, "and") == 0)
				{
					instr.opcode = AND;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else
				{
					errorNo = ER_ELF0001;
				}
				break;
			case 'b':
				if (strcmp(_tok.text, "brk") == 0)
				{
					instr.opcode = BRK;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else
				{
					errorNo = ER_ELF0001;
				}
				break;
			case 'c':
				if (strcmp(_tok.text, "call") == 0)
				{
					instr.opcode = CALL;
					errorNo = ILCallArgumentList();
					instr.arg = _curMethod._addr;
					_instrs.PushBack(instr);
				}
				else if (strcmp(_tok.text, "ceq") == 0)
				{
					instr.opcode = CEQ;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else if (strcmp(_tok.text, "conv.f") == 0)
				{
					instr.opcode = CONV_F;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else if (strcmp(_tok.text, "cpblk") == 0)
				{
					instr.opcode = CPBLK;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else
				{
					errorNo = ER_ELF0001;
				}
				break;
			case 'd':
				if (strcmp(_tok.text, "div") == 0)
				{
					instr.opcode = DIV;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else if (strcmp(_tok.text, "dup") == 0)
				{
					instr.opcode = DUP;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else
				{
					errorNo = ER_ELF0001;
				}
				break;
			case 'h':
				if (strcmp(_tok.text, "halt") == 0)
				{
					instr.opcode = HALT;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else
				{
					errorNo = ER_ELF0001;
				}
				break;
			case 'j':
				if (strcmp(_tok.text, "jmp") == 0)
				{
					instr.opcode = JMP;
					_instrs.PushBack(instr); 
					_curMethod._addr += 2;
				}
				else
				{
					errorNo = ER_ELF0001;
				}
				break;
			case 'l':
				if (strcmp(_tok.text, "ldc") == 0)
				{
					instr.opcode = LDC;
					instr.hasArg = true;
					_lexer ->GetNextToken(_tok);

					if (_lexer ->Match(_tok, TOK_INT_CONST))
					{
						instr.arg = _tok.arg;
						_instrs.PushBack(instr); 
						_curMethod._addr += 10;
					}
					else
					{
						errorNo = ER_ELF0001;
					}

				}
				else if (strcmp(_tok.text, "ldc.s") == 0)
				{
					instr.hasArg = true;
					instr.opcode = LDC_S;
					_lexer ->GetNextToken(_tok);

					if (_lexer ->Match(_tok, TOK_INT_CONST))
					{
						if (_tok.arg > 127)
						{
							errorNo = ER_ELF0003;
						}
						else
						{
							instr.arg = _tok.arg;
							_instrs.PushBack(instr); 
							_curMethod._addr += 10;
						}

					}
					else
					{
						errorNo = ER_ELF0001;
					}
				}
				else if (strcmp(_tok.text, "ldstr") == 0)
				{
					instr.hasArg = true;
					instr.opcode = LDSTR;
					_lexer ->GetNextToken(_tok);

					if (_lexer ->Match(_tok, TOK_STR_CONST))
					{
						instr.hasArg = true;
						instr.arg = _strPool.Add(_tok.text); 
						_instrs.PushBack(instr); 
						_curMethod._addr += 10;
					}
					else
					{
						errorNo = ER_ELF0004;

					}
				}
				else
				{
					errorNo = ER_ELF0001;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品欧美在线| 成人av第一页| 国产成人8x视频一区二区| 在线观看中文字幕不卡| 久久日一线二线三线suv| 亚洲国产欧美一区二区三区丁香婷| 99久久99久久综合| 日韩精品自拍偷拍| 亚洲国产精品久久艾草纯爱| 高清shemale亚洲人妖| 欧美一区二区在线播放| 一区二区三区在线观看动漫| 丁香六月久久综合狠狠色| 日韩精品在线一区二区| 亚洲大片在线观看| 色综合久久天天| 国产精品水嫩水嫩| 国产盗摄一区二区| 欧美日本视频在线| 一区二区久久久久| 色综合视频一区二区三区高清| 99热在这里有精品免费| 欧美mv日韩mv国产| 全国精品久久少妇| 欧美二区三区91| 爽好久久久欧美精品| 色香蕉成人二区免费| 中文字幕日韩一区二区| 丁香网亚洲国际| 中文字幕欧美区| 成人涩涩免费视频| 国产精品成人午夜| 99久久免费精品高清特色大片| 色婷婷av一区二区三区之一色屋| 欧美午夜精品久久久久久孕妇| 欧美一区二区三区日韩| 亚洲一区二区三区不卡国产欧美| 久久超碰97人人做人人爱| 欧美一二三区在线观看| 久久精品99国产国产精| 久久综合九色欧美综合狠狠| 激情五月婷婷综合网| 久久九九久精品国产免费直播| 亚洲影视资源网| 69堂精品视频| 极品少妇一区二区三区精品视频 | 欧美日韩午夜在线视频| 亚洲综合激情网| 欧美日韩国产精品自在自线| 亚洲成人久久影院| 日韩欧美色电影| 国产精品一级黄| 亚洲激情第一区| 91精品国产综合久久婷婷香蕉 | 亚洲尤物在线视频观看| 欧洲生活片亚洲生活在线观看| 欧美大胆人体bbbb| 成人三级在线视频| 香蕉乱码成人久久天堂爱免费| 国产不卡在线一区| 亚洲香肠在线观看| 精品国产露脸精彩对白| 99久久久无码国产精品| 亚洲在线观看免费视频| xfplay精品久久| 色婷婷综合久久久久中文一区二区| 久久亚洲精华国产精华液 | 欧美经典三级视频一区二区三区| 亚洲3atv精品一区二区三区| 欧美刺激脚交jootjob| 成人av在线影院| 日本中文一区二区三区| 中文字幕不卡一区| 欧美精品第1页| 成人精品一区二区三区四区| 亚洲国产成人av| 国产天堂亚洲国产碰碰| 7777精品伊人久久久大香线蕉超级流畅| 亚洲人快播电影网| 日韩欧美高清在线| 欧美亚洲精品一区| 成人a区在线观看| 久久99九九99精品| 亚洲成人av一区二区三区| 久久久久久久久99精品| 这里只有精品视频在线观看| 99精品一区二区| 国产乱一区二区| 日韩av一二三| 亚洲福利一区二区| 亚洲欧美日韩国产手机在线 | 国产一区不卡精品| 亚洲国产精品影院| 国产精品国产馆在线真实露脸| 成人免费视频播放| 国内精品嫩模私拍在线| 亚洲福中文字幕伊人影院| 日韩美女久久久| 国产精品免费视频网站| 久久人人97超碰com| 日韩精品一区二区三区老鸭窝| 久久er精品视频| 日本欧美一区二区三区| 亚洲成人资源在线| 亚洲成在人线免费| 亚洲国产cao| 亚洲欧美另类久久久精品2019| 欧美日韩国产a| 欧美午夜电影在线播放| 91婷婷韩国欧美一区二区| www.成人网.com| 波多野结衣视频一区| 成人黄色777网| 成人福利在线看| 97久久精品人人爽人人爽蜜臀| 亚洲卡通欧美制服中文| 亚洲欧洲美洲综合色网| 国产区在线观看成人精品 | 国产一区激情在线| 国产尤物一区二区在线| 韩国一区二区视频| 国产精品影音先锋| 成人看片黄a免费看在线| 成人黄色软件下载| 色狠狠一区二区| 欧美午夜片在线看| 91精品国产综合久久福利软件 | 五月天欧美精品| 日韩高清不卡一区二区| 久久精品噜噜噜成人88aⅴ| 国产曰批免费观看久久久| 国产成人精品午夜视频免费 | 亚洲国产高清不卡| 中文字幕一区二区三区四区| 亚洲色图第一区| 日韩电影一区二区三区四区| 久久精品72免费观看| 国产精品88888| 色哟哟亚洲精品| 欧美精品tushy高清| 精品国产第一区二区三区观看体验 | 国产精品美女久久福利网站| 国产精品拍天天在线| 亚洲成人精品一区| 精品在线播放免费| 不卡av电影在线播放| 欧美区一区二区三区| 久久久久国产精品麻豆ai换脸| 欧美精品自拍偷拍| 久久亚洲欧美国产精品乐播| 亚洲精品乱码久久久久久 | 欧美人与z0zoxxxx视频| 欧美成人a在线| 亚洲人123区| 美腿丝袜在线亚洲一区 | 美女视频一区二区三区| 成人国产精品免费观看视频| 欧美日韩精品三区| 欧美激情综合在线| 亚洲成人免费观看| 成人深夜在线观看| 欧美一区二区免费观在线| 中文字幕精品综合| 欧美aaa在线| 91免费在线播放| 久久久精品免费观看| 亚洲成人在线免费| 91在线国内视频| 久久你懂得1024| 日本伊人色综合网| 色噜噜久久综合| 国产精品久久夜| 韩国成人精品a∨在线观看| 欧美日韩高清不卡| 亚洲日本在线看| 成人午夜在线播放| 精品国产髙清在线看国产毛片 | 91精品久久久久久久99蜜桃| 中文字幕在线观看一区| 国产高清亚洲一区| 欧美va在线播放| 亚洲6080在线| 欧美主播一区二区三区| 亚洲丝袜自拍清纯另类| 国产精品99久久久久久久vr | 国产在线播精品第三| 欧美日韩一区视频| 一区二区三区精品久久久| eeuss鲁一区二区三区| 国产视频亚洲色图| 国产麻豆视频精品| 国产色产综合产在线视频| 麻豆国产精品视频| 欧美sm美女调教| 久草精品在线观看| 久久免费电影网| 粉嫩一区二区三区在线看| 精品乱人伦小说| 国产精品一区在线| 国产精品日产欧美久久久久|