PL0编译系统C版本.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PL0编译系统C版本

/* PL/0 编译系统C版本头文件pl0.h */ 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 200 /* 最多的虚拟机代码数 */ 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}; /* 虚拟机代码 */ enum fct { lit, opr, lod, sto, cal, inte, jmp, jpc }; #define fctnum 8 /* 虚拟机代码结构 */ struct instruction{ enum fct f; int l; int a; }; FILE* fas; FILE* fa; FILE* fa1; FILE* fa2; bool listswitch; bool tableswitch; char ch; enum symbol sym; char id[al+1]; int num; int cc, ll; int cx; char line[81]; char a[al+1]; 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; int val; int level; int adr; int size; }; 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 == c

文档评论(0)

dzzn118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档