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

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

?? cc1.c

?? MIPS系列CPU下的測試代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*
** Small-C Compiler -- Part 1 --  Top End.
** Copyright 1982, 1983, 1985, 1988 J. E. Hendrix
** All rights reserved.
*/

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

/*
** miscellaneous storage
*/
int
  nogo,     /* disable goto statements? */
  noloc,    /* disable block locals? */
  opindex,  /* index to matched operator */
  opsize,   /* size of operator in characters */
  swactive, /* inside a switch? */
  swdefault,/* default label #, else 0 */
 *swnext,   /* address of next entry */
 *swend,    /* address of last entry */
 *stage,    /* staging buffer address */
 *wq,       /* while queue */
  argcs,    /* static argc */
 *argvs,    /* static argv */
 *wqptr,    /* ptr to next entry */
  litptr,   /* ptr to next entry */
  macptr,   /* macro buffer index */
  pptr,     /* ptr to parsing buffer */
  ch,       /* current character of input line */
  nch,      /* next character of input line */
  declared, /* # of local bytes to declare, -1 when declared */
  iflevel,  /* #if... nest level */
  skiplevel,/* level at which #if... skipping started */
  nxtlab,   /* next avail label # */
  litlab,   /* label # assigned to literal pool */
  csp,      /* compiler relative stk ptr */
  argstk,   /* function arg sp */
  argtop,   /* highest formal argument offset */
  ncmp,     /* # open compound statements */
  errflag,  /* true after 1st error in statement */
  eof,      /* true on final input eof */
  output,   /* fd for output file */
  files,    /* true if file list specified on cmd line */
  filearg,  /* cur file arg index */
  input   = EOF, /* fd for input file */
  input2  = EOF, /* fd for "#include" file */
  usexpr  = YES, /* true if value of expression is used */
  ccode   = YES, /* true while parsing C code */
 *snext,    /* next addr in stage */
 *stail,    /* last addr of data in stage */
 *slast,    /* last addr in stage */
  listfp,   /* file pointer to list device */
  lastst,   /* last parsed statement type */
  oldseg;   /* current segment (0, DATASEG, CODESEG) */

char
  optimize, /* optimize output of staging buffer? */
  alarm,    /* audible alarm on errors? */
  monitor,  /* monitor function headers? */
  pause,    /* pause for operator on errors? */
 *symtab,   /* symbol table */
 *litq,     /* literal pool */
 *macn,     /* macro name buffer */
 *macq,     /* macro string buffer */
 *pline,    /* parsing buffer */
 *mline,    /* macro buffer */
 *line,     /* ptr to pline or mline */
 *lptr,     /* ptr to current character in "line" */
 *glbptr,   /* global symbol table */
 *locptr,   /* next local symbol table entry */
  quote[2] = {'"'}, /* literal string for '"' */
 *cptr,     /* work ptrs to any char buffer */
 *cptr2,
 *cptr3,
  msname[NAMESIZE],   /* macro symbol name */
  ssname[NAMESIZE];   /* static symbol name */

int op[16] = {   /* p-codes of signed binary operators */
  OR12,                        /* level5 */
  XOR12,                       /* level6 */
  AND12,                       /* level7 */
  EQ12,   NE12,                /* level8 */
  LE12,   GE12,  LT12,  GT12,  /* level9 */
  ASR12,  ASL12,               /* level10 */
  ADD12,  SUB12,               /* level11 */
  MUL12, DIV12, MOD12          /* level12 */
  };

int op2[16] = {  /* p-codes of unsigned binary operators */
  OR12,                        /* level5 */
  XOR12,                       /* level6 */
  AND12,                       /* level7 */
  EQ12,   NE12,                /* level8 */
  LE12u,  GE12u, LT12u, GT12u, /* level9 */
  ASR12,  ASL12,               /* level10 */
  ADD12,  SUB12,               /* level11 */
  MUL12u, DIV12u, MOD12u       /* level12 */
  };

/*
** execution begins here
*/
main(argc, argv) int argc, *argv; {
  fputs(VERSION, stderr);
  fputs(CRIGHT1, stderr);
  argcs   = argc;
  argvs   = argv;
  swnext  = calloc(SWTABSZ, 1);
  swend   = swnext+(SWTABSZ-SWSIZ);
  stage   = calloc(STAGESIZE, 2*BPW);
  wqptr   =
  wq      = calloc(WQTABSZ, BPW);
  litq    = calloc(LITABSZ, 1);
  macn    = calloc(MACNSIZE, 1);
  macq    = calloc(MACQSIZE, 1);
  pline   = calloc(LINESIZE, 1);
  mline   = calloc(LINESIZE, 1);
  slast   = stage+(STAGESIZE*2*BPW);
  symtab  = calloc((NUMLOCS*SYMAVG + NUMGLBS*SYMMAX), 1);
  locptr  = STARTLOC;
  glbptr  = STARTGLB;
  
  ask();          /* get user options */
  openfile();     /* and initial input file */
  preprocess();   /* fetch first line */
  header();       /* intro code */
  setcodes();     /* initialize code pointer array */ 
  parse();        /* process ALL input */
  trailer();      /* follow-up code */
  fclose(output); /* explicitly close output */
  }

/******************** high level parsing *******************/

/*
** process all input text
**
** At this level, only static declarations,
**      defines, includes and function
**      definitions are legal...
*/
parse() {
  while (eof == 0) {
    if     (amatch("extern", 6)) dodeclare(EXTERNAL);
    else if(dodeclare(STATIC))   ;
    else if( match("#asm"))      doasm();
    else if( match("#include"))  doinclude();
    else if( match("#define"))   dodefine();
    else                         dofunction();
    blanks();                 /* force eof if pending */
    }
  }

/*
** test for global declarations
*/
dodeclare(class) int class; {
  if     (amatch("char",     4))  declglb(CHR,  class);
  else if(amatch("unsigned", 8)) {
    if   (amatch("char",     4))  declglb(UCHR, class);
    else {amatch("int",      3);  declglb(UINT, class);}
    }
  else if(amatch("int",      3)
       || class == EXTERNAL)      declglb(INT,  class);
  else return 0;
  ns();
  return 1;
  }

/*
** declare a static variable
*/
declglb(type, class)  int type, class; {
  int id, dim;
  while(1) {
    if(endst()) return;  /* do line */
    if(match("*"))       {id = POINTER;  dim = 0;}
    else                 {id = VARIABLE; dim = 1;}
    if(symname(ssname) == 0) illname();
    if(findglb(ssname)) multidef(ssname);
    if(id == VARIABLE) {
      if     (match("("))  {id = FUNCTION; need(")");}
      else if(match("["))  {id = ARRAY; dim = needsub();}
      }
    if     (class == EXTERNAL) external(ssname, type >> 2, id);
    else if(   id != FUNCTION) initials(type >> 2, id, dim);
    if(id == POINTER) 
         addsym(ssname, id, type, BPW, 0, &glbptr, class);
    else addsym(ssname, id, type, dim * (type >> 2), 0, &glbptr, class);
    if(match(",") == 0) return;
    }
  }

/*
** initialize global objects
*/
initials(size, ident, dim) int size, ident, dim; {
  int savedim;
  litptr = 0;
  if(dim == 0) dim = -1;         /* *... or ...[] */
  savedim = dim;
  public(ident);
  if(match("=")) {
    if(match("{")) {
      while(dim) {
        init(size, ident, &dim);
        if(match(",") == 0) break;
        }
      need("}");
      }
    else init(size, ident, &dim);
    }
  if(savedim == -1 && dim == -1) {
    if(ident == ARRAY) error("need array size");
    stowlit(0, size = BPW);
    }
  dumplits(size);
  dumpzero(size, dim);           /* only if dim > 0 */
  }

/*
** evaluate one initializer
*/
init(size, ident, dim) int size, ident, *dim; {
  int value;
  if(string(&value)) {
    if(ident == VARIABLE || size != 1)
      error("must assign to char pointer or char array");
    *dim -= (litptr - value);
    if(ident == POINTER) point();
    }
  else if(constexpr(&value)) {
    if(ident == POINTER) error("cannot assign to pointer");
    stowlit(value, size);
    *dim -= 1;
    }
  }

/*
** get required array size
*/
needsub()  {
  int val;
  if(match("]")) return 0; /* null size */
  if(constexpr(&val) == 0) val = 1;
  if(val < 0) {
    error("negative size illegal");
    val = -val;
    }
  need("]");               /* force single dimension */
  return val;              /* and return size */
  }

/*
** open an include file
*/
doinclude() {
  int i; char str[30];
  blanks();       /* skip over to name */
  if(*lptr == '"' || *lptr == '<') ++lptr;
  i = 0;
  while(lptr[i]
     && lptr[i] != '"'
     && lptr[i] != '>'
     && lptr[i] != '\n') {
    str[i] = lptr[i];
    ++i;
    }
  str[i] = NULL;
  if((input2 = fopen(str,"r")) == NULL) {
    input2 = EOF;
    error("open failure on include file");
    }
  kill();   /* make next read come from new file (if open) */
  }

/*
** define a macro symbol
*/
dodefine() {
  int k;
  if(symname(msname) == 0) {
    illname();
    kill();
    return;
    }
  k = 0;
  if(search(msname, macn, NAMESIZE+2, MACNEND, MACNBR, 0) == 0) {
    if(cptr2 = cptr)
      while(*cptr2++ = msname[k++]) ;
    else {
      error("macro name table full");
      return;
      }
    }
  putint(macptr, cptr+NAMESIZE, 2);
  while(white()) gch();
  while(putmac(gch()));
  if(macptr >= MACMAX) {
    error("macro string queue full");
    abort(ERRCODE);
    }
  }

putmac(c)  char c; {
  macq[macptr] = c;
  if(macptr < MACMAX) ++macptr;
  return c;
  }

/*
** begin a function
**
** called from "parse" and tries to make a function
** out of the following text
*/
dofunction()  {
  char *ptr;
  nogo   =                      /* enable goto statements */
  noloc  =                      /* enable block-local declarations */
  lastst =                      /* no statement yet */
  litptr = 0;                   /* clear lit pool */
  litlab = getlabel();          /* label next lit pool */
  locptr = STARTLOC;            /* clear local variables */
  if(match("void")) blanks();   /* skip "void" & locate header */
  if(monitor) lout(line, stderr);
  if(symname(ssname) == 0) {
    error("illegal function or declaration");
    errflag = 0;
    kill();                     /* invalidate line */
    return;
    }
  if(ptr = findglb(ssname)) {   /* already in symbol table? */
    if(ptr[CLASS] == AUTOEXT)
         ptr[CLASS] = STATIC;
    else multidef(ssname);
    }
  else addsym(ssname, FUNCTION, INT, 0, 0, &glbptr, STATIC);
  public(FUNCTION);
  argstk = 0;                  /* init arg count */
  if(match("(") == 0) error("no open paren");
  while(match(")") == 0) {     /* then count args */
    if(symname(ssname)) {
      if(findloc(ssname)) multidef(ssname);
      else {
        addsym(ssname, 0, 0, 0, argstk, &locptr, AUTOMATIC);
        argstk += BPW;
        }
      }
    else {
      error("illegal argument name");
      skip();
      }
    blanks();
    if(streq(lptr,")") == 0 && match(",") == 0)
      error("no comma");
    if(endst()) break;
    }
  csp = 0;                     /* preset stack ptr */
  argtop = argstk+BPW;         /* account for the pushed BP */
  while(argstk) {
    if     (amatch("char",     4)) {doargs(CHR);  ns();}
    else if(amatch("int",      3)) {doargs(INT);  ns();}
    else if(amatch("unsigned", 8)) {
      if   (amatch("char", 4))     {doargs(UCHR); ns();}
      else {amatch("int", 3);       doargs(UINT); ns();}
      }
    else {error("wrong number of arguments"); break;}
    }
  gen(ENTER, 0);
  statement();
  if(lastst != STRETURN && lastst != STGOTO)
    gen(RETURN, 0);
  if(litptr) {
    toseg(DATASEG);
    gen(REFm, litlab);
    dumplits(1);               /* dump literals */
    }
  }

/*
** declare argument types
*/
doargs(type) int type; {
  int id, sz;
  char c, *ptr;
  while(1) {
    if(argstk == 0) return;           /* no arguments */
    if(decl(type, POINTER, &id, &sz)) {
      if(ptr = findloc(ssname)) {
        ptr[IDENT] = id;
        ptr[TYPE]  = type;
        putint(sz, ptr+SIZE, 2);
        putint(argtop-getint(ptr+OFFSET, 2), ptr+OFFSET, 2);
        }
      else error("not an argument");
      }
    argstk = argstk - BPW;            /* cnt down */
    if(endst()) return;
    if(match(",") == 0) error("no comma");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av毛片久久久久**hd| 国产精品一区二区不卡| 99精品在线观看视频| 久久久蜜桃精品| 韩国女主播一区| 欧美精品一区二区三| 精品影视av免费| 欧美mv日韩mv| 国产在线一区观看| 国产网站一区二区| 国产很黄免费观看久久| 国产日韩影视精品| 国产91丝袜在线18| 中文字幕va一区二区三区| 国产精品一二三四| 国产日产欧美一区二区三区| 国产精品小仙女| 欧美韩国日本一区| aaa亚洲精品| 亚洲女人小视频在线观看| 色激情天天射综合网| 亚洲高清视频在线| 欧美日韩久久一区| 另类小说综合欧美亚洲| 2024国产精品视频| 成人性生交大片免费看中文 | 欧美主播一区二区三区美女| 夜夜精品浪潮av一区二区三区| 在线看日本不卡| 同产精品九九九| 精品国产人成亚洲区| 欧美日本在线一区| 日韩码欧中文字| 色视频成人在线观看免| 性久久久久久久| 欧美一卡2卡三卡4卡5免费| 久久99精品网久久| 久久精品亚洲一区二区三区浴池| eeuss鲁片一区二区三区在线看 | 精品国产乱码久久久久久久| 国产一区福利在线| 国产精品系列在线| 色婷婷精品大在线视频| 日韩—二三区免费观看av| 精品国产一区二区三区av性色| 国产91精品久久久久久久网曝门| 国产精品久久国产精麻豆99网站| 在线一区二区三区四区| 三级一区在线视频先锋| 久久夜色精品国产噜噜av| 99久久伊人网影院| 五月天激情综合| 久久精品免费在线观看| 色播五月激情综合网| 麻豆久久久久久| 中文字幕制服丝袜成人av| 欧美日韩不卡在线| 国产成人精品三级麻豆| 一区二区日韩av| 欧美影院午夜播放| 韩国女主播一区二区三区| 亚洲男人的天堂一区二区| 欧美一区二区三区在线观看视频| 国产成人免费在线观看不卡| 亚洲综合精品久久| 精品少妇一区二区三区视频免付费| www.欧美.com| 麻豆国产精品视频| 亚洲天天做日日做天天谢日日欢| 日韩午夜三级在线| 99这里都是精品| 青青青伊人色综合久久| 亚洲国产精品精华液ab| 制服丝袜中文字幕亚洲| voyeur盗摄精品| 蜜臀久久99精品久久久画质超高清| 国产精品福利一区| 精品国产污网站| 欧美三区在线视频| 成人不卡免费av| 久久国产人妖系列| 亚洲午夜久久久| 欧美高清在线精品一区| 制服丝袜日韩国产| 色视频一区二区| 国产xxx精品视频大全| 日韩主播视频在线| 亚洲蜜臀av乱码久久精品| 久久综合国产精品| 在线播放视频一区| 一本色道久久综合狠狠躁的推荐| 精品一区二区三区免费播放| 亚洲夂夂婷婷色拍ww47| 中国色在线观看另类| 精品国产一区a| 777亚洲妇女| 在线视频一区二区免费| av午夜精品一区二区三区| 国产一区二区免费在线| 奇米影视一区二区三区| 一级日本不卡的影视| 国产精品不卡一区| 国产欧美精品一区二区色综合朱莉 | 免费一级片91| 日韩三级视频在线看| 欧美中文字幕一区| av一区二区三区在线| 国产精品69毛片高清亚洲| 免费成人在线网站| 亚洲6080在线| 亚洲综合偷拍欧美一区色| 亚洲欧洲精品一区二区三区 | 久久色.com| 91麻豆精品国产自产在线观看一区 | 91丨九色丨黑人外教| 国产电影一区二区三区| 狠狠狠色丁香婷婷综合激情| 麻豆视频一区二区| 免费亚洲电影在线| 男人的天堂亚洲一区| 午夜精品影院在线观看| 亚洲成人你懂的| 亚洲成人手机在线| 午夜国产精品影院在线观看| 亚洲与欧洲av电影| 亚洲午夜私人影院| 亚洲综合色视频| 亚洲国产精品久久人人爱| 亚洲自拍都市欧美小说| 亚洲一二三区在线观看| 亚洲一区二区三区爽爽爽爽爽| 一区二区在线看| 一级女性全黄久久生活片免费| 亚洲综合色网站| 亚洲成人免费看| 日韩av成人高清| 久久99精品国产麻豆不卡| 毛片不卡一区二区| 激情六月婷婷久久| 国产麻豆91精品| 福利视频网站一区二区三区| 成人午夜av在线| 99re热这里只有精品免费视频| 91捆绑美女网站| 欧美三级资源在线| 欧美一区二区性放荡片| 欧美成人官网二区| 久久久精品国产99久久精品芒果| 国产三区在线成人av| 国产精品美日韩| 亚洲激情欧美激情| 日韩激情一二三区| 激情五月婷婷综合网| 成人性视频网站| 色综合久久六月婷婷中文字幕| 91豆麻精品91久久久久久| 欧美理论电影在线| 欧美变态tickling挠脚心| 国产亚洲精品超碰| 国产精品初高中害羞小美女文| 亚洲精品国产无天堂网2021| 亚洲福中文字幕伊人影院| 男女男精品视频| 极品少妇一区二区三区精品视频 | 日韩精品欧美精品| 激情综合五月天| 成人国产精品视频| 欧美制服丝袜第一页| 欧美一区二区免费视频| 久久久久高清精品| 中文字幕一区二区三区不卡| 亚洲自拍另类综合| 激情综合五月天| 91亚洲精品一区二区乱码| 欧美日韩极品在线观看一区| 久久综合av免费| 亚洲啪啪综合av一区二区三区| 亚洲成a人片在线不卡一二三区 | 色综合久久久久综合| 3751色影院一区二区三区| 国产日韩欧美一区二区三区综合| 亚洲素人一区二区| 蜜桃视频在线观看一区| 99在线视频精品| 91精品欧美久久久久久动漫| 国产欧美日韩精品在线| 亚洲不卡av一区二区三区| 国产成人av电影在线播放| 欧美无乱码久久久免费午夜一区| 精品处破学生在线二十三| 亚洲麻豆国产自偷在线| 久久99国产精品免费| 色嗨嗨av一区二区三区| 久久久久久久网| 亚洲一区二区3| 粉嫩久久99精品久久久久久夜| 337p亚洲精品色噜噜| 亚洲婷婷国产精品电影人久久| 精品亚洲国内自在自线福利| 欧美综合一区二区|