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

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

?? pl0.c

?? C語言編寫的PLO源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*
 * 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
 *
 * 使用方法:
 * 運行后輸入PL/0源程序文件?
 * 回答是否輸出虛擬機代碼
 * 回答是否輸出名字表
 * fa.tmp輸出虛擬機代碼
 * fa1.tmp輸出源文件及其各行對應的首地址
 * fa2.tmp輸出結?
 * fas.tmp輸出名字表
 */

#include <stdio.h>

#include "pl0.h"
#include "string.h"

/* 解釋執行時使用的棧 */
#define stacksize 500


int main()
{
    bool nxtlev[symnum];

    printf("Input pl/0 file:");
    scanf("%s", fname);     /* 輸入文件名 */

    fin = fopen(fname, "r");

    if (fin)
    {
        printf("List object code?(Y/N)");   /* 是否輸出虛擬機代碼 */
        scanf("%s", fname);
        listswitch = (fname[0]=='y' || fname[0]=='Y');

        printf("List symbol table?(Y/N)");  /* 是否輸出名字表 */
        scanf("%s", fname);
        tableswitch = (fname[0]=='y' || fname[0]=='Y');

        fa1 = fopen("fa1.tmp", "w");
        fprintf(fa1,"Input pl/0 file?   ");
        fprintf(fa1,"%s\n",fname);

        init();     /* 初始化 */

        err = 0;
        cc = cx = ll = 0;
        ch = ' ';

        if(-1 != getsym())
    	{
            fa = fopen("fa.tmp", "w");
            fas = fopen("fas.tmp", "w");
            addset(nxtlev, declbegsys, statbegsys, symnum);
            nxtlev[period] = true;

            if(-1 == block(0, 0, nxtlev))   /* 調用編譯程序 */
    		{
                fclose(fa);
                fclose(fa1);
                fclose(fas);
                fclose(fin);
                printf("\n");
                return 0;
    		}
            fclose(fa);
            fclose(fa1);
            fclose(fas);

            if (sym != period)
    		{
                error(9);
    		}

            if (err == 0)
    		{
                fa2 = fopen("fa2.tmp", "w");
                interpret();    /* 調用解釋執行程序 */
                fclose(fa2);
    		}
        	else
    		{
                printf("Errors in pl/0 program");
    		}
    	}

        fclose(fin);
    }
    else
    {
        printf("Can't open file!\n");
    }

    printf("\n");
    return 0;
}

/*
* 初始化
*/
void init()
{
    int i;

    /* 設置單字符符號 */
    for (i=0; i<=255; i++)
    {
        ssym[i] = nul;
    }
    ssym['+'] = plus;
    ssym['-'] = minus;
    ssym['*'] = times;
    ssym['/'] = slash;
    ssym['('] = lparen;
    ssym[')'] = rparen;
    ssym['='] = eql;
    ssym[','] = comma;
    ssym['.'] = period;
    ssym['#'] = neq;
    ssym[';'] = semicolon;

    /* 設置保留字名字,按照字母順序,便于折半查找 */
    strcpy(&(word[0][0]), "begin");
    strcpy(&(word[1][0]), "call");
    strcpy(&(word[2][0]), "const");
    strcpy(&(word[3][0]), "do");
    strcpy(&(word[4][0]), "end");
    strcpy(&(word[5][0]), "if");
    strcpy(&(word[6][0]), "odd");
    strcpy(&(word[7][0]), "procedure");
    strcpy(&(word[8][0]), "read");
    strcpy(&(word[9][0]), "then");
    strcpy(&(word[10][0]), "var");
    strcpy(&(word[11][0]), "while");
    strcpy(&(word[12][0]), "write");

    /* 設置保留字符號 */
    wsym[0] = beginsym;
    wsym[1] = callsym;
    wsym[2] = constsym;
    wsym[3] = dosym;
    wsym[4] = endsym;
    wsym[5] = ifsym;
    wsym[6] = oddsym;
    wsym[7] = procsym;
    wsym[8] = readsym;
    wsym[9] = thensym;
    wsym[10] = varsym;
    wsym[11] = whilesym;
    wsym[12] = writesym;

    /* 設置指令名稱 */
    strcpy(&(mnemonic[lit][0]), "lit");
    strcpy(&(mnemonic[opr][0]), "opr");
    strcpy(&(mnemonic[lod][0]), "lod");
    strcpy(&(mnemonic[sto][0]), "sto");
    strcpy(&(mnemonic[cal][0]), "cal");
    strcpy(&(mnemonic[inte][0]), "int");
    strcpy(&(mnemonic[jmp][0]), "jmp");
    strcpy(&(mnemonic[jpc][0]), "jpc");

    /* 設置符號集 */
    for (i=0; i<symnum; i++)
    {
        declbegsys[i] = false;
        statbegsys[i] = false;
        facbegsys[i] = false;
    }

    /* 設置聲明開始符號集 */
    declbegsys[constsym] = true;
    declbegsys[varsym] = true;
    declbegsys[procsym] = true;

    /* 設置語句開始符號集 */
    statbegsys[beginsym] = true;
    statbegsys[callsym] = true;
    statbegsys[ifsym] = true;
    statbegsys[whilesym] = true;

    /* 設置因子開始符號集 */
    facbegsys[ident] = true;
    facbegsys[number] = true;
    facbegsys[lparen] = true;
}

/*
* 每次讀一行,存入line緩沖區,line被getsym取空后再讀一行
*
* 被函數getsym調用。
*/
int getch()
{
    if (cc == ll)
    {
        if (feof(fin))
    	{
            printf("program incomplete");
            return -1;
    	}
        ll=0;
        cc=0;
        printf("%d ", cx);
        fprintf(fa1,"%d ", cx);
        ch = ' ';
        while (ch != 10) //10為換行符
    	{
            if (EOF == fscanf(fin,"%c", &ch))
    		{
                line[ll] = 0;
            	break;
    		}
            printf("%c", ch);
            fprintf(fa1, "%c", ch);
            line[ll] = ch;
        	ll++;
    	}
        printf("\n");
        fprintf(fa1, "\n");
    }
    ch = line[cc];
    cc++;
    return 0;   //0為讀取成功
}

/*
* 詞法分析,獲取一個符號
*/
int getsym()
{
    int i,j,k;

    /* the original version lacks "\r", thanks to foolevery */
    while (ch==' ' || ch==10 || ch==13 || ch==9)  /* 忽略空格、換行、回車和TAB */
    {
        getchdo;
    }
    if (ch>='a' && ch<='z')
    {           /* 名字或保留字以a..z開頭 */
        k = 0;
        do {
            if(k<al)
    		{
                a[k] = ch;
        		k++;
    		}
            getchdo;
        } while (ch>='a' && ch<='z' || ch>='0' && ch<='9');
        a[k] = 0;
        strcpy(id, a);
        i = 0;
        j = norw-1;
        do {    /* 搜索當前符號是否為保留字 */
            k = (i+j)/2;
			if (strcmp(id,word[k]) == 0) 
			{
				sym = wsym[k];
				break; 
			}
            if (strcmp(id,word[k]) < 0)
                j = k - 1;    	
            else
                i = k + 1;    		
        } while (i <= j);
        if ( i > j)
    	{
            sym = ident; /* 搜索失敗則,是名字或數字 */
    	}
    }
    else
    {
        if (ch>='0' && ch<='9')
        {           /* 檢測是否為數字:以0..9開頭 */
            k = 0;
            num = 0;
            sym = number;
        	do {
                num = 10*num + ch - '0';
        		k++;
            	getchdo;
            } while (ch>='0' && ch<='9'); /* 獲取數字的值 */
        	k--;
            if (k > nmax)
    		{
                error(30);
    		}
    	}
        else
    	{
            if (ch == ':')      /* 檢測賦值符號 */
    		{
            	getchdo;
                if (ch == '=')
        		{
                    sym = becomes;
                	getchdo;
        		}
        		else
        		{
                    sym = nul;  /* 不能識別的符號 */
        		}
    		}
        	else
    		{
                if (ch == '<')      /* 檢測小于或小于等于符號 */
        		{
                	getchdo;
                    if (ch == '=')
        			{
                		sym = leq;
                		getchdo;
        			}
            		else
        			{
                		sym = lss;
        			}
        		}
        		else
        		{
                    if (ch=='>')        /* 檢測大于或大于等于符號 */
        			{
                		getchdo;
                    	if (ch == '=')
        				{
                    		sym = geq;
                			getchdo;
        				}
            			else
        				{
                    		sym = gtr;
        				}
        			}
            		else
        			{
                        sym = ssym[ch];     /* 當符號不滿足上述條件時,全部按照單字符符號處理 */
                		if (sym != period)
        				{
                			getchdo;
        				}
        			}
        		}
    		}
    	}
    }
    return 0;
}

/*
* 查找名字的位置.
* 找到則返回在名字表中的位置,否則返回0.
*
* idt:    要查找的名字
* tx:     當前名字表尾指針
*/
int position(char* idt, int tx)
{
    int i;
    strcpy(table[0].name, idt);
    i = tx;
    while (strcmp(table[i].name, idt) != 0)
    {
        i--;
    }
    return i;
}

/*
* 在名字表中加入一項
*
* k:      名字種類constant, variable, procedur
* ptx:    名字表尾指針的指針,為了可以改變名字表尾指針的值
* lev:    名字所在的層次,,以后所有的lev都是這樣
* pdx:    dx為當前應分配的變量的相對地址,分配后要增加1
*/
void enter(enum object k, int* ptx, int lev, int* pdx)
{
    (*ptx)++;
    strcpy(table[(*ptx)].name, id); /* 全局變量id中已存有當前名字的名字 */
    table[(*ptx)].kind = k;
    switch (k)
    {
    case constant:  /* 常量名字 */
        if (num > amax)
    	{
            error(31);  /* 數越界 */
            num = 0;
    	}
        table[(*ptx)].val = num;
        break;
    case variable:  /* 變量名字 */
        table[(*ptx)].level = lev;
        table[(*ptx)].adr = (*pdx);
        (*pdx)++;
        break;
    case procedur:  /* 過程名字 */
        table[(*ptx)].level = lev;
        break;
    }
}

/*
* 用數組實現集合的集合運算
*/
int inset(int e, bool* s)
{
    return s[e];
}

int addset(bool* sr, bool* s1, bool* s2, int n)
{
    int i;
    for (i=0; i<n; i++)
    {
        sr[i] = s1[i]||s2[i];
    }
    return 0;
}

int subset(bool* sr, bool* s1, bool* s2, int n)
{
    int i;
    for (i=0; i<n; i++)
    {
        sr[i] = s1[i]&&(!s2[i]);
    }
    return 0;
}

int mulset(bool* sr, bool* s1, bool* s2, int n)
{
    int i;
    for (i=0; i<n; i++)
    {
        sr[i] = s1[i]&&s2[i];
    }
    return 0;
}

/*
* 測試當前符號是否合法
*
* 在某一部分(如一條語句,一個表達式)將要結束時時我們希望下一個符號屬于某集合

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米影视一区二区三区小说| 国产精品综合一区二区三区| 国产成人精品影视| 欧美片网站yy| 欧美成人精品3d动漫h| 国产日韩欧美精品电影三级在线| 18成人在线观看| 精油按摩中文字幕久久| 欧美在线免费播放| 亚洲一区二区三区视频在线 | 亚洲日本免费电影| 日本vs亚洲vs韩国一区三区二区| 成人a免费在线看| 亚洲精品一区二区精华| 视频一区视频二区中文字幕| 91老司机福利 在线| 国产午夜精品美女毛片视频| 蜜臀久久久久久久| 亚洲欧洲av另类| 一区二区三区色| 亚洲欧洲综合另类| 国模冰冰炮一区二区| 91精品国产入口在线| 亚洲欧洲综合另类| 成人免费三级在线| 久久久一区二区三区捆绑**| 麻豆精品视频在线观看| 91精品中文字幕一区二区三区| 亚洲欧美日韩中文播放| 91原创在线视频| 亚洲免费视频中文字幕| 91丝袜高跟美女视频| 亚洲三级电影全部在线观看高清| 粉嫩在线一区二区三区视频| 久久久久久久久一| 国产一区视频网站| 久久精品视频一区二区三区| 国产呦萝稀缺另类资源| 国产日韩精品视频一区| 久久精品夜夜夜夜久久| 性欧美大战久久久久久久久| 91论坛在线播放| 一区二区三区在线看| 在线观看一区二区视频| 亚洲妇熟xx妇色黄| 久久不见久久见免费视频1| 在线观看av不卡| 日韩欧美久久久| 色综合色综合色综合| 国产精品三级av在线播放| 99久久亚洲一区二区三区青草| 国产精品乱码一区二区三区软件| 成人av中文字幕| 亚洲最大色网站| 欧美一二三区在线观看| 国产成人在线视频播放| 亚洲天堂免费看| 欧美丰满嫩嫩电影| 国产在线精品一区二区不卡了| 国产日韩精品一区二区浪潮av | 国产精品久久久久久久蜜臀| 成人黄页在线观看| 亚洲综合激情另类小说区| 欧美日产在线观看| 国产乱码精品一区二区三区五月婷| 国产亚洲精品7777| 在线欧美小视频| 激情五月激情综合网| 亚洲天堂免费在线观看视频| 欧美一区二区三区婷婷月色 | 成人午夜av在线| 亚洲国产毛片aaaaa无费看| 日韩视频国产视频| 99国产麻豆精品| 久久精品免费观看| 日韩伦理av电影| 欧美精品一区二区三区视频| 91美女蜜桃在线| 国产最新精品免费| 亚洲高清免费视频| 国产精品女人毛片| 日韩欧美一区在线| 色婷婷亚洲一区二区三区| 日本美女一区二区| 亚洲卡通动漫在线| 久久精品亚洲精品国产欧美| 欧美精品久久久久久久久老牛影院| 国产精品亚洲综合一区在线观看| 夜夜揉揉日日人人青青一国产精品 | 91麻豆精品在线观看| 裸体健美xxxx欧美裸体表演| 亚洲欧美日韩成人高清在线一区| 精品国产一区二区三区久久久蜜月| 91伊人久久大香线蕉| 国产福利一区二区三区视频在线| 亚洲成av人片www| 亚洲少妇30p| 中文在线免费一区三区高中清不卡| 4438成人网| 欧美另类久久久品| 欧美最新大片在线看| 99综合电影在线视频| 国产成人午夜精品5599 | 风间由美一区二区三区在线观看| 强制捆绑调教一区二区| 亚洲福利一区二区| 亚洲激情自拍视频| 樱桃视频在线观看一区| 亚洲欧美一区二区在线观看| 欧美国产禁国产网站cc| 国产欧美一区二区三区在线老狼| 日韩欧美国产不卡| 欧美妇女性影城| 8x8x8国产精品| 69堂精品视频| 日韩视频一区在线观看| 91精品国产综合久久精品图片 | 日韩欧美激情一区| 日韩西西人体444www| 欧美一区二区三级| 日韩欧美在线网站| 精品播放一区二区| 久久久91精品国产一区二区精品 | 一本一本大道香蕉久在线精品| 国产91精品一区二区| 成人午夜激情片| 日本丰满少妇一区二区三区| 色综合欧美在线| 欧美三级日韩三级| 日韩一本二本av| 久久久av毛片精品| 中文字幕日韩av资源站| 一区二区三区在线观看欧美 | 婷婷成人激情在线网| 日韩精品国产精品| 激情文学综合插| 成人免费观看av| 在线看一区二区| 欧美电视剧在线看免费| 欧美xfplay| 国产精品美女久久久久aⅴ| 亚洲欧美二区三区| 天天综合网 天天综合色| 蜜臀av性久久久久蜜臀av麻豆| 精品夜夜嗨av一区二区三区| 播五月开心婷婷综合| 欧美日韩一区二区欧美激情| 欧美一区二区视频免费观看| 久久久久97国产精华液好用吗| 国产精品国产a| 午夜久久久久久电影| 国模冰冰炮一区二区| 91麻豆免费在线观看| 日韩色在线观看| 亚洲欧洲制服丝袜| 九九国产精品视频| 色8久久精品久久久久久蜜| 日韩欧美第一区| 亚洲色图欧洲色图婷婷| 狠狠狠色丁香婷婷综合久久五月| 99国产欧美久久久精品| 精品蜜桃在线看| 亚洲精品videosex极品| 国产美女精品人人做人人爽| 在线观看国产日韩| 国产亚洲精品资源在线26u| 亚洲成在人线在线播放| 成人一级片网址| 日韩亚洲欧美在线| 一个色妞综合视频在线观看| 国产精品一区在线观看你懂的| 在线观看成人免费视频| 国产日韩欧美亚洲| 青青草成人在线观看| 在线观看日韩av先锋影音电影院| 久久影音资源网| 青青草国产成人99久久| 在线国产电影不卡| 国产精品国产三级国产专播品爱网| 免费成人小视频| 欧美日韩精品系列| 有坂深雪av一区二区精品| 成人午夜大片免费观看| 久久久亚洲综合| 久久精品国产秦先生| 91精品国产麻豆国产自产在线 | 精品国产亚洲在线| 日本午夜精品一区二区三区电影| 91网站视频在线观看| 亚洲国产精品传媒在线观看| 久久99热狠狠色一区二区| 欧美一区二区三区色| 亚洲不卡av一区二区三区| 在线观看国产91| 亚洲一二三区视频在线观看| 色婷婷综合五月| 亚洲综合色在线| 欧美色爱综合网| 天天亚洲美女在线视频| 欧美军同video69gay|