- 添加 .gitignore 文件,忽略编译器生成的二进制文件 - 重构 lexer.c 文件,改进了关键字处理和字符串处理 - 更新前端的前端、解析器和 AST 相关文件,以适应新的词法分析器 - 优化了 token 相关的定义和函数,引入了新的 token 类型
39 lines
994 B
C
39 lines
994 B
C
#ifndef __SMCC_CC_LEXER_H__
|
|
#define __SMCC_CC_LEXER_H__
|
|
|
|
#include <lib/core.h>
|
|
#include "token.h"
|
|
#ifndef LEXER_MAX_TOKEN_SIZE
|
|
#define LEXER_MAX_TOKEN_SIZE 63
|
|
#endif
|
|
#ifndef LEXER_BUFFER_SIZE
|
|
#define LEXER_BUFFER_SIZE 4095
|
|
#endif
|
|
|
|
typedef int (*lexer_sread_fn)(void *dst_buf, int dst_size,
|
|
int elem_size, int count, void *stream);
|
|
|
|
typedef struct lexer {
|
|
loc_t loc;
|
|
|
|
char* cur_ptr; // 当前扫描的字符,但是还没有开始扫描
|
|
char* end_ptr; // 缓冲区最后一个字符的下一个位置
|
|
char buffer[LEXER_BUFFER_SIZE+1];
|
|
|
|
lexer_sread_fn sread;
|
|
void* stream;
|
|
|
|
strpool_t* strpool;
|
|
} lexer_t;
|
|
|
|
void init_lexer(lexer_t* lexer, const char* file_name, void* stream,
|
|
lexer_sread_fn sread, strpool_t* strpool);
|
|
|
|
// pure token getter it will included empty token like TOKEN_BLANK
|
|
void get_token(lexer_t* lexer, tok_t* token);
|
|
|
|
// get_token maybe got invalid (with parser as TOKEN_BLANK)
|
|
void get_valid_token(lexer_t* lexer, tok_t* token);
|
|
|
|
#endif
|