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

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

?? tm.c

?? 一個小型C語言編譯器
?? C
?? 第 1 頁 / 共 2 頁
字號:
/****************************************************/
/* File: tm.c                                       */
/* The TM ("Tiny Machine") computer                 */
/* Compiler Construction: Principles and Practice   */
/* Kenneth C. Louden                                */
/****************************************************/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>

#ifndef TRUE
#define TRUE 1
#endif
#ifndef FALSE
#define FALSE 0
#endif

/******* const *******/
#define   IADDR_SIZE  1024 /* increase for large programs */
#define   DADDR_SIZE  1024 /* increase for large programs */
#define   NO_REGS 8
#define   PC_REG  7

#define   LINESIZE  121
#define   WORDSIZE  20

/******* type  *******/

typedef enum {
   opclRR,     /* reg operands r,s,t */
   opclRM,     /* reg r, mem d+s */
   opclRA      /* reg r, int d+s */
   } OPCLASS;

typedef enum {
   /* RR instructions */
   opHALT,    /* RR     halt, operands are ignored */
   opIN,      /* RR     read into reg(r); s and t are ignored */
   opOUT,     /* RR     write from reg(r), s and t are ignored */
   opADD,    /* RR     reg(r) = reg(s)+reg(t) */
   opSUB,    /* RR     reg(r) = reg(s)-reg(t) */
   opMUL,    /* RR     reg(r) = reg(s)*reg(t) */
   opDIV,    /* RR     reg(r) = reg(s)/reg(t) */
   opRRLim,   /* limit of RR opcodes */

   /* RM instructions */
   opLD,      /* RM     reg(r) = mem(d+reg(s)) */
   opST,      /* RM     mem(d+reg(s)) = reg(r) */
   opRMLim,   /* Limit of RM opcodes */

   /* RA instructions */
   opLDA,     /* RA     reg(r) = d+reg(s) */
   opLDC,     /* RA     reg(r) = d ; reg(s) is ignored */
   opJLT,     /* RA     if reg(r)<0 then reg(7) = d+reg(s) */
   opJLE,     /* RA     if reg(r)<=0 then reg(7) = d+reg(s) */
   opJGT,     /* RA     if reg(r)>0 then reg(7) = d+reg(s) */
   opJGE,     /* RA     if reg(r)>=0 then reg(7) = d+reg(s) */
   opJEQ,     /* RA     if reg(r)==0 then reg(7) = d+reg(s) */
   opJNE,     /* RA     if reg(r)!=0 then reg(7) = d+reg(s) */
   opRALim    /* Limit of RA opcodes */
   } OPCODE;

typedef enum {
   srOKAY,
   srHALT,
   srIMEM_ERR,
   srDMEM_ERR,
   srZERODIVIDE
   } STEPRESULT;

typedef struct {
      int iop  ;
      int iarg1  ;
      int iarg2  ;
      int iarg3  ;
   } INSTRUCTION;

/******** vars ********/
int iloc = 0 ;
int dloc = 0 ;
int traceflag = FALSE;
int icountflag = FALSE;

INSTRUCTION iMem [IADDR_SIZE];
int dMem [DADDR_SIZE];
int reg [NO_REGS];

char * opCodeTab[]
        = {"HALT","IN","OUT","ADD","SUB","MUL","DIV","????",
            /* RR opcodes */
           "LD","ST","????", /* RM opcodes */
           "LDA","LDC","JLT","JLE","JGT","JGE","JEQ","JNE","????"
           /* RA opcodes */
          };

char * stepResultTab[]
        = {"OK","Halted","Instruction Memory Fault",
           "Data Memory Fault","Division by 0"
          };

char pgmName[20];
FILE *pgm  ;

char in_Line[LINESIZE] ;
int lineLen ;
int inCol  ;
int num  ;
char word[WORDSIZE] ;
char ch  ;
int done  ;

/********************************************/
int opClass( int c )
{ if      ( c <= opRRLim) return ( opclRR );
  else if ( c <= opRMLim) return ( opclRM );
  else                    return ( opclRA );
} /* opClass */

/********************************************/
void writeInstruction ( int loc )
{ printf( "%5d: ", loc) ;
  if ( (loc >= 0) && (loc < IADDR_SIZE) )
  { printf("%6s%3d,", opCodeTab[iMem[loc].iop], iMem[loc].iarg1);
    switch ( opClass(iMem[loc].iop) )
    { case opclRR: printf("%1d,%1d", iMem[loc].iarg2, iMem[loc].iarg3);
                   break;
      case opclRM:
      case opclRA: printf("%3d(%1d)", iMem[loc].iarg2, iMem[loc].iarg3);
                   break;
    }
    printf ("\n") ;
  }
} /* writeInstruction */

/********************************************/
void getCh (void)
{ if (++inCol < lineLen)
  ch = in_Line[inCol] ;
  else ch = ' ' ;
} /* getCh */

/********************************************/
int nonBlank (void)
{ while ((inCol < lineLen)
         && (in_Line[inCol] == ' ') )
    inCol++ ;
  if (inCol < lineLen)
  { ch = in_Line[inCol] ;
    return TRUE ; }
  else
  { ch = ' ' ;
    return FALSE ; }
} /* nonBlank */

/********************************************/
int getNum (void)
{ int sign;
  int term;
  int temp = FALSE;
  num = 0 ;
  do
  { sign = 1;
    while ( nonBlank() && ((ch == '+') || (ch == '-')) )
    { temp = FALSE ;
      if (ch == '-')  sign = - sign ;
      getCh();
    }
    term = 0 ;
    nonBlank();
    while (isdigit(ch))
    { temp = TRUE ;
      term = term * 10 + ( ch - '0' ) ;
      getCh();
    }
    num = num + (term * sign) ;
  } while ( (nonBlank()) && ((ch == '+') || (ch == '-')) ) ;
  return temp;
} /* getNum */

/********************************************/
int getWord (void)
{ int temp = FALSE;
  int length = 0;
  if (nonBlank ())
  { while (isalnum(ch))
    { if (length < WORDSIZE-1) word [length++] =  ch ;
      getCh() ;
    }
    word[length] = '\0';
    temp = (length != 0);
  }
  return temp;
} /* getWord */

/********************************************/
int skipCh ( char c  )
{ int temp = FALSE;
  if ( nonBlank() && (ch == c) )
  { getCh();
    temp = TRUE;
  }
  return temp;
} /* skipCh */

/********************************************/
int atEOL(void)
{ return ( ! nonBlank ());
} /* atEOL */

/********************************************/
int error( char * msg, int lineNo, int instNo)
{ printf("Line %d",lineNo);
  if (instNo >= 0) printf(" (Instruction %d)",instNo);
  printf("   %s\n",msg);
  return FALSE;
} /* error */

/********************************************/
int readInstructions (void)
{ OPCODE op;
  int arg1, arg2, arg3;
  int loc, regNo, lineNo;
  for (regNo = 0 ; regNo < NO_REGS ; regNo++)
      reg[regNo] = 0 ;
  dMem[0] = DADDR_SIZE - 1 ;
  for (loc = 1 ; loc < DADDR_SIZE ; loc++)
      dMem[loc] = 0 ;
  for (loc = 0 ; loc < IADDR_SIZE ; loc++)
  { iMem[loc].iop = opHALT ;
    iMem[loc].iarg1 = 0 ;
    iMem[loc].iarg2 = 0 ;
    iMem[loc].iarg3 = 0 ;
  }
  lineNo = 0 ;
  while (! feof(pgm))
  { fgets( in_Line, LINESIZE-2, pgm  ) ;
    inCol = 0 ; 
    lineNo++;
    lineLen = strlen(in_Line)-1 ;
    if (in_Line[lineLen]=='\n') in_Line[lineLen] = '\0' ;
    else in_Line[++lineLen] = '\0';
    if ( (nonBlank()) && (in_Line[inCol] != '*') )
    { if (! getNum())
        return error("Bad location", lineNo,-1);
      loc = num;
      if (loc > IADDR_SIZE)
        return error("Location too large",lineNo,loc);
      if (! skipCh(':'))
        return error("Missing colon", lineNo,loc);
      if (! getWord ())
        return error("Missing opcode", lineNo,loc);
      op = opHALT ;
      while ((op < opRALim)
             && (strncmp(opCodeTab[op], word, 4) != 0) )
          op++ ;
      if (strncmp(opCodeTab[op], word, 4) != 0)
          return error("Illegal opcode", lineNo,loc);
      switch ( opClass(op) )
      { case opclRR :
        /***********************************/
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad first register", lineNo,loc);
        arg1 = num;
        if ( ! skipCh(','))
            return error("Missing comma", lineNo, loc);
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad second register", lineNo, loc);
        arg2 = num;
        if ( ! skipCh(',')) 
            return error("Missing comma", lineNo,loc);
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad third register", lineNo,loc);
        arg3 = num;
        break;

        case opclRM :
        case opclRA :
        /***********************************/
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad first register", lineNo,loc);
        arg1 = num;
        if ( ! skipCh(','))
            return error("Missing comma", lineNo,loc);
        if (! getNum ())
            return error("Bad displacement", lineNo,loc);
        arg2 = num;
        if ( ! skipCh('(') && ! skipCh(',') )
            return error("Missing LParen", lineNo,loc);
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS))
            return error("Bad second register", lineNo,loc);
        arg3 = num;
        break;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产aⅴ精品一区二区三区色成熟| 一区二区三区在线免费视频| 日韩av网站在线观看| 在线成人午夜影院| 五月天激情综合| 日韩一区二区三区精品视频| 久久精品国产在热久久| 精品久久久久一区| 丰满亚洲少妇av| 亚洲精品国产一区二区精华液| 色综合久久久网| 五月天视频一区| 精品国产乱码久久久久久闺蜜| 国产一区欧美日韩| 国产精品美女久久久久久久久久久| www.亚洲在线| 石原莉奈一区二区三区在线观看| 日韩视频123| 成人在线视频首页| 亚洲成人av免费| 2017欧美狠狠色| 色88888久久久久久影院按摩 | 久久av资源网| 久久久99久久精品欧美| 99re这里都是精品| 肉肉av福利一精品导航| 久久久精品2019中文字幕之3| 成人免费不卡视频| 午夜久久久久久久久久一区二区| 日韩欧美精品在线视频| 99视频一区二区| 美国十次综合导航| 国产精品久久久久aaaa| 7777精品伊人久久久大香线蕉经典版下载 | 国产视频911| 欧洲色大大久久| 久久国产精品无码网站| 成人欧美一区二区三区视频网页| 欧美午夜理伦三级在线观看| 国产乱码字幕精品高清av | 色综合中文字幕国产| 日韩黄色小视频| 欧美国产一区二区在线观看| 欧美日韩一二三| 成人国产精品免费| 久久精品国产色蜜蜜麻豆| 亚洲欧美日韩国产成人精品影院| 欧美成人精品3d动漫h| 色婷婷久久久亚洲一区二区三区 | 91麻豆国产自产在线观看| 蜜乳av一区二区| 亚洲曰韩产成在线| 国产欧美一区二区精品秋霞影院| 3atv一区二区三区| 欧洲国内综合视频| 波多野结衣中文字幕一区二区三区 | 丝袜美腿亚洲色图| 综合久久一区二区三区| 久久精品人人爽人人爽| 日韩一区二区在线观看视频 | 国产福利精品一区| 看片的网站亚洲| 日本欧美一区二区| 天天做天天摸天天爽国产一区 | 99久久国产综合精品女不卡| 国产乱子伦视频一区二区三区 | 欧美人xxxx| 在线免费观看日韩欧美| av成人免费在线| 成人黄动漫网站免费app| 国产一区二区精品久久| 韩国女主播一区| 经典三级在线一区| 国产在线播放一区三区四| 九色综合国产一区二区三区| 久久er99精品| 国产毛片精品一区| 国产精品1区2区3区在线观看| 国产尤物一区二区| 国产麻豆精品视频| 成人网男人的天堂| www.亚洲色图| 91久久久免费一区二区| 91成人在线精品| 欧美日韩中文字幕一区二区| 欧美伊人久久久久久久久影院 | 欧美日韩一级二级| 91精品在线麻豆| 日韩三级视频在线看| 欧美α欧美αv大片| 久久综合九色综合欧美亚洲| 2019国产精品| 国产精品九色蝌蚪自拍| 亚洲男人的天堂在线观看| 一区二区三区中文字幕电影| 亚洲1区2区3区4区| 美国毛片一区二区三区| 国产精品自产自拍| 99精品视频在线播放观看| 91国产福利在线| 日韩一区二区在线看片| 久久久久99精品国产片| 亚洲日本成人在线观看| 香蕉av福利精品导航| 九九**精品视频免费播放| 国产成人精品免费一区二区| 99久久亚洲一区二区三区青草 | 成人97人人超碰人人99| 日本高清不卡一区| 日韩欧美国产午夜精品| 中文av一区二区| 水蜜桃久久夜色精品一区的特点 | 欧美日韩免费电影| 精品三级在线观看| 亚洲人成亚洲人成在线观看图片| 亚洲成人av一区| 国产一区二区伦理| 欧美吞精做爰啪啪高潮| 久久久另类综合| 亚洲在线一区二区三区| 国产精品2024| 欧美蜜桃一区二区三区| 久久久国产精华| 亚洲国产精品一区二区久久| 国产精品一色哟哟哟| 欧美主播一区二区三区美女| 精品日韩成人av| 亚洲激情在线播放| 国产成人精品亚洲日本在线桃色 | 自拍偷在线精品自拍偷无码专区| 午夜婷婷国产麻豆精品| 成人性色生活片| 欧美一区二区三区啪啪| 亚洲日本一区二区三区| 国产精品影视天天线| 91精品国产综合久久小美女| 亚洲精品乱码久久久久久黑人| 国内精品国产三级国产a久久| 精品视频一区三区九区| 一区二区中文视频| 国产一区二区网址| 精品污污网站免费看| 国产精品超碰97尤物18| 国产自产2019最新不卡| 欧美日韩电影在线| 一区二区欧美在线观看| 成人亚洲一区二区一| 精品福利一二区| 日韩专区中文字幕一区二区| 99这里都是精品| 国产日本亚洲高清| 狠狠色丁香久久婷婷综合丁香| 91.麻豆视频| 亚洲午夜免费电影| 在线精品视频一区二区三四| 国产精品福利一区| 成人动漫在线一区| 国产欧美视频在线观看| 国产一区二区不卡老阿姨| 日韩午夜av一区| 美女在线视频一区| 91精品国产乱| 日韩—二三区免费观看av| 欧美日本一区二区三区四区| 亚洲一区二区精品久久av| 在线日韩一区二区| 亚洲国产成人porn| 欧美三日本三级三级在线播放| 亚洲综合色丁香婷婷六月图片| 色婷婷精品大在线视频| 亚洲午夜免费视频| 欧美日韩免费电影| 日韩高清不卡一区二区三区| 欧美一级国产精品| 久久99精品久久久久久动态图| 日韩欧美你懂的| 国产精品18久久久久久久久久久久 | 日本成人在线网站| 日韩视频123| 国产一区二区视频在线| 国产精品热久久久久夜色精品三区 | 欧美极品少妇xxxxⅹ高跟鞋 | 欧美成人a∨高清免费观看| 久久精品999| 久久精品视频在线看| a亚洲天堂av| 一区二区三区精品在线| 欧美日韩中文字幕精品| 美女脱光内衣内裤视频久久网站| 精品1区2区在线观看| 国产成人久久精品77777最新版本| 国产精品精品国产色婷婷| 欧美综合色免费| 另类人妖一区二区av| 欧美国产日产图区| 欧洲一区二区三区免费视频| 裸体歌舞表演一区二区| 国产欧美一区二区精品性色| 日本国产一区二区| 卡一卡二国产精品|