TINY源码分析
一、文件概述
MAIN.C: 主函数
GLOBALS.H:全局定义的文件
SCAN.C/SCAN.H: 词法分析
PARSE.C/PARSE.H:语法分析
UTIL.C/UTIL.H:构造树
SYMTAB.C/SYMTAB.H:符号表
CGEN.C/CGEN.H:生成"汇编代码"
CODE.C/CODE.H:这个只是用来把分析过程输出到屏幕的.
二、各个文件的分析
1.MAIN.C:
主要有三个FILE*句柄:
source--源代码文件。
listing--显示分析过程的文件,这里重定向到stdout。
code--目标汇编代码文件。
从该文件中可知程序运行的流程:
检查参数正确否(tiny.exe filename)->构造语法树(调用parse函数)->根据语法树生成代码(调用codeGen函数,该函数又调用cGen函数。
2.GLOBALS.H:
定义了关键字个数8个。
定义了关键字,运算符等内容的枚举值。
定义了语句类型的枚举值,这个决定树的结点。