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

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

?? cgen.cpp

?? 小型編譯系統的源代碼
?? CPP
字號:
#include "globals.h"
#include "symtab.h"
#include "code.h"
#include "cgen.h"

/* loc is the memory offset for temps
   It is incremented each time a temp is
   stored
*/
static int loc = 0;
static char funExitLab[10];

/* prototype for internal recursive code generator */
static void cGen (TreeNode * tree);
static void genExp( TreeNode * tree, int isAddr);

void genLabel(char lab1[])
{
	static int nLabel = 1;

	sprintf(lab1, "@Label%d", nLabel);
	nLabel++;
}

/* Procedure genStmt generates code at a statement node */
static void genStmt( TreeNode * tree)
{ 
	TreeNode * p1, * p2, * p3, * p4;
  int temploc;
	char lab1[10], lab2[10];
	char codestr[CODESIZE];

	if (tree != 0) switch (tree->kind.stmt) 
	{
    case IfK :
      if (TraceCode) 
				emitComment("-> if") ;
      p1 = tree->child[0] ;
      p2 = tree->child[1] ;
      p3 = tree->child[2] ;
        
			/* generate code for test expression */
      cGen(p1);
      genLabel(lab1);
			sprintf(codestr, "%s %s", "fjp", lab1);
			emitCode(codestr);
      emitComment("if: jump to else belongs here");
  
			/* recurse on then part */
      cGen(p2);
			if (p3 != 0)
			{
				genLabel(lab2);
				sprintf(codestr, "%s %s", "ujp", lab2);
				emitCode(codestr);
			}
			sprintf(codestr, "%s %s", "lab", lab1);
			emitCode(codestr);
			if (p3 != 0)
			{
				cGen(p3);
				sprintf(codestr, "%s %s", "lab", lab2);
				emitCode(codestr);
			}
      if (TraceCode)
				emitComment("-> if") ;
			break;

      case WhileK:
				if (TraceCode) 
					emitComment("-> while");
				p1 = tree->child[0] ;
        p2 = tree->child[1] ;

				genLabel(lab1);
				sprintf(codestr, "%s %s", "lab", lab1);
				emitCode(codestr);
				cGen(p1);
				genLabel(lab2);
				sprintf(codestr, "%s %s", "fjp", lab2);
				emitCode(codestr);
				cGen(p2);
				sprintf(codestr, "%s %s", "ujp", lab1);
				emitCode(codestr);
				sprintf(codestr, "%s %s", "lab", lab2);
				emitCode(codestr);
				if (TraceCode) 
					emitComment("<- while");
				break;

			case ForK:
				if (TraceCode)
					emitComment("-> for");
				p1 = tree->child[0] ;
        p2 = tree->child[1] ;
				p3 = tree->child[2] ;
        p4 = tree->child[3] ;

				cGen(p1);
				genLabel(lab1);
				sprintf(codestr, "%s %s", "lab", lab1);
				emitCode(codestr);
				cGen(p2);
				genLabel(lab2);
				sprintf(codestr, "%s %s", "fjp", lab2);
				emitCode(codestr);
				cGen(p4);
				cGen(p3);
				sprintf(codestr, "%s %s", "ujp", lab1);
				emitCode(codestr);
				sprintf(codestr, "%s %s", "lab", lab2);
				emitCode(codestr);
				if (TraceCode)
					emitComment("<- for");
				break;
			
			case ReturnK:
				if (TraceCode)
				  emitComment("-> return");
				
				p1 = tree->child[0];

				if (p1 != 0)
					genExp(p1, FALSE);
				else
					emitCode("ldc 0");

				sprintf(codestr, "%s %s", "ujp", funExitLab);
				emitCode(codestr);
				if (TraceCode)
				  emitComment("<- return");

				break;
			
			case CompoundK:
				if (TraceCode)
				  emitComment("-> compound");

				p1 = tree->child[0];
				temploc = loc;

				st_newBuck();
				cGen(p1);
				if (TraceCode)
					emitComment("<- compound");
				st_delBuck();
				loc = temploc;
				break;

			default:
         break;
    }
} /* genStmt */

/* Procedure genExp generates code at an expression node */
static void genExp( TreeNode * tree, int isAddr)
{
  TreeNode * p1, * p2;
	char lab1[10], lab2[10];
	char codestr[CODESIZE];

  switch (tree->kind.exp) 
	{
    case ConstK :
      if (TraceCode) emitComment("-> Const") ;
			switch (tree->attr.vartype)
			{
				case Integer:
					sprintf(codestr, "%s %d", "ldci", tree->attr.vali);
					break;
				case Float:
					sprintf(codestr, "%s %f", "ldcf", tree->attr.valf);
				  break;
				case Char:
					sprintf(codestr, "%s %c", "ldcc", tree->attr.valch);
					break;
			}
			emitCode(codestr);
      if (TraceCode)  emitComment("<- Const") ;
      break; /* ConstK */
    
		case NotK:
			if (TraceCode) 
				emitComment("-> Not") ;
			cGen(tree->child[0]);
			emitCode("not");
			if (TraceCode) emitComment("<- Not") ;
			break;	/* NotK */

		case ArrayK:
			if (TraceCode) 
				emitComment("-> Array") ;
			sprintf(codestr, "%s %s", "lod", tree->attr.name);
			emitCode(codestr);
			cGen(tree->child[0]);
			sprintf(codestr, "%s elem_size(%s)", "ixa", tree->attr.name);
			emitCode(codestr);

			if (isAddr == FALSE)
				emitCode("ind 0");
			if (TraceCode) 
				emitComment("<- Array") ;
			break;

    case IdK:
      if (TraceCode) emitComment("-> Id") ;
      if (isAddr == TRUE)
				sprintf(codestr, "%s %s", "lda", tree->attr.name);
			else
				sprintf(codestr, "%s %s", "lod", tree->attr.name);
			emitCode(codestr);
      if (TraceCode)  emitComment("<- Id") ;
      break; /* IdK */

    case OpK :
      if (TraceCode) 
				emitComment("-> Op");
      p1 = tree->child[0];
      p2 = tree->child[1];
    
      switch (tree->attr.op) 
			{
				case ASSIGN:
					genExp(p1, TRUE);
					genExp(p2, FALSE);
					if(isAddr == FALSE)
						emitCode("stn");
					else
						emitCode("sto");
					break;
        case PLUS:
          genExp(p1, FALSE);
					genExp(p2, FALSE);
					
					switch (tree->attr.vartype)
					{
						case Integer: emitCode("adi");	break;
						case Float:		emitCode("adf");	break;
					}
          break;
        case MINUS:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					switch (tree->attr.vartype)
					{
						case Integer: emitCode("subi");	break;
						case Float:		emitCode("subf");	break;
					}
					break;
        case TIMES:
          genExp(p1, FALSE);
					genExp(p2, FALSE);
					switch (tree->attr.vartype)
					{
						case Integer: emitCode("multi");	break;
						case Float:		emitCode("multf");	break;
					}
          break;
        case OVER:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					switch (tree->attr.vartype)
					{
						case Integer: emitCode("divi");	break;
						case Float:		emitCode("divf");	break;
					}
          break;       
				case LT:
          genExp(p1, FALSE);
					genExp(p2, FALSE);
					emitCode("les");
					break;
				case GT:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					emitCode("grt");
					break;
				case LE:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					emitCode("leq");
					break;
				case GE:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					emitCode("geq");
					break;
				case EQ:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					emitCode("equ");
					break;
				case NE:
					genExp(p1, FALSE);
					genExp(p2, FALSE);
					emitCode("neq");
					break;
				case OR:
					genExp(p1, FALSE);
					emitCode("ldc 1");
					emitCode("neq");
					genLabel(lab1);
					sprintf(codestr, "%s %s", "fjp", lab1);
					emitCode("lod TRUE");
					genLabel(lab2);
					sprintf(codestr, "%s %s", "ujp", lab2);
					emitCode(codestr);
					sprintf(codestr, "%s %s", "lab", lab1);
					emitCode(codestr);
					genExp(p2, FALSE);
					sprintf(codestr, "%s %s", "lab", lab2);
					emitCode(codestr);
				  break;
				case AND:
					genExp(p1, FALSE);
					emitCode("ldc 0");
					emitCode("neq");
					genLabel(lab1);
					sprintf(codestr, "%s %s", "fjp", lab1);
					genExp(p2, FALSE);
					genLabel(lab2);
					sprintf(codestr, "%s %s", "ujp", lab2);
					emitCode(codestr);
					sprintf(codestr, "%s %s", "lab", lab1);
					emitCode(codestr);
					emitCode("lod FALSE");
					sprintf(codestr, "%s %s", "lab", lab2);
					emitCode(codestr);
				  break;
        default:
          emitComment("BUG: Unknown operator");
          break;
      } /* case op */
      if (TraceCode)
				emitComment("<- Op");
        break; /* OpK */

		case CallK:
      if (TraceCode)
				emitComment("-> Call");
			p1 = tree->child[0];
			p2 = tree->child[1];

			emitCode("mst");
			while(p2 != 0)
			{
				genExp(p2, FALSE);
				p2 = p2 -> sibling;
			}
			sprintf(codestr, "%s %s", "cup", p1->attr.name);
			emitCode(codestr);
      if (TraceCode)
				emitComment("<- Call");
			break;

    default:
      break;
  }
} /* genExp */

static void genDecl(TreeNode * tree)
{
	TreeNode *p1, *p2, *p3, *p4;
	char codestr[CODESIZE];

	switch (tree->kind.decl)
	{
	case VarDeclK:
    if (TraceCode)
			emitComment("-> VarDecl");
	
		for(p2 = tree->child[1]; p2 != 0; p2 = p2->sibling)
		{
			switch (p2->attr.vartype)
			{
				case Integer:
					st_setLoc(p2->attr.name, loc);
					loc += 4;
					if(p2->kind.exp == ArrayK)
					{
						loc += 4 * (p2->child[0]->attr.vali - 1);
					}
					break;
				case Float:
					st_setLoc(p2->attr.name, loc);
					loc += 4;
					if(p2->kind.exp == ArrayK)
					{
						loc += 4 * (p2->child[0]->attr.vali - 1);
					}
					break;
				case Char:
					st_setLoc(p2->attr.name, loc);
					loc += 1;
					if(p2->kind.exp == ArrayK)
					{
						loc += 4 * (p2->child[0]->attr.vali - 1);
					}
					break;
			}
		}

    if (TraceCode)
			emitComment("<- VarDecl");
		break; /* VarDeclK */

	case FuncDefK:
		p2 = tree->child[1];
		p3 = tree->child[2];
		p4 = tree->child[3];

		loc = 0;

		if (TraceCode)
			emitComment("-> FuncDef");
		
		genLabel(funExitLab);
		sprintf(codestr, "%s %s", "ent", p2->attr.name);
		emitCode(codestr);
		st_setLoc(p2->attr.name, emitLoc);
		st_newBuck();
		cGen(p3);
		cGen(p4);
		st_delBuck();
		sprintf(codestr, "%s %s", "lab", funExitLab);
		emitCode(codestr);
		emitCode("ret");

    if (TraceCode)
			emitComment("<- FuncDef");
		break;	/* FuncDefK */

	case ParamK:
		st_setLoc(tree->child[1]->attr.name, loc);
		switch (tree->child[0]->attr.vartype)
		{
			case Integer:	loc += 4;	break;
			case Float:		loc += 4;	break;
			case Char:		loc += 1; break;
		}
		break;

	default:
		break;
	}
}
/* Procedure cGen recursively generates code by
 * tree traversal
 */
static void cGen( TreeNode * tree)
{
	if (tree != NULL)
  { switch (tree->nodekind) {
      case StmtK:
        genStmt(tree);
        break;
      case ExpK:
        genExp(tree, TRUE);		//set to TRUE for destructive store
        break;
			case DeclK:
				genDecl(tree);
      default:
        break;
    }
    cGen(tree->sibling);
  }
}

/**********************************************/
/* the primary function of the code generator */
/**********************************************/
/* Procedure codeGen generates code to a code
 * file by traversal of the syntax tree. The
 * second parameter (codefile) is the file name
 * of the code file, and is used to print the
 * file name as a comment in the code file
 */
void codeGen(TreeNode * syntaxTree, char * codefile)
{
	char* s = (char*) malloc(strlen(codefile)+7);

  strcpy(s,"File: ");
  strcat(s,codefile);
  emitComment("C- Compilation to P-Code");
  emitComment(s);

  /* generate code for C- program */
  cGen(syntaxTree);

  /* finish */
  emitComment("End of execution.");
  //emitCode("stp");

	if (TraceAnalyze)
  { 
		fprintf(listing,"\nSymbol table:\n\n");
    printSymTab(listing);
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美激情插| 樱花草国产18久久久久| 色伊人久久综合中文字幕| 麻豆91在线播放| 亚洲午夜精品在线| 天堂资源在线中文精品| 五月天视频一区| 美女www一区二区| 精品系列免费在线观看| 国产乱子伦视频一区二区三区| 久久精品国产在热久久| 国模一区二区三区白浆| 精彩视频一区二区三区| 国产a精品视频| 99久久综合精品| 欧美色电影在线| 日韩一区二区三区三四区视频在线观看 | av成人动漫在线观看| www.欧美日韩| 欧美综合色免费| 亚洲欧美在线aaa| 亚洲视频一区二区在线| 一二三区精品视频| 日韩va亚洲va欧美va久久| 亚洲成人自拍一区| 国产成人综合视频| 麻豆成人久久精品二区三区小说| 久久99精品网久久| 99天天综合性| 日韩视频免费观看高清在线视频| 国产精品视频免费看| 一区二区三区免费观看| 免费成人你懂的| 91在线播放网址| 欧美电影免费观看完整版 | 久久精品国产一区二区三| 国产不卡视频一区二区三区| 91一区二区三区在线播放| 欧美电影一区二区三区| 国产女同性恋一区二区| 性感美女久久精品| 成人精品视频一区| 精品国产乱码久久久久久夜甘婷婷| 国产区在线观看成人精品 | 国产精品电影院| 天天av天天翘天天综合网色鬼国产| 国产激情视频一区二区三区欧美| 欧洲一区二区三区在线| 中文字幕av免费专区久久| 琪琪一区二区三区| 欧美做爰猛烈大尺度电影无法无天| 精品1区2区在线观看| 亚洲国产精品自拍| 99re这里只有精品视频首页| 久久人人爽爽爽人久久久| 午夜精品aaa| 一本到一区二区三区| 国产欧美精品一区| 久久99精品久久久久久久久久久久 | 成av人片一区二区| 欧美精品一区二区三区一线天视频 | 国产不卡免费视频| 2017欧美狠狠色| 奇米四色…亚洲| 91精品国产综合久久福利| 亚洲一区二区三区精品在线| 北条麻妃一区二区三区| 日本一区二区三区国色天香| 国产综合色在线视频区| 精品1区2区在线观看| 激情亚洲综合在线| 久久影院午夜论| 狠狠色综合播放一区二区| 欧美一区二区黄色| 美国毛片一区二区三区| 精品免费日韩av| 国产永久精品大片wwwapp| 日韩欧美精品在线视频| 美女被吸乳得到大胸91| 欧美一级二级三级蜜桃| 麻豆一区二区在线| 久久久久国产精品人| 国产高清亚洲一区| 国产精品麻豆网站| 91麻豆精品秘密| 亚洲一区二区三区四区中文字幕| 欧美性受xxxx黑人xyx性爽| 亚洲第一会所有码转帖| 7777精品伊人久久久大香线蕉超级流畅 | 7777精品久久久大香线蕉| 日韩精品亚洲专区| 欧美大片一区二区| 成人综合在线观看| 亚洲欧洲制服丝袜| 91精品午夜视频| 国产精品一区在线观看你懂的| 久久久久久久久久久久久久久99 | 中日韩av电影| 91免费看视频| 免费高清视频精品| 国产欧美日韩三区| 在线观看亚洲一区| 精品一区二区三区日韩| 国产精品久久久久一区| 欧美日韩在线精品一区二区三区激情 | 久久久精品免费免费| 99久久精品国产导航| 首页欧美精品中文字幕| 久久九九影视网| 色哟哟国产精品| 国产一区91精品张津瑜| 一区二区高清视频在线观看| 日韩亚洲欧美成人一区| 99国产精品99久久久久久| 日韩精品一二三| 亚洲精品国产一区二区三区四区在线| 91麻豆精品91久久久久同性| 91麻豆精东视频| 国产精品主播直播| 日韩av成人高清| 亚洲丝袜制服诱惑| 2023国产精华国产精品| 欧美美女一区二区三区| 91小宝寻花一区二区三区| 久久狠狠亚洲综合| 亚洲成人免费观看| 国产精品第四页| 国产午夜一区二区三区| 欧美精品xxxxbbbb| 日本大香伊一区二区三区| 风流少妇一区二区| 国模一区二区三区白浆| 日本不卡视频一二三区| 亚洲摸摸操操av| 欧美国产综合一区二区| 精品国产sm最大网站| 91精品久久久久久久99蜜桃| 色悠悠亚洲一区二区| 成人精品视频一区二区三区| 狠狠色2019综合网| 免费日韩伦理电影| 日本成人在线一区| 日韩精彩视频在线观看| 亚洲第一电影网| 亚洲精品中文在线影院| 成人欧美一区二区三区| 国产精品久久久久久久岛一牛影视 | 中文字幕一区二区三区色视频| 久久久久久久久久久久电影 | 综合在线观看色| 中文字幕亚洲在| 亚洲欧美中日韩| 国产精品久久久久7777按摩 | 亚洲成人av中文| 亚洲成av人**亚洲成av**| 亚洲一区免费观看| 亚洲综合成人在线| 亚洲一区二区视频| 奇米影视一区二区三区小说| 奇米色一区二区三区四区| 精品一区二区三区视频在线观看| 久久99精品视频| 福利视频网站一区二区三区| 97久久人人超碰| 日本韩国欧美三级| 欧美精品乱人伦久久久久久| 欧美一区二区三区视频在线| 精品国内二区三区| 国产视频不卡一区| 国产精品不卡在线| 亚洲福中文字幕伊人影院| 日韩制服丝袜av| 国产91在线看| 欧美亚洲国产怡红院影院| 91精品国产麻豆国产自产在线 | 免费看黄色91| 国产一区二区三区免费看| 99久久精品国产一区二区三区| 欧美视频中文一区二区三区在线观看| 91麻豆精品国产91久久久久久 | 欧美成人福利视频| 国产精品久久久久天堂| 亚洲成人综合在线| 国产成人av福利| 欧美三级电影在线观看| 欧美精品一区二区三区很污很色的| 国产欧美综合在线| 亚洲一区电影777| 国产麻豆欧美日韩一区| 色激情天天射综合网| 久久人人爽人人爽| 亚洲一卡二卡三卡四卡无卡久久 | 久久99精品国产.久久久久| 不卡一区中文字幕| 91精品国产欧美一区二区成人| 国产精品美女久久久久高潮| 欧美a级理论片| 在线观看不卡视频| 国产精品激情偷乱一区二区∴| 免费观看在线综合色|