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

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

?? pl0.h

?? pl0編譯原理源代碼
?? H
字號:
/*
 * PL/0 complier program for win32 platform (implemented in C)
 *
 * The program has been test on Visual C++ 6.0,  Visual C++.NET and
 * Visual C++.NET 2003,  on Win98,  WinNT,  Win2000,  WinXP and Win2003
 *
 */

typedef enum {
    false,
    true
} bool;


#define norw 13     /* 關鍵字個數 */
#define txmax 100   /* 名字表容量 */
#define nmax 14     /* number的最大位數 */
#define al 10       /* 符號的最大長度 */
#define amax 2047   /* 地址上界*/
#define levmax 3    /* 最大允許過程嵌套聲明層數 [0,  levmax]*/
#define cxmax 500   /* 最多的虛擬機代碼數 */

/* 符號 */
enum symbol {
    nul,         ident,     number,     plus,      minus,
    times,       slash,     oddsym,     eql,       neq,
    lss,         leq,       gtr,        geq,       lparen,
    rparen,      comma,     semicolon,  period,    becomes,
    beginsym,    endsym,    ifsym,      thensym,   whilesym,
    writesym,    readsym,   dosym,      callsym,   constsym,
    varsym,      procsym,
};
#define symnum 32

/* 名字表中的類型 */
enum object {
    constant,
    variable,
    procedur,
    array       //add
};

/* 虛擬機代碼 */
enum fct {
    lit,     opr,     lod,
    sto,     cal,     inte,
    jmp,     jpc,
};
#define fctnum 8

/* 虛擬機代碼結構 */
struct instruction
{
    enum fct f; /* 虛擬機代碼指令 */
    int l;      /* 引用層與聲明層的層次差 */
    int a;      /* 根據f的不同而不同 */
};

FILE* fas;  /* 輸出名字表 */
FILE* fa;   /* 輸出虛擬機代碼 */
FILE* fa1;  /* 輸出源文件及其各行對應的首地址 */
FILE* fa2;  /* 輸出結果 */
bool listswitch;    /* 顯示虛擬機代碼與否 */
bool tableswitch;   /* 顯示名字表與否 */
char ch;            /* 獲取字符的緩沖區,getch 使用 */
enum symbol sym;    /* 當前的符號 */
char id[al+1];      /* 當前ident, 多出的一個字節用于存放0 */
int num;            /* 當前number */
int cc, ll;          /* getch使用的計數器,cc表示當前字符(ch)的位置 */
int cx;             /* 虛擬機代碼指針, 取值范圍[0, cxmax-1]*/
char line[81];      /* 讀取行緩沖區 */
char a[al+1];       /* 臨時符號, 多出的一個字節用于存放0 */
struct instruction code[cxmax]; /* 存放虛擬機代碼的數組 */
char word[norw][al];        /* 保留字 */
enum symbol wsym[norw];     /* 保留字對應的符號值 */
enum symbol ssym[256];      /* 單字符的符號值 */
char mnemonic[fctnum][5];   /* 虛擬機代碼指令名稱 */
bool declbegsys[symnum];    /* 表示聲明開始的符號集合 */
bool statbegsys[symnum];    /* 表示語句開始的符號集合 */
bool facbegsys[symnum];     /* 表示因子開始的符號集合 */

/* 名字表結構 */
struct tablestruct
{
    char name[al];      /* 名字 */
    enum object kind;   /* 類型:const, var, array or procedure */
    int val;            /* 數值,僅const使用 */
    int level;          /* 所處層,僅const不使用 */
    int adr;            /* 地址,僅const不使用 */
    int size;           /* 需要分配的數據區空間, 僅procedure使用 */
};

struct tablestruct table[txmax]; /* 名字表 */

FILE* fin;
FILE* fout;
char fname[al];
int err; /* 錯誤計數器 */

/* 當函數中會發生fatal error時,返回-1告知調用它的函數,最終退出程序 */
#define getsymdo                      if(-1 == getsym()) return -1
#define getchdo                       if(-1 == getch()) return -1
#define testdo(a, b, c)               if(-1 == test(a, b, c)) return -1
#define gendo(a, b, c)                if(-1 == gen(a, b, c)) return -1
#define expressiondo(a, b, c)         if(-1 == expression(a, b, c)) return -1
#define factordo(a, b, c)             if(-1 == factor(a, b, c)) return -1
#define termdo(a, b, c)               if(-1 == term(a, b, c)) return -1
#define conditiondo(a, b, c)          if(-1 == condition(a, b, c)) return -1
#define statementdo(a, b, c)          if(-1 == statement(a, b, c)) return -1
#define constdeclarationdo(a, b, c)   if(-1 == constdeclaration(a, b, c)) return -1
#define vardeclarationdo(a, b, c)     if(-1 == vardeclaration(a, b, c)) return -1

void error(int n);
int getsym();
int getch();
void init();
int gen(enum fct x, int y, int z);
int test(bool* s1, bool* s2, int n);
int inset(int e, bool* s);
int addset(bool* sr, bool* s1, bool* s2, int n);
int subset(bool* sr, bool* s1, bool* s2, int n);
int mulset(bool* sr, bool* s1, bool* s2, int n);
int block(int lev, int tx, bool* fsys);
void interpret();
int factor(bool* fsys, int* ptx, int lev);
int term(bool* fsys, int* ptx, int lev);
int condition(bool* fsys, int* ptx, int lev);
int expression(bool* fsys, int* ptx, int lev);
int statement(bool* fsys, int* ptx, int lev);
void listcode(int cx0);
int vardeclaration(int* ptx, int lev, int* pdx);
int constdeclaration(int* ptx, int lev, int* pdx);
int position(char* idt, int tx);
void enter(enum object k, int* ptx, int lev, int* pdx);
int base(int l, int* s, int b);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
高清不卡在线观看| 不卡欧美aaaaa| 在线观看一区二区视频| 一区av在线播放| 日本午夜一本久久久综合| 欧美精品久久一区| 波多野洁衣一区| 成人理论电影网| 国产网红主播福利一区二区| 亚洲国产精品影院| 91精品国产免费久久综合| 午夜影视日本亚洲欧洲精品| 欧美丝袜丝nylons| 精品一区二区三区久久| 欧美一区二区视频免费观看| 狠狠色丁香婷综合久久| 一区二区三区四区在线播放 | 国产欧美一区二区精品性| 久久se这里有精品| 538prom精品视频线放| 精品亚洲国产成人av制服丝袜| 国产精品久久久久影院| 色偷偷久久一区二区三区| 亚洲黄色片在线观看| 制服丝袜亚洲精品中文字幕| 五月天欧美精品| 国产精品蜜臀在线观看| 午夜私人影院久久久久| 欧美最新大片在线看| 久久91精品久久久久久秒播| 亚洲欧美日韩一区二区三区在线观看| 欧美成人一区二区三区| 91精品国产麻豆| 99精品黄色片免费大全| 日日摸夜夜添夜夜添亚洲女人| 91黄色免费版| 国产精品一区三区| 日韩1区2区3区| 久久久三级国产网站| 欧洲人成人精品| 国产成人自拍在线| 奇米在线7777在线精品| 蜜臀a∨国产成人精品| 午夜激情一区二区三区| 国产三级三级三级精品8ⅰ区| 欧美久久久久中文字幕| 99re在线视频这里只有精品| 日韩成人免费电影| 精品午夜久久福利影院| 亚洲综合成人在线视频| 不卡av在线网| 成人激情午夜影院| 国产麻豆精品在线| 久久99九九99精品| 国产在线一区二区| 波多野结衣精品在线| 日韩精品乱码av一区二区| 一区二区三区四区精品在线视频 | 国产精品热久久久久夜色精品三区 | 26uuu精品一区二区三区四区在线| 欧美精品v国产精品v日韩精品| 在线不卡a资源高清| 欧美体内she精高潮| 国产·精品毛片| 国内精品伊人久久久久影院对白| 国产精品一区二区久久不卡| 国产夫妻精品视频| 成人午夜av影视| 懂色av一区二区在线播放| 欧美日韩视频在线观看一区二区三区| 7777精品伊人久久久大香线蕉的 | 91小视频在线免费看| 91免费看视频| 色诱视频网站一区| 欧美亚洲动漫精品| 欧美揉bbbbb揉bbbbb| 久久久一区二区| 亚洲人午夜精品天堂一二香蕉| 美脚の诱脚舐め脚责91| 成人动漫一区二区| 欧美手机在线视频| 国产精品麻豆欧美日韩ww| 一级精品视频在线观看宜春院 | 欧美一区二区三区视频在线| 欧美一区二区三区影视| 欧美精品在线一区二区| 久久久精品影视| 午夜精品久久久久久久久久久| 国产成人精品免费在线| 色94色欧美sute亚洲线路二 | 91视视频在线直接观看在线看网页在线看 | 91丨porny丨在线| 一本久久综合亚洲鲁鲁五月天| 欧美日韩在线直播| 国产精品国产三级国产有无不卡| 国产成人精品网址| 久久久国际精品| 久久99国产精品久久99果冻传媒 | 欧美日韩成人一区| 亚洲欧美在线视频| 国产一区二区按摩在线观看| 美女一区二区久久| 欧美唯美清纯偷拍| 中文字幕一区日韩精品欧美| 秋霞影院一区二区| 欧美性色欧美a在线播放| 久久久久久久久免费| 看电影不卡的网站| 91精品国产综合久久福利软件| 天天综合天天做天天综合| 欧美电影影音先锋| 蜜乳av一区二区| 久久久夜色精品亚洲| 九九视频精品免费| 欧美一级黄色录像| 国产精品一二三四五| 91精品国产91久久综合桃花 | 亚洲精品水蜜桃| 国产成人午夜高潮毛片| 欧美综合欧美视频| 成人欧美一区二区三区1314| 在线观看三级视频欧美| 亚洲高清久久久| 欧美喷水一区二区| 亚洲欧美综合网| 欧美揉bbbbb揉bbbbb| 国产欧美日韩三区| 99久久精品99国产精品| 国产欧美一区二区三区在线看蜜臀| 丁香亚洲综合激情啪啪综合| 一区二区三区欧美视频| 欧美四级电影在线观看| 精品一区二区综合| 伊人性伊人情综合网| 另类欧美日韩国产在线| 91麻豆精品91久久久久久清纯| 麻豆成人综合网| 国产精品久久久久桃色tv| 欧美高清一级片在线| 日韩成人一级片| 久久女同性恋中文字幕| 国产一区二区三区四| 中文子幕无线码一区tr| a在线欧美一区| 日韩激情一二三区| 精品亚洲国产成人av制服丝袜 | 一区二区三区在线不卡| 一本色道久久综合亚洲精品按摩| 免费高清在线一区| 亚洲一区二区在线观看视频| 欧美亚洲综合久久| 精品在线视频一区| 午夜不卡av免费| 亚洲成人av免费| 久久亚洲欧美国产精品乐播| 日本道在线观看一区二区| 日韩二区在线观看| 一区二区三区欧美| 精品国产伦一区二区三区免费| 欧美日韩中文字幕一区| 成人亚洲精品久久久久软件| 国产精品资源在线看| 日本在线不卡一区| 亚洲福利视频导航| 亚洲欧洲综合另类在线| 国产精品免费丝袜| 久久人人爽爽爽人久久久| 91精品视频网| 色综合久久中文综合久久牛| 美国毛片一区二区三区| 麻豆成人综合网| 韩国欧美国产1区| 亚洲激情六月丁香| 亚洲午夜久久久久中文字幕久| 亚洲精品视频观看| 伦理电影国产精品| 蜜臀国产一区二区三区在线播放| 成人免费小视频| 亚洲一区二区高清| 午夜欧美大尺度福利影院在线看 | 亚洲视频图片小说| 国产精品久久综合| 国产精品美女久久久久aⅴ国产馆| 91精品黄色片免费大全| 欧美蜜桃一区二区三区| 欧美成人一区二区三区片免费| 精品99久久久久久| 中文字幕一区二区日韩精品绯色| 亚洲综合999| 天天影视网天天综合色在线播放| 国产女同互慰高潮91漫画| 亚洲乱码日产精品bd| 中文字幕一区二区三区四区不卡| 国产精品久久久久婷婷| 五月婷婷久久丁香| 狠狠色狠狠色综合系列| 在线观看精品一区| 国产欧美一区二区精品性色超碰 | 日韩片之四级片| 日韩视频一区二区三区|