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

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

?? util.c

?? 一個C語言的編譯器
?? C
字號:

#include "globals.h"
#include "util.h"
#include "parse.h"

void printType(Type type)
{
	switch(type){
	case Void:	fprintf(listing,"Void"); break;
	case Integer:	fprintf(listing,"Integer"); break;
	case Double:	fprintf(listing,"Double"); break;
	case Char:	fprintf(listing,"Char"); break;
	case Boolean:	fprintf(listing,"Boolean"); break;
	default: fprintf(listing,"Unknown Type"); break;
	}
}

/* procedure printToken prints a token 
 * and its lexeme to the listing file
 */
void printToken(TokenType token, const char* tokenString )
{ switch (token)
  { case INT:
	case CHAR:
	case DOUBLE:
	case VOID:
	case IF:
    case ELSE:
    case WHILE:
    case RETURN:
	case FOR:
	case INPUT:
	case OUTPUT:
      fprintf(listing,"reserved word: %s\n",tokenString);
      break;
      case PLUS: fprintf(listing,"+\n"); break;
    case SUB:  fprintf(listing,"-\n"); break;
    case MUT:  fprintf(listing,"*\n"); break;
    case DIV:  fprintf(listing,"/\n"); break;
	case MOD:  fprintf(listing,"%%\n"); break;
	case INC:  fprintf(listing,"++\n"); break;
	case DEC:  fprintf(listing,"--\n"); break;
	case B_XOR:  fprintf(listing,"^\n"); break;
	case B_LEFT:fprintf(listing,"<<\n"); break;
	case B_RIGHT:fprintf(listing,">>\n"); break;
	case B_NOT:  fprintf(listing,"~\n"); break;
	case B_AND:  fprintf(listing,"&\n"); break;
	case B_OR:   fprintf(listing,"|\n"); break;
	//關系運算
    case LT: fprintf(listing,"<\n"); break;
    case LE: fprintf(listing,"<=\n"); break;
    case GT: fprintf(listing,">\n"); break;
    case GE: fprintf(listing,">=\n"); break;
    case EQ: fprintf(listing,"==\n"); break;
    case NEQ: fprintf(listing,"!=\n"); break;
	//邏輯運算
    case AND: fprintf(listing,"&&\n"); break;
    case OR: fprintf(listing,"||\n"); break;
    case NOT: fprintf(listing,"!\n"); break;
	//輔助符號
    case ASSIGN: fprintf(listing,"=\n"); break;
    case SEMI: fprintf(listing,";\n"); break;
    case COMMA: fprintf(listing,",\n"); break;
    case LP: fprintf(listing,"(\n"); break;
    case RP: fprintf(listing,")\n"); break;
    case LSP: fprintf(listing,"[\n"); break;
    case RSP: fprintf(listing,"]\n"); break;
    case LFP: fprintf(listing,"{\n"); break;
    case RFP: fprintf(listing,"}\n"); break;
    case ENDFILE: fprintf(listing,"EOF\n"); break;
    case NUM: fprintf(listing,"NUM, val= %s\n",tokenString); break;
    case FNUM: fprintf(listing,"FNUM, val= %s\n",tokenString); break;
	case SCHAR: fprintf(listing,"SCHAR, val= %s\n",tokenString); break;
    case ID: fprintf(listing,"ID, name= %s\n",tokenString); break;
    case ERROR:fprintf(listing,"ERROR: %s\n",tokenString); break;
    case '\0':fprintf(listing,"End_Flag: '\\0'\n"); break;
    default: /* should never happen */
         fprintf(listing,"Unknown token: %s\n",token);//%c
  }
}

/* function newNode creates a new treenode
 * for syntax tree construction
 */
TreeNode * newDecNode(DecKind kind)
{ 
  TreeNode * t = (TreeNode *) malloc(sizeof(TreeNode));
  int i;
  if (t==NULL)
    fprintf(listing,"Out of memory error at line %d\n",lineno);
  else {
    for (i=0;i<MAXCHILDREN;i++) t->child[i] = NULL;
    t->sibling = NULL;
    t->nodekind = Dec;
    t->lineno = lineno;
	t->call_stmt = 0;
    t->kind.dec = kind;
  }
  return t;
}

TreeNode * newStmtNode(StmtKind kind)
{ TreeNode * t = (TreeNode *) malloc(sizeof(TreeNode));
  int i;
  if (t==NULL)
    fprintf(listing,"Out of memory error at line %d\n",lineno);
  else {
    for (i=0;i<MAXCHILDREN;i++) t->child[i] = NULL;
    t->sibling = NULL;
    t->nodekind = Stmt;
    t->lineno = lineno;
	t->call_stmt = 0;
	t->kind.stmt = kind;
  }
  return t;
}

TreeNode * newExpNode(ExpKind kind)
{ TreeNode * t = (TreeNode *) malloc(sizeof(TreeNode));
  int i;
  if (t==NULL)
    fprintf(listing,"Out of memory error at line %d\n",lineno);
  else {
    for (i=0;i<MAXCHILDREN;i++) t->child[i] = NULL;
    t->sibling = NULL;
    t->nodekind = Exp;
    t->lineno = lineno;
	t->call_stmt = 0;
	t->kind.exp = kind;
  }
  return t;
}


/* function copyString allocates and makes a new
 * copy of an existing string
 */
char * copyString(char * s)
{ int n;
  char * t;
  if (s==NULL) return NULL;
  n = strlen(s)+1;
  t = malloc(n);
  if (t==NULL)
    fprintf(listing,"Out of memory error at line %d\n",lineno);
  else strcpy(t,s);
  return t;
}

/* variable indentno is used by printTree to
 * store current number of spaces to indent
 */
static indentno = 0;

/* macros to increase/decrease indentation */
#define INDENT indentno+=2
#define UNINDENT indentno-=2

/* printSpaces indents by printing spaces */
static void printSpaces(void)
{ int i;
  for (i=0;i<indentno;i++)
    fprintf(listing," ");
}

/* procedure printTree prints a syntax tree to the 
 * listing file using indentation to indicate subtrees
 */
void printTree(TreeNode * tree)
{ int i;
  INDENT;
  while (tree != NULL) {
	printSpaces();
    
    switch (tree ->nodekind) {
	 case Dec:
		 switch(tree ->kind.dec){
		 case VarK:
          fprintf(listing,"ID_Dec Var_Type: ");
		  printType(tree ->type);
		  fprintf(listing,"\n");
          break;
		 case FunDecK:
          fprintf(listing,"Fun_Dec name: %s		Return_Type: ",tree->attr.name);
          printType(tree ->type);
		  fprintf(listing,"\n");
		  break;
		 case FunDefK:
          fprintf(listing,"Fun_Def name: %s		Return_Type: ",tree->attr.name);
		  printType(tree ->type);
		  fprintf(listing,"\n");
          break;
         case ParamK:
          fprintf(listing,"Param_Dec Param_Type: ");
		  printType(tree ->type);
		  fprintf(listing,"\n");
          break;
         case CompK:
          fprintf(listing,"Comp_Dec \n");
          break;
		 }
		 break;
	  case Stmt:
		 switch(tree ->kind.stmt){
         case IfK:
          fprintf(listing,"If\n");
          break;
         case WhileK:
          fprintf(listing,"While\n");
          break;
         case AssignK:
          fprintf(listing,"Assign\n");
          break;
         case ReturnK:
          fprintf(listing,"Return\n");
          break;
         case CallK:
          fprintf(listing,"Call to: %s\n",tree ->attr.name);
          break;
		 }
		 break;
	  case Exp:
		 switch(tree->kind.exp){
         case NumK:
			fprintf(listing,"Num_Const: %d\n",tree->attr.val.i);
			break;
		 case FnumK:
		    fprintf(listing,"FNum_Const: %f\n",tree->attr.val.f);
			break;
         case CharK:
		    fprintf(listing,"Char_Const: %c\n",tree->attr.val.i);
			break;
		 case IdK:
			fprintf(listing,"Var: %s\n",tree->attr.name);
			break;
		 case NotK:
			 fprintf(listing,"Not: \n");
			 break;
		 default:
          fprintf(listing,"Op: ");
          printToken(tree->attr.op,"\0");
          break;
		 }
		 break;
       default:
          fprintf(listing,"Unknown treenode kind\n");
          break;
      }
    
    for (i=0;i<MAXCHILDREN;i++)
         printTree(tree->child[i]);
    tree = tree->sibling;
  }
  UNINDENT;
}
       

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
777a∨成人精品桃花网| 国产精品无人区| 一区二区三区在线观看欧美| 国产成人精品午夜视频免费| 欧美精品一区二区三区四区| 毛片一区二区三区| 日本一区二区三区免费乱视频| 人妖欧美一区二区| 2020国产精品自拍| 国产成人夜色高潮福利影视| 久久久精品免费观看| 99久久精品免费| 亚洲欧洲精品一区二区精品久久久| 成人h动漫精品一区二区| 亚洲乱码中文字幕| 91精品综合久久久久久| 免费高清在线一区| 欧美午夜精品一区二区蜜桃| 国产精品亲子乱子伦xxxx裸| av一二三不卡影片| 亚洲h动漫在线| 欧美哺乳videos| 91丝袜美腿高跟国产极品老师| 日本一区二区三区在线不卡| 99精品在线观看视频| 亚洲综合无码一区二区| 欧美不卡一区二区| thepron国产精品| 亚洲成人动漫av| 国产丝袜美腿一区二区三区| 99精品黄色片免费大全| 三级一区在线视频先锋| 日本一区二区三级电影在线观看| 一本在线高清不卡dvd| 麻豆精品在线观看| 欧美国产禁国产网站cc| 成人深夜视频在线观看| 亚洲国产日韩a在线播放| 日本欧洲一区二区| 中文字幕精品一区| 91精品国产综合久久香蕉的特点| 日韩极品在线观看| 最新不卡av在线| 色素色在线综合| 亚洲二区在线视频| 91精品在线一区二区| 欧美性受xxxx黑人xyx性爽| 国产日韩三级在线| 91免费在线播放| 亚洲乱码日产精品bd | 欧美精品精品一区| 国产成人免费视频| 亚洲国产精品人人做人人爽| 久久九九久久九九| 欧美日韩一区二区在线观看| 国产成人精品亚洲日本在线桃色 | 国产欧美久久久精品影院 | 欧美日韩一区二区欧美激情| 韩国精品在线观看| 一区二区三区中文字幕在线观看| 精品少妇一区二区三区免费观看| 欧美制服丝袜第一页| 日韩主播视频在线| 国产性天天综合网| 日韩亚洲欧美一区| 欧洲视频一区二区| 成人精品免费视频| 国产成人午夜精品5599| 九九视频精品免费| 亚洲人成网站色在线观看| 51精品视频一区二区三区| 91女厕偷拍女厕偷拍高清| 国产不卡高清在线观看视频| 极品美女销魂一区二区三区| 美腿丝袜亚洲一区| 天天影视涩香欲综合网| 亚洲图片欧美色图| 亚洲国产一区二区三区| 欧美中文字幕一区二区三区 | 在线综合+亚洲+欧美中文字幕| 国产美女在线观看一区| 精品国产乱码久久久久久免费| 盗摄精品av一区二区三区| 美腿丝袜亚洲色图| 国产欧美中文在线| 久久久久久久综合狠狠综合| 亚洲天堂中文字幕| 亚洲人精品午夜| 国产精品日产欧美久久久久| 久久久久9999亚洲精品| 久久久久九九视频| 国产肉丝袜一区二区| 国产亚洲欧美中文| 久久精品夜色噜噜亚洲aⅴ| 精品99久久久久久| 国产色综合一区| 国产情人综合久久777777| 国产人久久人人人人爽| 日韩一区欧美一区| 亚洲欧美日韩国产手机在线| 亚洲一区视频在线| 亚洲18影院在线观看| 亚洲免费在线视频一区 二区| 国产精品丝袜在线| 亚洲午夜久久久久中文字幕久| 综合激情成人伊人| 国产高清精品久久久久| 日本一区二区免费在线| 色av成人天堂桃色av| 风间由美性色一区二区三区| 一区二区三区在线影院| 亚洲日本在线看| 久久精品人人做| 99riav一区二区三区| 成人激情免费视频| 欧美精品 日韩| 欧美中文字幕一区| 国产精品系列在线播放| 久久精工是国产品牌吗| 国产激情91久久精品导航| 狠狠狠色丁香婷婷综合久久五月| 亚洲免费资源在线播放| 美日韩一区二区三区| 99久久精品免费精品国产| 国产精品 欧美精品| 日本视频在线一区| 青草av.久久免费一区| 大白屁股一区二区视频| 欧美日韩中文国产| 国产精品久久久久毛片软件| 日本成人在线电影网| 91丨九色丨蝌蚪丨老版| 欧美大片顶级少妇| 亚洲欧洲成人精品av97| 久草精品在线观看| 在线成人高清不卡| 中文字幕欧美一| 久久99精品久久久久久| 一本色道久久加勒比精品| 欧美二区三区的天堂| 国产喷白浆一区二区三区| 亚洲午夜在线电影| 欧美日韩国产色站一区二区三区| 91.xcao| 666欧美在线视频| 欧美精品aⅴ在线视频| 亚洲男人的天堂在线观看| 亚洲图片欧美视频| 色老汉av一区二区三区| 国内久久精品视频| 日韩欧美在线网站| 亚洲国产日韩一区二区| 成人自拍视频在线观看| 久久久夜色精品亚洲| 亚洲日韩欧美一区二区在线| 成人理论电影网| 在线综合+亚洲+欧美中文字幕| 亚洲欧美日韩中文字幕一区二区三区 | 日韩高清在线一区| 高清av一区二区| 欧美军同video69gay| 国产欧美一区二区精品忘忧草| 国模一区二区三区白浆| 色婷婷久久久久swag精品| 亚洲欧美另类小说视频| 亚洲第一会所有码转帖| 欧美偷拍一区二区| 亚洲免费电影在线| 国产精品一线二线三线精华| 久久久三级国产网站| 夜夜揉揉日日人人青青一国产精品| 成人精品国产免费网站| 欧美电视剧免费全集观看| 久久成人久久鬼色| 一本色道久久综合亚洲aⅴ蜜桃 | 亚洲国产视频a| 欧美欧美欧美欧美| 国产亚洲va综合人人澡精品| 懂色av一区二区三区免费观看| 欧美人牲a欧美精品| 欧美96一区二区免费视频| 色婷婷综合久久久| 丝袜美腿高跟呻吟高潮一区| 蜜桃精品视频在线观看| 91福利视频在线| 亚洲va韩国va欧美va精品| 成人app软件下载大全免费| 亚洲精品精品亚洲| 成人av网站免费| 一区二区三区欧美在线观看| 成人性生交大片免费看中文| 亚洲天天做日日做天天谢日日欢| 日韩精品一区二区在线| 国产一区二区剧情av在线| 欧美va日韩va| 国产麻豆欧美日韩一区| 精品对白一区国产伦| 蜜桃视频免费观看一区| 欧美日韩国产乱码电影| 26uuu精品一区二区三区四区在线|