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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? cc3.c

?? 一個小的c語言的編譯程序源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
** Small-C Compiler -- Part 3 -- Expression Analyzer.
** Copyright 1982, 1983, 1985, 1988 J. E. Hendrix
** All rights reserved.
*/

#include <stdio.h>
#include "cc.h"

#define ST 0   /* is[ST] - symbol table address, else 0 */
#define TI 1   /* is[TI] - type of indirect obj to fetch, else 0 */
#define TA 2   /* is[TA] - type of address, else 0 */
#define TC 3   /* is[TC] - type of constant (INT or UINT), else 0 */
#define CV 4   /* is[CV] - value of constant (+ auxiliary uses) */
#define OP 5   /* is[OP] - code of highest/last binary operator */
#define SA 6   /* is[SA] - stage address of "op 0" code, else 0 */

extern char
 *litq, *glbptr, *lptr,  ssname[NAMESIZE],  quote[2];
extern int
  ch,  csp,  litlab,  litptr,  nch,  op[16],  op2[16],
  opindex,  opsize, *snext;

/***************** lead-in functions *******************/

constexpr(val) int *val; {
  int const;
  int *before, *start;
  setstage(&before, &start);
  expression(&const, val);
  clearstage(before, 0);     /* scratch generated code */
  if(const == 0) error("must be constant expression");
  return const;
  }

expression(con, val) int *con, *val;  {
  int is[7];
  if(level1(is)) fetch(is);
  *con = is[TC];
  *val = is[CV];
  }

test(label, parens)  int label, parens;  {
  int is[7];
  int *before, *start;
  if(parens) need("(");
  while(1) {
    setstage(&before, &start);
    if(level1(is)) fetch(is);
    if(match(",")) clearstage(before, start);
    else break;
    }
  if(parens) need(")");
  if(is[TC]) {             /* constant expression */
    clearstage(before, 0);
    if(is[CV]) return;
    gen(JMPm, label);
    return;
    }
  if(is[SA]) {             /* stage address of "oper 0" code */
    switch(is[OP]) {       /* operator code */
      case EQ12:
      case LE12u: zerojump(EQ10f, label, is); break;
      case NE12:
      case GT12u: zerojump(NE10f, label, is); break;
      case GT12:  zerojump(GT10f, label, is); break;
      case GE12:  zerojump(GE10f, label, is); break;
      case GE12u: clearstage(is[SA], 0);      break;
      case LT12:  zerojump(LT10f, label, is); break;
      case LT12u: zerojump(JMPm,  label, is); break;
      case LE12:  zerojump(LE10f, label, is); break;
      default:    gen(NE10f, label);          break;
      }
    }
  else gen(NE10f, label);
  clearstage(before, start);
  }

/*
** test primary register against zero and jump if false
*/
zerojump(oper, label, is) int oper, label, is[]; {
  clearstage(is[SA], 0);       /* purge conventional code */
  gen(oper, label);
  }

/***************** precedence levels ******************/

level1(is) int is[];  {
  int k, is2[7], is3[2], oper, oper2;
  k = down1(level2, is);
  if(is[TC]) gen(GETw1n, is[CV]);
       if(match("|="))  {oper =        oper2 = OR12;}
  else if(match("^="))  {oper =        oper2 = XOR12;}
  else if(match("&="))  {oper =        oper2 = AND12;}
  else if(match("+="))  {oper =        oper2 = ADD12;}
  else if(match("-="))  {oper =        oper2 = SUB12;}
  else if(match("*="))  {oper = MUL12; oper2 = MUL12u;}
  else if(match("/="))  {oper = DIV12; oper2 = DIV12u;}
  else if(match("%="))  {oper = MOD12; oper2 = MOD12u;}
  else if(match(">>=")) {oper =        oper2 = ASR12;}
  else if(match("<<=")) {oper =        oper2 = ASL12;}
  else if(match("="))   {oper =        oper2 = 0;}
  else return k;
                        /* have an assignment operator */
  if(k == 0) {
    needlval();
    return 0;
    }
  is3[ST] = is[ST];
  is3[TI] = is[TI];
  if(is[TI]) {                             /* indirect target */
    if(oper) {                             /* ?= */
      gen(PUSH1, 0);                       /* save address */
      fetch(is);                           /* fetch left side */
      }
    down2(oper, oper2, level1, is, is2);   /* parse right side */
    if(oper) gen(POP2, 0);                 /* retrieve address */
    }
  else {                                   /* direct target */
    if(oper) {                             /* ?= */
      fetch(is);                           /* fetch left side */
      down2(oper, oper2, level1, is, is2); /* parse right side */
      }
    else {                                 /*  = */
      if(level1(is2)) fetch(is2);          /* parse right side */
      }
    }
  store(is3);                              /* store result */
  return 0;
  }

level2(is1)  int is1[]; {
  int is2[7], is3[7], k, flab, endlab, *before, *after;
  k = down1(level3, is1);                   /* expression 1 */
  if(match("?") == 0) return k;
  dropout(k, NE10f, flab = getlabel(), is1);
  if(down1(level2, is2)) fetch(is2);        /* expression 2 */
  else if(is2[TC]) gen(GETw1n, is2[CV]);
  need(":");
  gen(JMPm, endlab = getlabel());
  gen(LABm, flab);
  if(down1(level2, is3)) fetch(is3);        /* expression 3 */
  else if(is3[TC]) gen(GETw1n, is3[CV]);
  gen(LABm, endlab);

  is1[TC] = is1[CV] = 0;
  if(is2[TC] && is3[TC]) {                  /* expr1 ? const2 : const3 */
    is1[TA] = is1[TI] = is1[SA] = 0;
    }
  else if(is3[TC]) {                        /* expr1 ? var2 : const3 */
    is1[TA] = is2[TA];
    is1[TI] = is2[TI];
    is1[SA] = is2[SA];
    }
  else if((is2[TC])                         /* expr1 ? const2 : var3 */
       || (is2[TA] == is3[TA])) {           /* expr1 ? same2 : same3 */
    is1[TA] = is3[TA];
    is1[TI] = is3[TI];
    is1[SA] = is3[SA];
    }
  else error("mismatched expressions");
  return 0;
  }

level3 (is) int is[]; {return skim("||", EQ10f, 1, 0, level4,  is);}
level4 (is) int is[]; {return skim("&&", NE10f, 0, 1, level5,  is);}
level5 (is) int is[]; {return down("|",            0, level6,  is);}
level6 (is) int is[]; {return down("^",            1, level7,  is);}
level7 (is) int is[]; {return down("&",            2, level8,  is);}
level8 (is) int is[]; {return down("== !=",        3, level9,  is);}
level9 (is) int is[]; {return down("<= >= < >",    5, level10, is);}
level10(is) int is[]; {return down(">> <<",        9, level11, is);}
level11(is) int is[]; {return down("+ -",         11, level12, is);}
level12(is) int is[]; {return down("* / %",       13, level13, is);}

level13(is)  int is[];  {
  int k;
  char *ptr;
  if(match("++")) {                 /* ++lval */
    if(level13(is) == 0) {
      needlval();
      return 0;
      }
    step(rINC1, is, 0);
    return 0;
    }
  else if(match("--")) {            /* --lval */
    if(level13(is) == 0) {
      needlval();
      return 0;
      }
    step(rDEC1, is, 0);
    return 0;
    }
  else if(match("~")) {             /* ~ */
    if(level13(is)) fetch(is);
    gen(COM1, 0);
    is[CV] = ~ is[CV];
    return (is[SA] = 0);
    }
  else if(match("!")) {             /* ! */
    if(level13(is)) fetch(is);
    gen(LNEG1, 0);
    is[CV] = ! is[CV];
    return (is[SA] = 0);
    }
  else if(match("-")) {             /* unary - */
    if(level13(is)) fetch(is);
    gen(ANEG1, 0);
    is[CV] = -is[CV];
    return (is[SA] = 0);
    }
  else if(match("*")) {             /* unary * */
    if(level13(is)) fetch(is);
    if(ptr = is[ST]) is[TI] = ptr[TYPE];
    else             is[TI] = INT;
    is[SA] =       /* no (op 0) stage address */
    is[TA] =       /* not an address */
    is[TC] = 0;    /* not a constant */
    is[CV] = 1;    /* omit fetch() on func call */
    return 1;
    }
  else if(amatch("sizeof", 6)) {    /* sizeof() */
    int sz, p;  char *ptr, sname[NAMESIZE];
    if(match("(")) p = 1;
    else           p = 0;
    sz = 0;
    if     (amatch("unsigned", 8))  sz = BPW;
    if     (amatch("int",      3))  sz = BPW;
    else if(amatch("char",     4))  sz = 1;
    if(sz) {if(match("*"))          sz = BPW;}
    else if(symname(sname)
         && ((ptr = findloc(sname)) ||
             (ptr = findglb(sname)))
         && ptr[IDENT] != FUNCTION
         && ptr[IDENT] != LABEL)    sz = getint(ptr+SIZE, 2);
    else if(sz == 0) error("must be object or type");
    if(p) need(")");
    is[TC] = INT;
    is[CV] = sz;
    is[TA] = is[TI] = is[ST] = 0;
    return 0;
    }
  else if(match("&")) {             /* unary & */
    if(level13(is) == 0) {
      error("illegal address");
      return 0;
      }
    ptr = is[ST];
    is[TA] = ptr[TYPE];
    if(is[TI]) return 0;
    gen(POINT1m, ptr);
    is[TI] = ptr[TYPE];
    return 0;
    }
  else {
    k = level14(is);
    if(match("++")) {               /* lval++ */
      if(k == 0) {
        needlval();
        return 0;
        }
      step(rINC1, is, rDEC1);
      return 0;
      }
    else if(match("--")) {          /* lval-- */
      if(k == 0) {
        needlval();
        return 0;
        }
      step(rDEC1, is, rINC1);
      return 0;
      }
    else return k;
    }
  }

level14(is)  int *is; {
  int k, const, val;
  char *ptr, *before, *start;
  k = primary(is);
  ptr = is[ST];
  blanks();
  if(ch == '[' || ch == '(') {
    int is2[7];                     /* allocate only if needed */
    while(1) {
      if(match("[")) {              /* [subscript] */
        if(ptr == 0) {
          error("can't subscript");
          skip();
          need("]");
          return 0;
          }
        if(is[TA]) {if(k) fetch(is);}
        else       {error("can't subscript"); k = 0;}
        setstage(&before, &start);
        is2[TC] = 0;
        down2(0, 0, level1, is2, is2);
        need("]");
        if(is2[TC]) {
          clearstage(before, 0);
          if(is2[CV]) {             /* only add if non-zero */
            if(ptr[TYPE] >> 2 == BPW)
                 gen(GETw2n, is2[CV] << LBPW);
            else gen(GETw2n, is2[CV]);
            gen(ADD12, 0);
            }
          }
        else {
          if(ptr[TYPE] >> 2 == BPW) gen(DBL1, 0);
          gen(ADD12, 0);
          }
        is[TA] = 0;
        is[TI] = ptr[TYPE];
        k = 1;
        }
      else if(match("(")) {         /* function(...) */
        if(ptr == 0) callfunc(0);
        else if(ptr[IDENT] != FUNCTION) {
          if(k && !is[CV]) fetch(is);
          callfunc(0);
          }
        else callfunc(ptr);
        k = is[ST] = is[TC] = is[CV] = 0;
        }
      else return k;
      }
    }
  if(ptr && ptr[IDENT] == FUNCTION) {
    gen(POINT1m, ptr);
    is[ST] = 0;
    return 0;
    }
  return k;
  }

primary(is)  int *is; {
  char *ptr, sname[NAMESIZE];
  int k;
  if(match("(")) {                  /* (subexpression) */ 
    do k = level1(is); while(match(","));
    need(")");
    return k;
    }
  putint(0, is, 7 << LBPW);         /* clear "is" array */
  if(symname(sname)) {              /* is legal symbol */
    if(ptr = findloc(sname)) {      /* is local */
      if(ptr[IDENT] == LABEL) {
        experr();
        return 0;
        }
      gen(POINT1s, getint(ptr+OFFSET, 2));
      is[ST] = ptr;
      is[TI] = ptr[TYPE];
      if(ptr[IDENT] == ARRAY) {
        is[TA] = ptr[TYPE];
        return 0;
        }
      if(ptr[IDENT] == POINTER) {
        is[TI] = UINT;
        is[TA] = ptr[TYPE];
        }
      return 1;
      }
    if(ptr = findglb(sname)) {      /* is global */
      is[ST] = ptr;
      if(ptr[IDENT] != FUNCTION) {
        if(ptr[IDENT] == ARRAY) {
          gen(POINT1m, ptr);
          is[TI] = 
          is[TA] = ptr[TYPE];
          return 0;
          }
        if(ptr[IDENT] == POINTER)
          is[TA] = ptr[TYPE];
        return 1;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产麻豆精品theporn| 国产美女视频一区| 久久久久国产精品人| 色婷婷国产精品| 国产成人精品三级| 亚洲国产综合91精品麻豆| 久久嫩草精品久久久久| 欧美日韩免费在线视频| 成人精品国产免费网站| 另类成人小视频在线| 亚洲一级不卡视频| 久久人人爽爽爽人久久久| 欧美久久久久久蜜桃| 91啪亚洲精品| 成人午夜视频福利| 国产一区二区毛片| 麻豆91在线看| 日韩电影在线一区二区| 亚洲美女在线国产| 日韩理论在线观看| 国产日产亚洲精品系列| 精品国产一区久久| 欧美日韩不卡视频| 欧美图片一区二区三区| 91亚洲精华国产精华精华液| 成人亚洲一区二区一| 国产在线不卡一区| 久久www免费人成看片高清| 午夜精品爽啪视频| 亚洲午夜av在线| 亚洲综合网站在线观看| 亚洲黄色小视频| 国产成人在线视频网址| 蜜臀av国产精品久久久久 | 亚洲码国产岛国毛片在线| 久久久欧美精品sm网站| 欧美成人精精品一区二区频| 欧美一区二区三区思思人| 欧美二区乱c少妇| 4438亚洲最大| 91麻豆精品国产91久久久久| 欧美一区二区三区视频在线| 91 com成人网| 欧美一区二区三区免费在线看| 欧美日韩精品二区第二页| 欧美日韩国产一区| 欧美精品第1页| 欧美一区二区三区啪啪| 欧美大片一区二区| 久久综合狠狠综合久久激情 | 色婷婷久久久久swag精品| 色偷偷成人一区二区三区91| 91久久精品日日躁夜夜躁欧美| 色噜噜狠狠成人中文综合| 色婷婷亚洲精品| 欧美丰满少妇xxxxx高潮对白 | 亚洲天堂中文字幕| 一区二区久久久| 视频一区免费在线观看| 麻豆一区二区三区| 国产成人精品一区二区三区四区 | 成人妖精视频yjsp地址| 91免费视频网| 欧美一区二区大片| 久久久99精品久久| 亚洲视频在线一区观看| 亚洲成在人线免费| 国模一区二区三区白浆 | 97精品超碰一区二区三区| 黄网站免费久久| 成人免费av资源| 欧美日韩性生活| 日韩免费性生活视频播放| 国产精品午夜久久| 91免费在线看| 欧美乱熟臀69xxxxxx| 26uuu国产日韩综合| 亚洲色图欧美偷拍| 蜜桃av一区二区| 91亚洲国产成人精品一区二区三| 欧美日韩国产精选| 欧美激情一区不卡| 亚洲成年人影院| 国产69精品久久99不卡| 欧美日韩精品免费| 中国av一区二区三区| 青娱乐精品在线视频| k8久久久一区二区三区| 91精品国产综合久久小美女| 国产精品久久久久国产精品日日| 婷婷夜色潮精品综合在线| 成人中文字幕电影| 日韩一区二区三区在线视频| 亚洲欧美一区二区三区孕妇| 加勒比av一区二区| 欧美日韩国产不卡| 中文字幕亚洲在| 黑人巨大精品欧美黑白配亚洲| 91官网在线免费观看| 国产欧美日韩一区二区三区在线观看 | 国产suv精品一区二区6| 在线播放91灌醉迷j高跟美女| 中文欧美字幕免费| 激情综合色播五月| 欧美日韩精品一区视频| 亚洲欧美精品午睡沙发| 国产乱理伦片在线观看夜一区| 777色狠狠一区二区三区| 亚洲人成在线播放网站岛国| 国产成人综合精品三级| 91精品蜜臀在线一区尤物| 一区二区三区不卡视频| 成人精品国产免费网站| 久久久天堂av| 国内精品免费在线观看| 91精品国产福利| 亚洲va欧美va人人爽| 91麻豆国产香蕉久久精品| 中文字幕不卡三区| 国产精品资源站在线| 日韩你懂的在线播放| 蜜臀91精品一区二区三区| 欧美老人xxxx18| 亚洲va中文字幕| 欧美怡红院视频| 亚洲亚洲精品在线观看| 日本电影欧美片| 亚洲欧洲av在线| jvid福利写真一区二区三区| 国产精品传媒视频| 成人免费视频免费观看| 国产亚洲成aⅴ人片在线观看 | 麻豆成人久久精品二区三区小说| 欧美精品在线观看播放| 五月天激情综合| 欧美浪妇xxxx高跟鞋交| 亚洲h精品动漫在线观看| 欧美日韩一区二区三区不卡| 亚洲国产成人高清精品| 欧美人牲a欧美精品| 欧美96一区二区免费视频| 欧美一区二区三区色| 另类人妖一区二区av| 精品国产在天天线2019| 国产成人午夜精品5599| 国产精品你懂的| 在线中文字幕不卡| 香蕉影视欧美成人| 日韩精品一区在线| 国产精品一区二区三区99| 国产日韩精品一区二区三区 | 26uuu亚洲综合色欧美| 国产主播一区二区| 国产欧美精品区一区二区三区 | 处破女av一区二区| 国产精品一区二区91| 国产精品麻豆欧美日韩ww| 99re6这里只有精品视频在线观看| 亚洲精品国久久99热| 欧美午夜精品电影| 另类人妖一区二区av| 亚洲国产成人私人影院tom| 97久久久精品综合88久久| 亚洲国产aⅴ天堂久久| 日韩你懂的在线播放| 成人激情小说网站| 亚洲国产aⅴ天堂久久| 精品国产1区2区3区| av在线一区二区三区| 日韩电影在线一区二区三区| 久久久久久久久久久久久久久99| 99热99精品| 日韩激情av在线| 中文字幕乱码日本亚洲一区二区| 在线观看亚洲一区| 精品亚洲国内自在自线福利| 日韩美女久久久| 日韩欧美你懂的| 一本高清dvd不卡在线观看| 日韩高清在线观看| 国产精品久久久久影院亚瑟 | 欧美日韩亚洲国产综合| 精品一区二区三区免费毛片爱 | 精品女同一区二区| 色综合一区二区| 久久www免费人成看片高清| 1区2区3区精品视频| 日韩一区二区精品| 色哟哟国产精品免费观看| 韩国精品主播一区二区在线观看 | 日本韩国欧美一区| 国产一区二区三区在线看麻豆| 一区二区三区产品免费精品久久75| 日韩免费在线观看| 欧美午夜电影在线播放| 成人污视频在线观看| 美女视频黄频大全不卡视频在线播放 | 成人永久免费视频| 奇米影视一区二区三区小说| 亚洲日本va在线观看|