- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
编译原理实验Tiny语法分析
TINY+语言的语法分析软件
软件设计说明文档
院系 计算机学院
专业 计算机科学与技术
年级 2008级
班级 2班
姓名 张俊发 学号 20082101032
实验名称 综合利用多媒体制作网站或者应用程序
实验时间 5月1日至25 日
指导老师及职称 黄煜廉
1.总体描述
1.1总体功能概述
TINY+语言的语法分析软件提供Window界面,用户可以点击【打开】按钮打开或者在编辑框中输入一个扩展Tiny+语言源程序;通过【打印语法树】复选按钮可以选择在分析结果中打印语法树,【语法分析】按钮提供Tiny语言词法分析功能,对源程序进行语法分析后在内存中生成语法树,并将分析结果显示在编辑框中;【文件另存为】按钮可以保存文件。
1.2设计目标
设计目标:
扩充的语法规则有:
While-stmt -- while exp do stmt-sequence endwhile
Dowhile-stmt--do stmt-sequence while exp
for-stmt--for identifier:=simple-exp to simple-exp do stmt-sequence enddo 步长递增1
for-stmt--for identifier:=simple-exp downto simple-exp do stmt-sequence enddo 步长递减1
软件能对Tiny+语言源程序进行语法分析并生成语法树。
(1)要提供一个源程序编辑界面,以让用户输入源程序(可保存、打开源程序)
(2)可由用户选择是否生成语法树,并可查看所生成的语法树。
1.3 软件总体结构
本软件包括下面3个功能模块:词法分析功能模块;语法分析功能模块;?文本编辑模块;Scan:这部分的功能的核心函数是 getToken()函数。MyTokenType Scan::getToken(void)
{
int tokenStringIndex = 0;
MyTokenType currentToken;
StateType state = START;
int save;
while(state!=DONE){
int c = getNextChar();
save = TRUE;
switch(state){
case START:
if ( isdigit(c) ) state = INNUM;
else if ( isalpha(c) ) state = INID;
else if ( c == : ) state = INASSIGN;
else if ((c == ) || (c == \t) || (c == \n)) save = FALSE;
else if (c == {){
save = FALSE;
state = INCOMMENT;
}else{
state=DONE;
switch(c){
case EOF:save = FALSE;currentToken = MYENDFILE;break;
case =:currentToken = EQ;break;
case :currentToken = LT;break;
case +:currentToken = PLUS;break;
case -:currentToken = MINUS;break;
case *:currentToken = TIMES;break;
case /:currentToken = OVER;break;
case %:currentToken = MOD;break;
case (:currentToken = LPAREN;break;
case ):currentToken = RPAREN;break;
case ;:currentToken = SEMI;break;
default:currentToken = MYERROR;break;
}
}break;
case INCOMMENT:save =
您可能关注的文档
- 等角扇形束投影的CT重建算法研究.pdf
- 简单桁架内力计算.doc
- 简支钢桁架的静载试验报告.pdf
- 简易加减计算器数电课程设计.pdf
- 简析几种垂直轴风力机叶片攻角调整方法的优缺点.doc
- 算法分析与设计第十三讲第十四讲随机算法及实例分析.pdf
- 简述DMX通信.ppt
- 算符优先文法分析.doc
- 管机专业知识介绍.ppt
- 管桁架考试复习资料.doc
- 福莱特玻璃集团股份有限公司海外监管公告 - 福莱特玻璃集团股份有限公司2024年度环境、社会及管治报告.pdf
- 广哈通信:2024年度环境、社会及治理(ESG)报告.pdf
- 招商证券股份有限公司招商证券2024年度环境、社会及管治报告.pdf
- 宏信建设发展有限公司2024 可持续发展暨环境、社会及管治(ESG)报告.pdf
- 品创控股有限公司环境、社会及管治报告 2024.pdf
- 中信建投证券股份有限公司2024可持续发展暨环境、社会及管治报告.pdf
- 洛阳栾川钼业集团股份有限公司环境、社会及管治报告.pdf
- 361度国际有限公司二零二四年环境、社会及管治报告.pdf
- 中国神华能源股份有限公司2024年度环境、社会及管治报告.pdf
- 广西能源:2024年环境、社会及治理(ESG)报告.pdf
文档评论(0)