当前位置:首页 > 资讯 > info6 > 正文

第二人生的源码分析(104)脚本的词法分析(2)

发表于: 2008-07-11   作者:caimouse   来源:转载   浏览:
摘要: 接着上一次,再来分析flex文件的下一部份:规则部份。它们由一连串带有代码的正则表达式组成,当匹配相对应的正则表达式时,这些代码就会被运行。下面就一段规则的代码:#001 %%这行表示规则代码开始。 #002 "//"                  {gInternalLine++;gInternalColumn=0;comment();}这里使用“//”来表注释一行代码。 #003 #004
接着上一次,再来分析 flex文件的下一部份:规则部份。它们由一连串带有代码的正则表达式组成,当匹配相对应的正则表达式时,这些代码就会被运行。下面就一段规则的代码:
#001 %%
这行表示规则代码开始。
 
#002 "//"                    { gInternalLine++; gInternalColumn = 0; comment(); }
这里使用“ //”来表注释一行代码。
 
#003 
#004 "integer"           { count(); return(INTEGER); }
这里识别关键字 integer为整数据处理。
 
#005 "float"                 { count(); return(FLOAT_TYPE); }
#006 "string"            { count(); return(STRING); }
#007 "key"               { count(); return(LLKEY); }
#008 "vector"            { count(); return(VECTOR); }
#009 "quaternion"        { count(); return(QUATERNION); }
#010 "rotation"          { count(); return(QUATERNION); }
#011 "list"              { count(); return(LIST); }
上面这段依次是识别浮点数 float,字符串string,键key,数组vector,四元数quaternion,旋转rotation,列表list。可以看到每识别一个关键字出来就返回相应的标识ID,这样方便后面的语法分析和语义分析,以及代码的生成。
 
其它好多的规则都是跟上面一样的,下面再来分析一些比较特别的规则,如下:
#001 0[xX]{H}+           { count(); yylval.ival = strtoul(yytext, NULL, 0); return(INTEGER_CONSTANT); }
#002 {N}+                { count(); yylval.ival = strtoul(yytext, NULL, 10); return(INTEGER_CONSTANT); }
这两行就是识别数字串,比如第一行是识别 16进制的数字串,例如0x12,0Xa233。第二行是识别一般的10进制的数字。
 
下面这行是识文件结束的状态:
#001 "EOF"                   { yylval.sval = new char[UUID_STR_LENGTH]; strcpy(yylval.sval, "/n/n/n"); return(STRING_CONSTANT);
#002 }
 
下面是一些比较复杂的规则:
#001 
#002 {L}({L}|{N})*       { count(); yylval.sval = new char[strlen(yytext) + 1]; strcpy(yylval.sval, yytext); return(IDENTIFIER); }
这行是识别脚本定义的变量标识符。
 
#003 
#004 {N}+{E}                     { count(); yylval.fval = (F32)atof(yytext); return(FP_CONSTANT); }
识别浮点数。
 
#005 {N}*"."{N}+({E})?{FS}? { count(); yylval.fval = (F32)atof(yytext); return(FP_CONSTANT); }
识别浮点数。
 
#006 {N}+"."{N}*({E})?{FS}? { count(); yylval.fval = (F32)atof(yytext); return(FP_CONSTANT); }
识别浮点数。
 
#007 
#008 L?/"(//.|[^//"])*/"     { parse_string(); count(); return(STRING_CONSTANT); }
识别字符串常量。
 
下面一段是识别操作符的规则:
#001 "++"                { count(); return(INC_OP); }
#002 "--"                { count(); return(DEC_OP); }
#003 "+="                { count(); return(ADD_ASSIGN); }
#004 "-="                { count(); return(SUB_ASSIGN); }
#005 "*="                { count(); return(MUL_ASSIGN); }
#006 "/="                { count(); return(DIV_ASSIGN); }
#007 "%="                { count(); return(MOD_ASSIGN); }
 
 
下面两行:
#001 [ /t/v/n/f]             { count(); }
这行是处理制表符。
 
#002 .                   { /* ignore bad characters */ }
处理不能正确处理的字符。
 
通过上面这段 flex规则文件的分析,可以看到构造一个词法分析器,还是比较复杂的。如果使用手工来构造一个词法分析器会更加复杂多了。通过一节学会怎么编写flex词法分析器的规则。

第二人生的源码分析(104)脚本的词法分析(2)

编辑推荐
前面我们学习怎么样打开窗口来创建脚本,接着下来就需要知道这些脚本是做什么用的,这样最终才会按
前面我们学习怎么样打开窗口来创建脚本,接着下来就需要知道这些脚本是做什么用的,这样最终才会按
哲学里说,世界是永远在运动的。那么在现实中人们对软件的需求是永远在变化的,为了对付这种不断变
哲学里说,世界是永远在运动的。那么在现实中人们对软件的需求是永远在变化的,为了对付这种不断变
第二人生的基功能可以定义为网络游戏、社交网络和 Web2.0 。作为网络游戏,它可以让人扮演角色,也
网络的带宽,目前来说已经变得很大了,但那是相对以前的网络来说的。对于需求流量越来越大,传送的
在前面介绍了登录过程的界面里有一个退出按钮,如果当用户不想登录时,就可以随时按这个按钮退出登
在第二生里,菜单是缺少不了的。菜单提供了简单层次关系的一种表达方式,方便表达复杂的层次关系,
在基于 GUI界面的软件交互时,最基本的输入就是编辑框了,比如下图里输入的用户名称和密码,在游戏
由于第二人生是多媒体的程序,因此它有音乐播放和语言聊天,那么就得使用到一种滑动条来调整音量的
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号