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

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

?? cc1.c

?? MIPS系列CPU下的測試代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
    }
  }

/*
** parse next local or argument declaration
*/
decl(type, aid, id, sz) int type, aid, *id, *sz; {
  int n, p;
  if(match("(")) p = 1;
  else           p = 0;
  if(match("*"))        {*id = POINTER;  *sz  = BPW;}
  else                  {*id = VARIABLE; *sz  = type >> 2;}
  if((n = symname(ssname)) == 0) illname();
  if(p && match(")")) ;
  if(match("(")) {
    if(!p || *id != POINTER) error("try (*...)()");
    need(")");
    }
  else if(*id == VARIABLE && match("[")) {
    *id = aid;
    if((*sz *= needsub()) == 0) {
      if(aid == ARRAY) error("need array size");
      *sz  = BPW;      /* size of pointer argument */
      }
    }
  return n;
  }

/******************** start 2nd level parsing *******************/

/*
** statement parser
*/
statement() {
  if(ch == 0 && eof) return;
  else if(amatch("char",     4)) {declloc(CHR);    ns();}
  else if(amatch("int",      3)) {declloc(INT);    ns();}
  else if(amatch("unsigned", 8)) {
    if   (amatch("char",     4)) {declloc(UCHR);   ns();}
    else {amatch("int",      3);  declloc(UINT);   ns();}
    }
  else {
    if(declared >= 0) {
      if(ncmp > 1) nogo = declared;   /* disable goto */
      gen(ADDSP, csp - declared);
      declared = -1;
      }
    if(match("{"))                 compound();
    else if(amatch("if",       2)) {doif();           lastst = STIF;}
    else if(amatch("while",    5)) {dowhile();        lastst = STWHILE;}
    else if(amatch("do",       2)) {dodo();           lastst = STDO;}
    else if(amatch("for",      3)) {dofor();          lastst = STFOR;}
    else if(amatch("switch",   6)) {doswitch();       lastst = STSWITCH;}
    else if(amatch("case",     4)) {docase();         lastst = STCASE;}
    else if(amatch("default",  7)) {dodefault();      lastst = STDEF;}
    else if(amatch("goto",     4)) {dogoto();         lastst = STGOTO;}
    else if(dolabel())                                lastst = STLABEL;
    else if(amatch("return",   6)) {doreturn(); ns(); lastst = STRETURN;}
    else if(amatch("break",    5)) {dobreak();  ns(); lastst = STBREAK;}
    else if(amatch("continue", 8)) {docont();   ns(); lastst = STCONT;}
    else if(match(";"))            errflag = 0;
    else if(match("#asm"))         {doasm();          lastst = STASM;}
    else                           {doexpr(NO); ns(); lastst = STEXPR;}
    }
  return lastst;
  }

/*
** declare local variables
*/
declloc(type)  int type;  {
  int id, sz;
  if(swactive)     error("not allowed in switch");
  if(noloc)        error("not allowed with goto");
  if(declared < 0) error("must declare first in block");
  while(1) {
    if(endst()) return;
    decl(type, ARRAY, &id, &sz);
    declared += sz;
    addsym(ssname, id, type,  sz, csp - declared, &locptr, AUTOMATIC);
    if(match(",") == 0) return;
    }
  }

compound()  {
  int savcsp;
  char *savloc;
  savcsp = csp;
  savloc = locptr;
  declared = 0;           /* may now declare local variables */
  ++ncmp;                 /* new level open */
  while (match("}") == 0)
    if(eof) {
      error("no final }");
      break;
      }
    else statement();     /* do one */
  if(--ncmp               /* close current level */
  && lastst != STRETURN
  && lastst != STGOTO)
    gen(ADDSP, savcsp);   /* delete local variable space */
  cptr = savloc;          /* retain labels */
  while(cptr < locptr) {
    cptr2 = nextsym(cptr);
    if(cptr[IDENT] == LABEL) {
      while(cptr < cptr2) *savloc++ = *cptr++;
      }
    else cptr = cptr2;
    }
  locptr = savloc;        /* delete local symbols */
  declared = -1;          /* may not declare variables */
  }

doif()  {
  int flab1, flab2;
  test(flab1 = getlabel(), YES);  /* get expr, and branch false */
  statement();                    /* if true, do a statement */
  if(amatch("else", 4) == 0) {    /* if...else ? */
    /* simple "if"...print false label */
    gen(LABm, flab1);
    return;                       /* and exit */
    }
  flab2 = getlabel();
  if(lastst != STRETURN && lastst != STGOTO)
    gen(JMPm, flab2);
  gen(LABm, flab1);    /* print false label */
  statement();         /* and do "else" clause */
  gen(LABm, flab2);    /* print true label */
  }

dowhile()  {
  int wq[4];              /* allocate local queue */
  addwhile(wq);           /* add entry to queue for "break" */
  gen(LABm, wq[WQLOOP]);  /* loop label */
  test(wq[WQEXIT], YES);  /* see if true */
  statement();            /* if so, do a statement */
  gen(JMPm, wq[WQLOOP]);  /* loop to label */
  gen(LABm, wq[WQEXIT]);  /* exit label */
  delwhile();             /* delete queue entry */
  }

dodo() {
  int wq[4];
  addwhile(wq);
  gen(LABm, wq[WQLOOP]);
  statement();
  need("while");
  test(wq[WQEXIT], YES);
  gen(JMPm, wq[WQLOOP]);
  gen(LABm, wq[WQEXIT]);
  delwhile();
  ns();
  }

dofor() {
  int wq[4], lab1, lab2;
  addwhile(wq);
  lab1 = getlabel();
  lab2 = getlabel();
  need("(");
  if(match(";") == 0) {
    doexpr(NO);           /* expr 1 */
    ns();
    }
  gen(LABm, lab1);
  if(match(";") == 0) {
    test(wq[WQEXIT], NO); /* expr 2 */
    ns();
    }
  gen(JMPm, lab2);
  gen(LABm, wq[WQLOOP]);
  if(match(")") == 0) {
    doexpr(NO);           /* expr 3 */
    need(")");
    }
  gen(JMPm, lab1);
  gen(LABm, lab2);
  statement();
  gen(JMPm, wq[WQLOOP]);
  gen(LABm, wq[WQEXIT]);
  delwhile();
  }

doswitch() {
  int wq[4], endlab, swact, swdef, *swnex, *swptr;
  swact = swactive;
  swdef = swdefault;
  swnex = swptr = swnext;
  addwhile(wq);
  *(wqptr + WQLOOP - WQSIZ) = 0;
  need("(");
  doexpr(YES);                /* evaluate switch expression */
  need(")");
  swdefault = 0;
  swactive = 1;
  gen(JMPm, endlab = getlabel());
  statement();                /* cases, etc. */
  gen(JMPm, wq[WQEXIT]);
  gen(LABm, endlab);
  gen(SWITCH, 0);             /* match cases */
  while(swptr < swnext) {
    gen(NEARm, *swptr++);
    gen(WORDn,  *swptr++);    /* case value */
    }
  gen(WORDn, 0);
  if(swdefault) gen(JMPm, swdefault);
  gen(LABm, wq[WQEXIT]);
  delwhile();
  swnext    = swnex;
  swdefault = swdef;
  swactive  = swact;
  }

docase() {
  if(swactive == 0) error("not in switch");
  if(swnext > swend) {
    error("too many cases");
    return;
    }
  gen(LABm, *swnext++ = getlabel());
  constexpr(swnext++);
  need(":");
  }

dodefault() {
  if(swactive) {
    if(swdefault) error("multiple defaults");
    }
  else error("not in switch");
  need(":");
  gen(LABm, swdefault = getlabel());
  }

dogoto() {
  if(nogo > 0) error("not allowed with block-locals");
  else noloc = 1;
  if(symname(ssname)) gen(JMPm, addlabel(NO));
  else error("bad label");
  ns();
  }

dolabel() {
  char *savelptr;
  blanks();
  savelptr = lptr;
  if(symname(ssname)) {
    if(gch() == ':') {
      gen(LABm, addlabel(YES));
      return 1;
      }
    else bump(savelptr-lptr);
    }
  return 0;
  }

addlabel(def) int def; {
  if(cptr = findloc(ssname)) {
    if(cptr[IDENT] != LABEL) error("not a label");
    else if(def) {
      if(cptr[TYPE]) error("duplicate label");
      else cptr[TYPE] = YES;
      }
    }
  else cptr = addsym(ssname, LABEL, def, 0, getlabel(), &locptr, LABEL);
  return (getint(cptr+OFFSET, 2));
  }

doreturn()  {
  int savcsp;
  if(endst() == 0) doexpr(YES);
  savcsp = csp;
  gen(RETURN, 0);
  csp = savcsp;
  }

dobreak()  {
  int *ptr;
  if((ptr = readwhile(wqptr)) == 0) return;
  gen(ADDSP, ptr[WQSP]);
  gen(JMPm, ptr[WQEXIT]);
  }

docont()  {
  int *ptr;
  ptr = wqptr;
  while (1) {
    if((ptr = readwhile(ptr)) == 0) return;
    if(ptr[WQLOOP]) break;
    }
  gen(ADDSP, ptr[WQSP]);
  gen(JMPm, ptr[WQLOOP]);
  }

doasm()  {
  ccode = 0;           /* mark mode as "asm" */
  while (1) {
    inline();
    if(match("#endasm")) break;
    if(eof)break;
    fputs(line, output);
    }
  kill();
  ccode = 1;
  }

doexpr(use) int use; {
  int const, val;
  int *before, *start;
  usexpr = use;        /* tell isfree() whether expr value is used */
  while(1) {
    setstage(&before, &start);
    expression(&const, &val);
    clearstage(before, start);
    if(ch != ',') break;
    bump(1);
    }
  usexpr = YES;        /* return to normal value */
  }

/******************** miscellaneous functions *******************/

/*
** get run options
*/
ask() {
  int i;
  i = listfp = nxtlab = 0;
  output = stdout;
  optimize = YES;
  alarm = monitor = pause = NO;
  line = mline;
  while(getarg(++i, line, LINESIZE, argcs, argvs) != EOF) {
    if(line[0] != '-' && line[0] != '/') continue;
    if(toupper(line[1]) == 'L'
    && isdigit(line[2])
    && line[3] <= ' ') {
      listfp = line[2]-'0';
      continue;
      }
    if(toupper(line[1]) == 'N'
    && toupper(line[2]) == 'O'
    && line[3] <= ' ') {
      optimize = NO;
      continue;
      }
    if(line[2] <= ' ') {
      if(toupper(line[1]) == 'A') {alarm   = YES; continue;}
      if(toupper(line[1]) == 'M') {monitor = YES; continue;}
      if(toupper(line[1]) == 'P') {pause   = YES; continue;}
      }
    fputs("usage: cc [file]... [-m] [-a] [-p] [-l#] [-no]\n", stderr);
    abort(ERRCODE);
    }
  }

/*
** input and output file opens
*/
openfile() {        /* entire function revised */
  char outfn[15];
  int i, j, ext;
  input = EOF;
  while(getarg(++filearg, pline, LINESIZE, argcs, argvs) != EOF) {
    if(pline[0] == '-' || pline[0] == '/') continue;
    ext = NO;
    i = -1;
    j = 0;
    while(pline[++i]) {
      if(pline[i] == '.') {
        ext = YES;
        break;
        }
      if(j < 10) outfn[j++] = pline[i];
      }
    if(!ext) strcpy(pline + i, ".C");
    input = mustopen(pline, "r");
    if(!files && iscons(stdout)) {
      strcpy(outfn + j, ".ASM");
      output = mustopen(outfn, "w");
      }
    files = YES;
    kill();
    return;
    }
  if(files++) eof = YES;
  else input = stdin;
  kill();
  }

/*
** open a file with error checking
*/
mustopen(fn, mode) char *fn, *mode; {
  int fd;
  if(fd = fopen(fn, mode)) return fd;
  fputs("open error on ", stderr);
  lout(fn, stderr);
  abort(ERRCODE);
  }

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线视频中文字幕一区二区| 成人黄页毛片网站| 国产精品电影一区二区三区| 久久久精品影视| 久久一二三国产| 制服丝袜成人动漫| 欧美日韩精品系列| 欧美午夜一区二区| 欧美日韩国产精品成人| 欧美伊人久久久久久久久影院| 日本道色综合久久| 精品视频一区二区三区免费| 在线观看亚洲成人| 欧美精品xxxxbbbb| 欧美成人精品3d动漫h| 欧美不卡视频一区| 久久综合九色综合欧美亚洲| 国产日产欧美一区二区视频| 国产精品久久久久久久久动漫 | 一区二区三区中文字幕电影| 一区在线观看视频| 一区二区三区**美女毛片| 亚洲免费毛片网站| 亚洲成国产人片在线观看| 日本成人在线网站| 国产美女精品在线| www.在线欧美| 欧美午夜一区二区| 欧美变态tickle挠乳网站| 国产拍欧美日韩视频二区| 综合久久久久综合| 亚洲第一电影网| 国产精品18久久久久久vr| 99视频有精品| 在线播放91灌醉迷j高跟美女| 精品国产一区二区三区四区四 | 成人国产精品免费观看| 色噜噜狠狠一区二区三区果冻| 欧美日精品一区视频| 久久综合精品国产一区二区三区| 国产精品欧美久久久久无广告| 亚洲精品视频在线观看免费| 美女久久久精品| 99久久久国产精品| 日韩三级av在线播放| 中文字幕五月欧美| 蜜臀av一区二区| 色综合久久综合网97色综合| 欧美成人aa大片| 一区二区久久久久久| 精品一二线国产| 在线亚洲免费视频| 久久精品一区二区三区四区| 日本不卡免费在线视频| 成人h动漫精品一区二| 欧美一区二区女人| 亚洲欧美精品午睡沙发| 国产麻豆精品在线观看| 欧美一区二区视频在线观看2020| 亚洲欧美激情小说另类| 久久97超碰色| 欧美日韩一区二区三区不卡| 国产精品无人区| 久久国产成人午夜av影院| 色婷婷激情久久| 久久久精品国产免大香伊| 天天色天天爱天天射综合| 色偷偷88欧美精品久久久| 国产日本亚洲高清| 经典一区二区三区| 欧美一区二区三区在线电影| 亚洲成人动漫在线免费观看| av网站免费线看精品| 久久久精品国产免费观看同学| 狠狠色综合播放一区二区| 在线不卡的av| 亚洲高清免费观看高清完整版在线观看| 高清av一区二区| 亚洲国产精品99久久久久久久久 | 91无套直看片红桃| 欧美国产乱子伦| 成人国产电影网| 中文字幕在线一区二区三区| 成人免费毛片嘿嘿连载视频| 亚洲国产电影在线观看| 国产乱人伦偷精品视频不卡 | 亚洲一区中文日韩| 91亚洲精品一区二区乱码| 亚洲欧美怡红院| 91免费版在线| 亚洲综合自拍偷拍| 欧美调教femdomvk| 日韩激情在线观看| 精品国产乱码久久久久久免费| 久久国产欧美日韩精品| 精品粉嫩超白一线天av| 国产乱码精品一品二品| 中文字幕不卡在线播放| 成人三级伦理片| 欧美色区777第一页| 91免费看片在线观看| 国产精品五月天| 在线免费观看视频一区| 亚洲不卡一区二区三区| 色诱视频网站一区| 色激情天天射综合网| 奇米影视一区二区三区小说| 亚洲一区二区在线视频| 国产精品乱子久久久久| 久久嫩草精品久久久久| 精品久久久久久久久久久久包黑料 | 99精品久久只有精品| 久草精品在线观看| 亚洲第一电影网| 一卡二卡三卡日韩欧美| 亚洲日本va在线观看| 国产精品入口麻豆原神| 久久精品欧美日韩| 久久综合色8888| 26uuu成人网一区二区三区| 日韩免费一区二区三区在线播放| 这里只有精品免费| 欧美美女直播网站| 欧美麻豆精品久久久久久| 欧美色综合影院| 欧美亚洲精品一区| 欧美少妇一区二区| 91.com在线观看| 3d动漫精品啪啪一区二区竹菊| 8v天堂国产在线一区二区| 欧美一卡二卡三卡| 精品美女在线播放| 国产亚洲精久久久久久| 中文字幕av一区 二区| 国产精品久久久久一区| 亚洲天堂网中文字| 亚洲综合免费观看高清完整版在线| 一区二区在线观看av| 亚洲mv大片欧洲mv大片精品| 视频一区二区国产| 精品一区二区日韩| 成人91在线观看| 欧美日韩三级视频| 欧美一区二区福利在线| 久久久噜噜噜久久人人看| 中文字幕一区二区三中文字幕| 一区二区三区自拍| 日本视频在线一区| 国产中文字幕精品| av电影在线观看不卡| 欧美三级日韩在线| 久久色在线视频| 亚洲精品中文在线影院| 亚洲v精品v日韩v欧美v专区| 国产精品性做久久久久久| 99国产欧美另类久久久精品 | 日韩专区一卡二卡| 国产在线播精品第三| 91婷婷韩国欧美一区二区| 欧美日韩一二三区| 欧美经典一区二区三区| 亚洲午夜精品在线| 国产传媒日韩欧美成人| 欧美性三三影院| 久久久一区二区三区捆绑**| 夜夜亚洲天天久久| 国产成人免费网站| 欧美欧美午夜aⅴ在线观看| 国产喷白浆一区二区三区| 天天亚洲美女在线视频| 99久久er热在这里只有精品15 | 午夜电影网一区| 国产福利电影一区二区三区| 91精品国产福利在线观看| 国产精品久久久爽爽爽麻豆色哟哟| 日韩成人一区二区| 色偷偷久久一区二区三区| 久久综合九色综合97_久久久| 亚洲大片在线观看| 成+人+亚洲+综合天堂| 日韩美一区二区三区| 亚洲影院理伦片| 99久久久精品| 欧美国产一区二区| 狠狠色狠狠色综合系列| 欧美一区二区成人| 亚洲动漫第一页| 色婷婷综合久久久| 国产欧美一二三区| 精品一区二区三区久久久| 欧美久久一二三四区| 亚洲免费在线播放| 波波电影院一区二区三区| 国产视频不卡一区| 久久国产精品第一页| 91精品福利在线一区二区三区| 亚洲第一成人在线| 日本福利一区二区| 亚洲欧美激情小说另类| 99精品视频一区二区三区|