当前位置: 首页>>代码示例>>C++>>正文


C++ ParseTree::GetTop方法代码示例

本文整理汇总了C++中ParseTree::GetTop方法的典型用法代码示例。如果您正苦于以下问题:C++ ParseTree::GetTop方法的具体用法?C++ ParseTree::GetTop怎么用?C++ ParseTree::GetTop使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在ParseTree的用法示例。


在下文中一共展示了ParseTree::GetTop方法的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: ProcessWhileTerm

void CodeGenerator::ProcessWhileTerm(int flags)
{
	infunc(CodeGenerator::ProcessWhileTerm);

	ParseTree	*tree;
	int			code_position;

	if (!(flags & FLAGS_IN_CLASS))
		throw CompileError("(Line %d) Can't have a while loop statement outside of a class", CUR_TOKEN.line);

	// Go passed the declare
	INC_TOKEN;

	if (CUR_TOKEN.type != TOKEN_LEFT_BRACKET)
		throw CompileError("(Line %d) Expecting an opening bracket", CUR_TOKEN.line);

	// Should be at the expression opening here
	INC_TOKEN;

	// Allocate the parse tree for the test expression
	if ((tree = new ParseTree) == NULL)
		throw CError("Couldn't allocate parse tree");

	// Build the tree, ending at the closing bracket
	tree->Build(tokeniser, TOKEN_RIGHT_BRACKET, TOKEN_NULL);
	INC_TOKEN;

	// Reduce the tree
	tree->Optimise();

	if (g_Object)
	{
		// Mark before the loop test
		code_position = g_Object->GetPosition();

		// Generate the test statement
		tree->CompleteTypes(flags | FLAGS_IMPLICIT_ASSIGNMENT);
		tree->GenerateCode(flags | FLAGS_IMPLICIT_ASSIGNMENT);
	}

	// Valid?
	if (tree->GetTop() == NULL)
		throw CompileError("(Line %d) Expecting an expression for the if statement", CUR_TOKEN.line);

	if (g_Object)
	{
		g_Object->AddBackpatchItem(14);

		// Generate the jump out of the loop
		if (tree->GetTop()->out_type.id == VARIABLE_TYPEID_FLOAT)
			g_Object->WriteOp(OPCODE_FJZ, 0);
		else
			g_Object->WriteOp(OPCODE_JZ, 0);
	}

	// Don't need this anymore
	delete tree;

	ProcessBlock(flags | FLAGS_ALLOW_LINE_BLOCKS | FLAGS_ALLOW_BREAK_CONTINUE);

	if (g_Object)
	{
		// Jump back to the beginning of the loop
		g_Object->WriteOp(OPCODE_JMP, code_position);

		// Update the loop jump out
		g_Object->UpdateItems(14);

		// Update all breaks
		g_Object->UpdateItems(12);

		// Update all continues
		g_Object->UpdateItems(13, code_position);
	}

	outfunc;
}
开发者ID:dwilliamson,项目名称:TahitiGameLanguage,代码行数:77,代码来源:CodeGenerator.cpp

示例2: ReadConstant

void CodeGenerator::ReadConstant(dynamic *num, VarType &type, _TokenType terminator, _TokenType extra)
{
	infunc(CodeGenerator::ReadConstant);

	ParseTree		*tree;
	ParseTreeNode	*top;

	// Allocate the parse tree
	if ((tree = new ParseTree) == NULL)
		throw CError("Couldn't allocate parse tree");

	// Build the tree
	tree->Build(tokeniser, terminator, extra);

	// Reduce to a single constant
	tree->Optimise();

	// Grab the top of the tree
	if ((top = tree->GetTop()) == NULL)
		throw CompileError("(Line %d) No constant defined", CUR_TOKEN.line);

	// Get to see if the reduction produces a constant
	if (top->GetNodeType() != PTNODE_TYPE_CONSTANT || top->children[0] || top->children[1])
		throw CompileError("(Line %d) Definition not a constant", CUR_TOKEN.line);

	// Check for a floating point definition in the place of an integer
	if (type.id != VARIABLE_TYPEID_FLOAT && top->out_type.id == VARIABLE_TYPEID_FLOAT)
		throw CompileError("(Line %d) Type mismatch", CUR_TOKEN.line);

	// Scan for the constant with the intended type
	switch (type.id)
	{
		// char
		case (VARIABLE_TYPEID_CHAR):
			num->i = ((Constant *)top)->value.i;
			if (num->i > 127 || num->i < -128)
				throw CompileError("(Line %d) Constant out of range for variable type 'char'", CUR_TOKEN.line);
			break;

		// short
		case (VARIABLE_TYPEID_SHORT):
			num->i = ((Constant *)top)->value.i;
			if (num->i > 32767 || num->i < -32768)
				throw CompileError("(Line %d) Constant out of range for variable type 'short'", CUR_TOKEN.line);
			break;

		// int
		case (VARIABLE_TYPEID_INT):
			num->i = ((Constant *)top)->value.i;
			break;

		// unsigned char
		case (VARIABLE_TYPEID_UCHAR):
			num->i = ((Constant *)top)->value.i;
			if (num->i > 255 || num->i < 0)
				throw CompileError("(Line %d) Constant out of range for variable type 'unsigned char'", CUR_TOKEN.line);
			break;

		// unsigned short
		case (VARIABLE_TYPEID_USHORT):
			num->i = ((Constant *)top)->value.i;
			if (num->i > 65535 || num->i < 0)
				throw CompileError("(Line %d) Constant out of range for variable type 'unsigned short'", CUR_TOKEN.line);
			break;

		// unsigned int
		case (VARIABLE_TYPEID_UINT):
			num->ui = ((Constant *)top)->value.ui;
			break;

		// float
		case (VARIABLE_TYPEID_FLOAT):
			num->f = ((Constant *)top)->value.f;
			break;

		case (VARIABLE_TYPEID_STRING):
			num->i = ((StringLiteral *)top)->string->GetAddress();
			break;
	}

	outfunc;
}
开发者ID:dwilliamson,项目名称:TahitiGameLanguage,代码行数:82,代码来源:CodeGenerator.cpp

示例3: ProcessIfTerm

void CodeGenerator::ProcessIfTerm(int flags)
{
	infunc(CodeGenerator::ProcessIfTerm);

	ParseTree		*tree;
	ParseTreeNode	*top;
	int				a, b;

	a = b = 100 + rand();
	while (a == b) b = 100 + rand();

	if (!(flags & FLAGS_IN_CLASS))
		throw CompileError("(Line %d) Can't have an if statement outside of a class", CUR_TOKEN.line);

	// Go passed the declare
	INC_TOKEN;

	if (CUR_TOKEN.type != TOKEN_LEFT_BRACKET)
		throw CompileError("(Line %d) Expecting an opening bracket", CUR_TOKEN.line);

	// Should be at the expression opening here
	INC_TOKEN;

	// Allocate the parse tree for the expression
	if ((tree = new ParseTree) == NULL)
		throw CError("Couldn't allocate parse tree");

	// Build the tree, ending at the if close
	tree->Build(tokeniser, TOKEN_RIGHT_BRACKET, TOKEN_NULL);
	INC_TOKEN;

	// Reduce the tree
	tree->Optimise();

	if (g_Object)
	{
		tree->CompleteTypes(flags | FLAGS_IMPLICIT_ASSIGNMENT);

		// Implicit assignment (no need for asg at the end of the expression)
		tree->GenerateCode(flags | FLAGS_IMPLICIT_ASSIGNMENT);
	}

	if (tree->GetTop() == NULL)
		throw CompileError("(Line %d) Expecting an expression for the if statement", CUR_TOKEN.line);

	if (g_Object)
	{
		// Mark this jump
		g_Object->AddBackpatchItem(a);

		// Grab the top tree node
		if ((top = tree->GetTop()) == NULL)
			throw CompileError("(Line %d) Expecting an expression for the if statement", CUR_TOKEN.line);

		// Jump over the following block if the expression is false
		if (top->out_type.id == VARIABLE_TYPEID_FLOAT)
			g_Object->WriteOp(OPCODE_FJZ, 0);
		else
			g_Object->WriteOp(OPCODE_JZ, 0);
	}

	// The tree is no longer needed
	delete tree;

	BlockType bt = ProcessBlock(flags | FLAGS_ALLOW_LINE_BLOCKS);

	if (NEXT_TOKEN.type == TOKEN_ELSE)
	{
		// Step over the close scope
		INC_TOKEN;

		if (g_Object)
		{
			// Mark this jump, at the end of the if's true block
			g_Object->AddBackpatchItem(b);

			// Jump over the else false block
			g_Object->WriteOp(OPCODE_JMP, 0);
		}
	}

	if (g_Object)
		g_Object->UpdateItems(a);

	if (CUR_TOKEN.type == TOKEN_ELSE)
	{
		// Step over the keyword
		INC_TOKEN;

		ProcessBlock(flags | FLAGS_ALLOW_LINE_BLOCKS);

		// Back patch the jump over the else block
		if (g_Object)
			g_Object->UpdateItems(b);
	}

	outfunc;
}
开发者ID:dwilliamson,项目名称:TahitiGameLanguage,代码行数:98,代码来源:CodeGenerator.cpp

示例4: GetArrayInfo

void CodeGenerator::GetArrayInfo(VarType &type)
{
	infunc(CodeGenerator::GetArrayInfo);

	ParseTree		*tree;
	ParseTreeNode	*top;

	// Should be at the array opening here
	INC_TOKEN;

	// Allocate the parse tree for the expression
	if ((tree = new ParseTree) == NULL)
		throw CError("Couldn't allocate parse tree");

	// Build the tree, ending at the array close
	tree->Build(tokeniser, TOKEN_ARRAY_CLOSE, TOKEN_NULL);
	INC_TOKEN;

	// Reduce the tree to a single constant
	tree->Optimise();

	// Grab the top tree node
	if ((top = tree->GetTop()) == NULL)
		throw CompileError("(Line %d) No dimension for array", CUR_TOKEN.line);

	// Is it a constant?
	if (top->GetNodeType() != PTNODE_TYPE_CONSTANT || top->children[0] || top->children[1])
		throw CompileError("(Line %d) Array size is not a constant", CUR_TOKEN.line);

	// Check for floating point dimensions
	if (top->out_type.id == VARIABLE_TYPEID_FLOAT)
		throw CompileError("(Line %d) Cannot specify array dimension using floats", CUR_TOKEN.line);

	// Retrieve the correct value
	switch (top->out_type.id)
	{
		case (VARIABLE_TYPEID_CHAR):
			type.elements = (int)((Constant *)top)->value.c;
			break;

		case (VARIABLE_TYPEID_SHORT):
			type.elements = (int)((Constant *)top)->value.s;
			break;

		case (VARIABLE_TYPEID_INT):
			type.elements = (int)((Constant *)top)->value.i;
			break;

		case (VARIABLE_TYPEID_UCHAR):
			type.elements = (int)((Constant *)top)->value.uc;
			break;

		case (VARIABLE_TYPEID_USHORT):
			type.elements = (int)((Constant *)top)->value.us;
			break;

		case (VARIABLE_TYPEID_UINT):
			type.elements = (int)((Constant *)top)->value.ui;
			break;
	}

	// Set it as an array
	type.array = 1;

	// The tree is no longer needed
	delete tree;

	outfunc;
}
开发者ID:dwilliamson,项目名称:TahitiGameLanguage,代码行数:69,代码来源:CodeGenerator.cpp


注:本文中的ParseTree::GetTop方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。