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

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

?? parse.c

?? 一個小型C語言編譯器
?? C
字號:
/****************************************************/
/* File: parse.c                                    */
/* The parser implementation for the TINY compiler  */
/* Compiler Construction: Principles and Practice   */
/* Kenneth C. Louden                                */
/****************************************************/

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

static TokenType token; /* holds current token */

/* function prototypes for recursive calls */
static TreeNode * stmt_sequence(void);
static TreeNode * statement(void);
static TreeNode * if_stmt(void);
static TreeNode * repeat_stmt(void);
static TreeNode * assign_stmt(void);
static TreeNode * read_stmt(void);
static TreeNode * write_stmt(void);
static TreeNode * exp(void);
static TreeNode * simple_exp(void);
static TreeNode * term(void);
static TreeNode * factor(void);

static void syntaxError(char * message)
{ fprintf(listing,"\n>>> ");
  fprintf(listing,"Syntax error at line %d: %s",lineno,message);
  Error = TRUE;
}

static void match(TokenType expected)
{ if (token == expected) token = getToken();
  else {
    syntaxError("unexpected token -> ");
    printToken(token,tokenString);
    fprintf(listing,"      ");
  }
}

TreeNode * stmt_sequence(void)
{ TreeNode * t = statement();
  TreeNode * p = t;
  while ((token!=ENDFILE) && (token!=END) &&
         (token!=ELSE) && (token!=UNTIL))
  { TreeNode * q;
    match(SEMI);
    q = statement();
    if (q!=NULL) {
      if (t==NULL) t = p = q;
      else /* now p cannot be NULL either */
      { p->sibling = q;
        p = q;
      }
    }
  }
  return t;
}

TreeNode * statement(void)
{ TreeNode * t = NULL;
  switch (token) {
    case IF : t = if_stmt(); break;
    case REPEAT : t = repeat_stmt(); break;
    case ID : t = assign_stmt(); break;
    case READ : t = read_stmt(); break;
    case WRITE : t = write_stmt(); break;
    default : syntaxError("unexpected token -> ");
              printToken(token,tokenString);
              token = getToken();
              break;
  } /* end case */
  return t;
}

TreeNode * if_stmt(void)
{ TreeNode * t = newStmtNode(IfK);
  match(IF);
  if (t!=NULL) t->child[0] = exp();
  match(THEN);
  if (t!=NULL) t->child[1] = stmt_sequence();
  if (token==ELSE) {
    match(ELSE);
    if (t!=NULL) t->child[2] = stmt_sequence();
  }
  match(END);
  return t;
}

TreeNode * repeat_stmt(void)
{ TreeNode * t = newStmtNode(RepeatK);
  match(REPEAT);
  if (t!=NULL) t->child[0] = stmt_sequence();
  match(UNTIL);
  if (t!=NULL) t->child[1] = exp();
  return t;
}

TreeNode * assign_stmt(void)
{ TreeNode * t = newStmtNode(AssignK);
  if ((t!=NULL) && (token==ID))
    t->attr.name = copyString(tokenString);
  match(ID);
  match(ASSIGN);
  if (t!=NULL) t->child[0] = exp();
  return t;
}

TreeNode * read_stmt(void)
{ TreeNode * t = newStmtNode(ReadK);
  match(READ);
  if ((t!=NULL) && (token==ID))
    t->attr.name = copyString(tokenString);
  match(ID);
  return t;
}

TreeNode * write_stmt(void)
{ TreeNode * t = newStmtNode(WriteK);
  match(WRITE);
  if (t!=NULL) t->child[0] = exp();
  return t;
}

TreeNode * exp(void)
{ TreeNode * t = simple_exp();
  if ((token==LT)||(token==EQ)) {
    TreeNode * p = newExpNode(OpK);
    if (p!=NULL) {
      p->child[0] = t;
      p->attr.op = token;
      t = p;
    }
    match(token);
    if (t!=NULL)
      t->child[1] = simple_exp();
  }
  return t;
}

TreeNode * simple_exp(void)
{ TreeNode * t = term();
  while ((token==PLUS)||(token==MINUS))
  { TreeNode * p = newExpNode(OpK);
    if (p!=NULL) {
      p->child[0] = t;
      p->attr.op = token;
      t = p;
      match(token);
      t->child[1] = term();
    }
  }
  return t;
}

TreeNode * term(void)
{ TreeNode * t = factor();
  while ((token==TIMES)||(token==OVER))
  { TreeNode * p = newExpNode(OpK);
    if (p!=NULL) {
      p->child[0] = t;
      p->attr.op = token;
      t = p;
      match(token);
      p->child[1] = factor();
    }
  }
  return t;
}

TreeNode * factor(void)
{ TreeNode * t = NULL;
  switch (token) {
    case NUM :
      t = newExpNode(ConstK);
      if ((t!=NULL) && (token==NUM))
        t->attr.val = atoi(tokenString);
      match(NUM);
      break;
    case ID :
      t = newExpNode(IdK);
      if ((t!=NULL) && (token==ID))
        t->attr.name = copyString(tokenString);
      match(ID);
      break;
    case LPAREN :
      match(LPAREN);
      t = exp();
      match(RPAREN);
      break;
    default:
      syntaxError("unexpected token -> ");
      printToken(token,tokenString);
      token = getToken();
      break;
    }
  return t;
}

/****************************************/
/* the primary function of the parser   */
/****************************************/
/* Function parse returns the newly 
 * constructed syntax tree
 */
TreeNode * parse(void)
{ TreeNode * t;
  token = getToken();
  t = stmt_sequence();
  if (token!=ENDFILE)
    syntaxError("Code ends before file\n");
  return t;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
五月天激情综合网| 日韩三级视频在线观看| 亚洲靠逼com| 欧美日韩国产一级二级| 经典三级视频一区| 亚洲日本护士毛茸茸| 欧美一级理论片| 日韩三级免费观看| 欧美zozo另类异族| 色94色欧美sute亚洲13| 国产精华液一区二区三区| 亚洲第一搞黄网站| 综合久久一区二区三区| 亚洲欧美色一区| 国产欧美日韩三区| 亚洲精品一区二区三区在线观看 | 久久色.com| 在线免费不卡电影| 国产高清无密码一区二区三区| 蜜臀av一区二区三区| 一区二区三区欧美日| 欧美国产国产综合| 久久综合九色综合97婷婷女人 | 色婷婷亚洲婷婷| 国产乱码精品一区二区三区忘忧草 | 亚洲国产精品视频| 中文字幕一区二区三区四区| 2017欧美狠狠色| 国产精品色婷婷久久58| 久久久久久久一区| 久久久夜色精品亚洲| 国产精品大尺度| 亚洲欧洲av一区二区三区久久| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆| 亚洲男同1069视频| 麻豆精品在线播放| 色婷婷综合五月| 精品久久一二三区| 亚洲综合色婷婷| 一级女性全黄久久生活片免费| 青青草一区二区三区| 蜜臀91精品一区二区三区| 国产成人精品免费视频网站| 欧美日韩精品欧美日韩精品| 久久久精品日韩欧美| 亚洲电影一级片| 不卡大黄网站免费看| 色综合视频一区二区三区高清| 欧美精品色综合| 欧美一级片免费看| 精品美女一区二区| 亚洲国产精品久久久久婷婷884| 国产成人精品www牛牛影视| 欧美日韩专区在线| 日韩欧美一级片| 国产人成一区二区三区影院| 首页亚洲欧美制服丝腿| 久久精品久久精品| 福利一区在线观看| 在线观看一区日韩| 国产精品久久久久aaaa樱花| 精品一区二区免费看| 欧洲一区二区三区在线| 国产精品你懂的| 国产成人综合在线| 久久久久久久久久久久电影| 免费人成网站在线观看欧美高清| 欧美日韩一区二区在线观看 | 亚洲国产高清不卡| 精品一区二区三区免费| 日韩亚洲欧美高清| 日韩在线一二三区| 91精品国产手机| 日韩精品成人一区二区三区| 欧美私模裸体表演在线观看| 日韩一区二区三区免费观看| 视频一区视频二区在线观看| 91精品国产综合久久小美女| 欧美国产日产图区| 粉嫩高潮美女一区二区三区 | 亚洲日本护士毛茸茸| 成人av综合在线| 亚洲欧洲精品一区二区三区| 91一区二区三区在线观看| 日韩你懂的在线播放| 精品一区精品二区高清| 久久久99精品久久| 午夜视频一区二区三区| 欧美精品少妇一区二区三区| 日韩成人精品视频| 色婷婷av一区| 香蕉久久一区二区不卡无毒影院| 91精品国产综合久久久久| 奇米精品一区二区三区在线观看| 2021国产精品久久精品| 成人美女在线观看| 久久久91精品国产一区二区精品| 国产一区二区毛片| 日韩一区二区三区四区| 激情综合色播五月| 欧美日韩中文字幕一区| 日韩电影在线免费观看| 国产日韩欧美综合一区| 91啪亚洲精品| 蜜臀a∨国产成人精品| 欧美极品少妇xxxxⅹ高跟鞋| 在线精品观看国产| 久久国产精品区| 亚洲欧洲国产日本综合| 欧美精品黑人性xxxx| 国产精品一区二区在线观看不卡 | 国产一区欧美日韩| 亚洲日本在线看| 日韩一二三区视频| 91在线免费播放| 亚洲欧洲www| 精品国产伦理网| 欧美在线观看你懂的| 国产在线精品不卡| 亚洲成人av资源| 国产精品乱码一区二区三区软件| 欧美视频一二三区| 99久久精品免费看国产免费软件| 秋霞午夜鲁丝一区二区老狼| 国产精品毛片高清在线完整版| 欧美一区欧美二区| 色中色一区二区| 波多野结衣精品在线| 伊人夜夜躁av伊人久久| 国产区在线观看成人精品| 91精品国产综合久久福利软件| 91在线免费播放| 国产成人午夜电影网| 精品一区二区三区在线视频| 亚洲成人av免费| 亚洲最大色网站| 最近日韩中文字幕| 国产亚洲精品bt天堂精选| 日韩免费视频一区| 欧美一区二区播放| 777xxx欧美| 欧美区视频在线观看| 欧美性猛片xxxx免费看久爱| 99久久婷婷国产精品综合| 成人免费视频网站在线观看| 国产一区二区在线免费观看| 久久丁香综合五月国产三级网站| 石原莉奈在线亚洲二区| 日日骚欧美日韩| 亚洲123区在线观看| 天堂精品中文字幕在线| 亚洲3atv精品一区二区三区| 亚洲成人免费在线观看| 亚州成人在线电影| 天堂成人国产精品一区| 蜜桃视频第一区免费观看| 蜜桃免费网站一区二区三区| 久久精品久久精品| 国产一区999| 成人影视亚洲图片在线| 成人动漫一区二区三区| www.亚洲在线| 欧美亚洲国产一区二区三区va| 一本大道久久a久久精二百| 欧美在线免费播放| 欧美久久久久久久久中文字幕| 91.com在线观看| 精品国产三级a在线观看| 国产三级三级三级精品8ⅰ区| 国产亚洲一本大道中文在线| 国产精品美女久久久久高潮| 中文字幕综合网| 亚洲第一会所有码转帖| 精久久久久久久久久久| 国产成人精品影视| 欧美在线色视频| 日韩写真欧美这视频| 欧美国产精品中文字幕| 亚洲免费伊人电影| 麻豆成人在线观看| 99久久综合狠狠综合久久| 欧美日韩三级一区二区| 精品久久99ma| 一区二区三区精密机械公司| 蜜臀av一区二区在线观看| 成人高清在线视频| 欧美一区二区三区在线观看| 亚洲国产精品精华液ab| 亚洲在线视频一区| 国产乱色国产精品免费视频| 欧美中文字幕一二三区视频| 久久亚洲一区二区三区明星换脸| 亚洲欧美国产毛片在线| 毛片不卡一区二区| 91成人网在线| 久久嫩草精品久久久精品一| 亚洲曰韩产成在线| 成人午夜视频免费看| 日韩午夜电影在线观看| 亚洲欧美电影院|