网站大量收购独家精品文档,联系QQ:2885784924

编译原理实验Tiny语法分析.doc

  1. 1、本文档共11页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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 =

文档评论(0)

linsspace + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档