1. UCC的输入文件
UCC在编译源文件(实际上为预处理文件.i)时, 需要读入源文件的内容, 以便进一步处理.
2. UCC文件处理相关数据结构
2.1 文件位置
文件位置是字符串在文件中的位置, 文件名, 行数, 列数.
typedef struct coord
{
char *filename;
int ppline;
int line;
int col;
} *Coord;
filename, 文件名.
ppline, 预处理文件中的行数.
line, 源文件中的行数.
col, 预处理文件中的列数.
2.2 文件的表示
struct input
{
char *filename;
unsigned char *base;
unsigned char *cursor;
unsigned char *lineHead;
int line;
void* file;
void* fileMapping;
unsigned long size;
};
filename, 文件的名字.
base, 文件内存的地址.
cursor, 当前内容的地址.
linehead, 当前行的首地址.
line, 当前字符串的列.
file, 文件指针.
size, 文件大小.
3. 文件的操作
3.1 文件打开
在处理预处理文件时, 会将文件的内容一次读入分配的内存, 在文件结尾处放置特殊值END_OF_FILE 255.
每次处理一个文件, 使用全局的结构struct input Input管理打开的文件.
void ReadSourceFile(char *filename)
Input.file = fopen(filename, "r");
if (Input.file == NULL)
{
Fatal("Can't open file: %s.", filename);
}
//打开文件
fseek(Input.file, 0, SEEK_END);
Input.size = ftell(Input.file);
//获取文件长度
Input.base = malloc(Input.size + 1);
if (Input.base == NULL)
{
Fatal("The file %s is too big", filename);
fclose(Input.file);
}
//分配文件长度的内存
fseek(Input.file, 0, SEEK_SET);
Input.size = fread(Input.base, 1, Input.size, Input.file);
//读入全部的文件内容
fclose(Input.file);
//关闭文件.
Input.filename = filename;
Input.base[Input.size] = END_OF_FILE;
//设置最后的内存内容为END_OF_FILE
Input.cursor = Input.lineHead = Input.base;
//设置当前读位置, 行位置,
Input.line = 1;
//设置当前行数为1
3.2 关闭文件
void CloseSourceFile(void)
free(Input.base);
//释放分配的文件内容指针