Compare commits
6 Commits
| Author | SHA1 | Date |
|---|---|---|
|
|
c0a4de925f | 2 weeks ago |
|
|
04a29b2bf9 | 2 weeks ago |
|
|
477720eb5e | 2 weeks ago |
|
|
192b8004ed | 3 weeks ago |
|
|
702ed9c1fd | 3 weeks ago |
|
|
3832d65537 | 3 weeks ago |
@ -0,0 +1,12 @@
|
|||||||
|
## Lab1
|
||||||
|
|
||||||
|
# 1.构建
|
||||||
|
cmake -S . -B build -DCMAKE_BUILD_TYPE=Release -DCOMPILER_PARSE_ONLY=ON
|
||||||
|
cmake --build build -j "$(nproc)"
|
||||||
|
|
||||||
|
# 2.单例查看
|
||||||
|
./build/bin/compiler --emit-parse-tree test/test_case/functional/simple_add.sy
|
||||||
|
|
||||||
|
# 3.批量检查
|
||||||
|
find test/test_case -name '*.sy' | sort | while read f; do ./build/bin/compiler --emit-parse-tree "$f" >/dev/null || echo "FAIL $f"; done
|
||||||
|
|
||||||
@ -1,30 +1,213 @@
|
|||||||
// 基于语法树的语义检查与名称绑定。
|
#ifndef SEMANTIC_ANALYSIS_H
|
||||||
#pragma once
|
#define SEMANTIC_ANALYSIS_H
|
||||||
|
|
||||||
|
#include "SymbolTable.h"
|
||||||
|
#include "antlr4/SysYBaseVisitor.h"
|
||||||
|
#include "antlr4/SysYParser.h"
|
||||||
|
#include <vector>
|
||||||
|
#include <string>
|
||||||
|
#include <sstream>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
#include <any>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
#include "SysYParser.h"
|
// 错误信息结构体
|
||||||
|
struct ErrorMsg {
|
||||||
|
std::string msg;
|
||||||
|
int line;
|
||||||
|
int column;
|
||||||
|
ErrorMsg(std::string m, int l, int c) : msg(std::move(m)), line(l), column(c) {}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 前向声明
|
||||||
|
namespace antlr4 {
|
||||||
|
class ParserRuleContext;
|
||||||
|
namespace tree {
|
||||||
|
class ParseTree;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 语义/IR生成上下文核心类
|
||||||
|
class IRGenContext {
|
||||||
|
public:
|
||||||
|
// 错误管理
|
||||||
|
void RecordError(const ErrorMsg& err) { errors_.push_back(err); }
|
||||||
|
const std::vector<ErrorMsg>& GetErrors() const { return errors_; }
|
||||||
|
bool HasError() const { return !errors_.empty(); }
|
||||||
|
void ClearErrors() { errors_.clear(); }
|
||||||
|
|
||||||
|
// 类型绑定/查询 - 使用 void* 以兼容测试代码
|
||||||
|
void SetType(void* ctx, SymbolType type) {
|
||||||
|
node_type_map_[ctx] = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
SymbolType GetType(void* ctx) const {
|
||||||
|
auto it = node_type_map_.find(ctx);
|
||||||
|
return it == node_type_map_.end() ? SymbolType::TYPE_UNKNOWN : it->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 常量值绑定/查询 - 使用 void* 以兼容测试代码
|
||||||
|
void SetConstVal(void* ctx, const std::any& val) {
|
||||||
|
const_val_map_[ctx] = val;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any GetConstVal(void* ctx) const {
|
||||||
|
auto it = const_val_map_.find(ctx);
|
||||||
|
return it == const_val_map_.end() ? std::any() : it->second;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 循环状态管理
|
||||||
|
void EnterLoop() { sym_table_.EnterLoop(); }
|
||||||
|
void ExitLoop() { sym_table_.ExitLoop(); }
|
||||||
|
bool InLoop() const { return sym_table_.InLoop(); }
|
||||||
|
|
||||||
|
// 类型判断工具函数
|
||||||
|
bool IsIntType(const std::any& val) const {
|
||||||
|
return val.type() == typeid(long) || val.type() == typeid(int);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool IsFloatType(const std::any& val) const {
|
||||||
|
return val.type() == typeid(double) || val.type() == typeid(float);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 当前函数返回类型
|
||||||
|
SymbolType GetCurrentFuncReturnType() const {
|
||||||
|
return current_func_ret_type_;
|
||||||
|
}
|
||||||
|
|
||||||
|
void SetCurrentFuncReturnType(SymbolType type) {
|
||||||
|
current_func_ret_type_ = type;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 符号表访问
|
||||||
|
SymbolTable& GetSymbolTable() { return sym_table_; }
|
||||||
|
const SymbolTable& GetSymbolTable() const { return sym_table_; }
|
||||||
|
|
||||||
|
// 作用域管理
|
||||||
|
void EnterScope() { sym_table_.EnterScope(); }
|
||||||
|
void LeaveScope() { sym_table_.LeaveScope(); }
|
||||||
|
size_t GetScopeDepth() const { return sym_table_.GetScopeDepth(); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
SymbolTable sym_table_;
|
||||||
|
std::unordered_map<void*, SymbolType> node_type_map_;
|
||||||
|
std::unordered_map<void*, std::any> const_val_map_;
|
||||||
|
std::vector<ErrorMsg> errors_;
|
||||||
|
SymbolType current_func_ret_type_ = SymbolType::TYPE_UNKNOWN;
|
||||||
|
};
|
||||||
|
|
||||||
|
// 与现有 IRGen/主流程保持兼容的语义上下文占位。
|
||||||
class SemanticContext {
|
class SemanticContext {
|
||||||
public:
|
public:
|
||||||
void BindVarUse(SysYParser::VarContext* use,
|
void BindVarUse(const SysYParser::LValueContext* use,
|
||||||
SysYParser::VarDefContext* decl) {
|
SysYParser::VarDefContext* decl) {
|
||||||
var_uses_[use] = decl;
|
var_uses_[use] = decl;
|
||||||
}
|
}
|
||||||
|
|
||||||
SysYParser::VarDefContext* ResolveVarUse(
|
SysYParser::VarDefContext* ResolveVarUse(
|
||||||
const SysYParser::VarContext* use) const {
|
const SysYParser::LValueContext* use) const {
|
||||||
auto it = var_uses_.find(use);
|
auto it = var_uses_.find(use);
|
||||||
return it == var_uses_.end() ? nullptr : it->second;
|
return it == var_uses_.end() ? nullptr : it->second;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unordered_map<const SysYParser::VarContext*,
|
std::unordered_map<const SysYParser::LValueContext*,
|
||||||
SysYParser::VarDefContext*>
|
SysYParser::VarDefContext*>
|
||||||
var_uses_;
|
var_uses_;
|
||||||
|
};
|
||||||
|
|
||||||
|
// 错误信息格式化工具函数
|
||||||
|
inline std::string FormatErrMsg(const std::string& msg, int line, int col) {
|
||||||
|
std::ostringstream oss;
|
||||||
|
oss << "[行:" << line << ",列:" << col << "] " << msg;
|
||||||
|
return oss.str();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 语义分析访问器 - 继承自生成的基类
|
||||||
|
class SemaVisitor : public SysYBaseVisitor {
|
||||||
|
public:
|
||||||
|
explicit SemaVisitor(IRGenContext& ctx) : ir_ctx_(ctx) {}
|
||||||
|
|
||||||
|
// 必须实现的 ANTLR4 接口
|
||||||
|
std::any visit(antlr4::tree::ParseTree* tree) override {
|
||||||
|
if (tree) {
|
||||||
|
return tree->accept(this);
|
||||||
|
}
|
||||||
|
return std::any();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any visitTerminal(antlr4::tree::TerminalNode* node) override {
|
||||||
|
return std::any();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any visitErrorNode(antlr4::tree::ErrorNode* node) override {
|
||||||
|
if (node) {
|
||||||
|
int line = node->getSymbol()->getLine();
|
||||||
|
int col = node->getSymbol()->getCharPositionInLine() + 1;
|
||||||
|
ir_ctx_.RecordError(ErrorMsg("语法错误节点", line, col));
|
||||||
|
}
|
||||||
|
return std::any();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 核心访问方法
|
||||||
|
std::any visitCompUnit(SysYParser::CompUnitContext* ctx) override;
|
||||||
|
std::any visitDecl(SysYParser::DeclContext* ctx) override;
|
||||||
|
std::any visitConstDecl(SysYParser::ConstDeclContext* ctx) override;
|
||||||
|
std::any visitBtype(SysYParser::BtypeContext* ctx) override;
|
||||||
|
std::any visitConstDef(SysYParser::ConstDefContext* ctx) override;
|
||||||
|
std::any visitConstInitValue(SysYParser::ConstInitValueContext* ctx) override;
|
||||||
|
std::any visitVarDecl(SysYParser::VarDeclContext* ctx) override;
|
||||||
|
std::any visitVarDef(SysYParser::VarDefContext* ctx) override;
|
||||||
|
std::any visitInitValue(SysYParser::InitValueContext* ctx) override;
|
||||||
|
std::any visitFuncDef(SysYParser::FuncDefContext* ctx) override;
|
||||||
|
std::any visitFuncType(SysYParser::FuncTypeContext* ctx) override;
|
||||||
|
std::any visitFuncFParams(SysYParser::FuncFParamsContext* ctx) override;
|
||||||
|
std::any visitFuncFParam(SysYParser::FuncFParamContext* ctx) override;
|
||||||
|
std::any visitBlockStmt(SysYParser::BlockStmtContext* ctx) override;
|
||||||
|
std::any visitBlockItem(SysYParser::BlockItemContext* ctx) override;
|
||||||
|
std::any visitStmt(SysYParser::StmtContext* ctx) override;
|
||||||
|
std::any visitReturnStmt(SysYParser::ReturnStmtContext* ctx) override;
|
||||||
|
std::any visitExp(SysYParser::ExpContext* ctx) override;
|
||||||
|
std::any visitCond(SysYParser::CondContext* ctx) override;
|
||||||
|
std::any visitLValue(SysYParser::LValueContext* ctx) override;
|
||||||
|
std::any visitPrimaryExp(SysYParser::PrimaryExpContext* ctx) override;
|
||||||
|
std::any visitNumber(SysYParser::NumberContext* ctx) override;
|
||||||
|
std::any visitUnaryExp(SysYParser::UnaryExpContext* ctx) override;
|
||||||
|
std::any visitUnaryOp(SysYParser::UnaryOpContext* ctx) override;
|
||||||
|
std::any visitFuncRParams(SysYParser::FuncRParamsContext* ctx) override;
|
||||||
|
std::any visitMulExp(SysYParser::MulExpContext* ctx) override;
|
||||||
|
std::any visitAddExp(SysYParser::AddExpContext* ctx) override;
|
||||||
|
std::any visitRelExp(SysYParser::RelExpContext* ctx) override;
|
||||||
|
std::any visitEqExp(SysYParser::EqExpContext* ctx) override;
|
||||||
|
std::any visitLAndExp(SysYParser::LAndExpContext* ctx) override;
|
||||||
|
std::any visitLOrExp(SysYParser::LOrExpContext* ctx) override;
|
||||||
|
std::any visitConstExp(SysYParser::ConstExpContext* ctx) override;
|
||||||
|
|
||||||
|
// 通用子节点访问
|
||||||
|
std::any visitChildren(antlr4::tree::ParseTree* node) override {
|
||||||
|
std::any result;
|
||||||
|
if (node) {
|
||||||
|
for (auto* child : node->children) {
|
||||||
|
if (child) {
|
||||||
|
result = child->accept(this);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取上下文引用
|
||||||
|
IRGenContext& GetContext() { return ir_ctx_; }
|
||||||
|
const IRGenContext& GetContext() const { return ir_ctx_; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
IRGenContext& ir_ctx_;
|
||||||
};
|
};
|
||||||
|
|
||||||
// 目前仅检查:
|
// 语义分析入口函数
|
||||||
// - 变量先声明后使用
|
void RunSemanticAnalysis(SysYParser::CompUnitContext* ctx, IRGenContext& ir_ctx);
|
||||||
// - 局部变量不允许重复定义
|
|
||||||
|
// 兼容旧流程入口。
|
||||||
SemanticContext RunSema(SysYParser::CompUnitContext& comp_unit);
|
SemanticContext RunSema(SysYParser::CompUnitContext& comp_unit);
|
||||||
|
|
||||||
|
#endif // SEMANTIC_ANALYSIS_H
|
||||||
@ -1,17 +1,201 @@
|
|||||||
// 极简符号表:记录局部变量定义点。
|
#ifndef SYMBOL_TABLE_H
|
||||||
#pragma once
|
#define SYMBOL_TABLE_H
|
||||||
|
|
||||||
|
#include <any>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
#include <stack>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
#include "SysYParser.h"
|
// 核心类型枚举
|
||||||
|
enum class SymbolType {
|
||||||
|
TYPE_UNKNOWN, // 未知类型
|
||||||
|
TYPE_INT, // 整型
|
||||||
|
TYPE_FLOAT, // 浮点型
|
||||||
|
TYPE_VOID, // 空类型
|
||||||
|
TYPE_ARRAY, // 数组类型
|
||||||
|
TYPE_FUNCTION // 函数类型
|
||||||
|
};
|
||||||
|
|
||||||
|
// 获取类型名称字符串
|
||||||
|
inline const char* SymbolTypeToString(SymbolType type) {
|
||||||
|
switch (type) {
|
||||||
|
case SymbolType::TYPE_INT: return "int";
|
||||||
|
case SymbolType::TYPE_FLOAT: return "float";
|
||||||
|
case SymbolType::TYPE_VOID: return "void";
|
||||||
|
case SymbolType::TYPE_ARRAY: return "array";
|
||||||
|
case SymbolType::TYPE_FUNCTION: return "function";
|
||||||
|
default: return "unknown";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// 变量信息结构体
|
||||||
|
struct VarInfo {
|
||||||
|
SymbolType type = SymbolType::TYPE_UNKNOWN;
|
||||||
|
bool is_const = false;
|
||||||
|
std::any const_val;
|
||||||
|
std::vector<int> array_dims; // 数组维度,空表示非数组
|
||||||
|
void* decl_ctx = nullptr; // 关联的语法节点
|
||||||
|
|
||||||
|
// 检查是否为数组类型
|
||||||
|
bool IsArray() const { return !array_dims.empty(); }
|
||||||
|
|
||||||
|
// 获取数组元素总数
|
||||||
|
int GetArrayElementCount() const {
|
||||||
|
int count = 1;
|
||||||
|
for (int dim : array_dims) {
|
||||||
|
count *= dim;
|
||||||
|
}
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 函数信息结构体
|
||||||
|
struct FuncInfo {
|
||||||
|
SymbolType ret_type = SymbolType::TYPE_UNKNOWN;
|
||||||
|
std::string name;
|
||||||
|
std::vector<SymbolType> param_types; // 参数类型列表
|
||||||
|
void* decl_ctx = nullptr; // 关联的语法节点
|
||||||
|
|
||||||
|
// 检查参数匹配
|
||||||
|
bool CheckParams(const std::vector<SymbolType>& actual_params) const {
|
||||||
|
if (actual_params.size() != param_types.size()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (size_t i = 0; i < param_types.size(); ++i) {
|
||||||
|
if (param_types[i] != actual_params[i] &&
|
||||||
|
param_types[i] != SymbolType::TYPE_UNKNOWN &&
|
||||||
|
actual_params[i] != SymbolType::TYPE_UNKNOWN) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 作用域条目结构体
|
||||||
|
struct ScopeEntry {
|
||||||
|
// 变量符号表:符号名 -> (符号信息, 声明节点)
|
||||||
|
std::unordered_map<std::string, std::pair<VarInfo, void*>> var_symbols;
|
||||||
|
|
||||||
|
// 函数符号表:符号名 -> (函数信息, 声明节点)
|
||||||
|
std::unordered_map<std::string, std::pair<FuncInfo, void*>> func_symbols;
|
||||||
|
|
||||||
|
// 清空作用域
|
||||||
|
void Clear() {
|
||||||
|
var_symbols.clear();
|
||||||
|
func_symbols.clear();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// 符号表核心类
|
||||||
class SymbolTable {
|
class SymbolTable {
|
||||||
public:
|
public:
|
||||||
void Add(const std::string& name, SysYParser::VarDefContext* decl);
|
// ========== 作用域管理 ==========
|
||||||
bool Contains(const std::string& name) const;
|
|
||||||
SysYParser::VarDefContext* Lookup(const std::string& name) const;
|
// 进入新作用域
|
||||||
|
void EnterScope();
|
||||||
|
|
||||||
|
// 离开当前作用域
|
||||||
|
void LeaveScope();
|
||||||
|
|
||||||
|
// 获取当前作用域深度
|
||||||
|
size_t GetScopeDepth() const { return scopes_.size(); }
|
||||||
|
|
||||||
|
// 检查作用域栈是否为空
|
||||||
|
bool IsEmpty() const { return scopes_.empty(); }
|
||||||
|
|
||||||
|
// ========== 变量符号管理 ==========
|
||||||
|
|
||||||
|
// 检查当前作用域是否包含指定变量
|
||||||
|
bool CurrentScopeHasVar(const std::string& name) const;
|
||||||
|
|
||||||
|
// 绑定变量到当前作用域
|
||||||
|
void BindVar(const std::string& name, const VarInfo& info, void* decl_ctx);
|
||||||
|
|
||||||
|
// 查找变量(从当前作用域向上遍历)
|
||||||
|
bool LookupVar(const std::string& name, VarInfo& out_info, void*& out_decl_ctx) const;
|
||||||
|
|
||||||
|
// 快速查找变量(不获取详细信息)
|
||||||
|
bool HasVar(const std::string& name) const {
|
||||||
|
VarInfo info;
|
||||||
|
void* ctx;
|
||||||
|
return LookupVar(name, info, ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ========== 函数符号管理 ==========
|
||||||
|
|
||||||
|
// 检查当前作用域是否包含指定函数
|
||||||
|
bool CurrentScopeHasFunc(const std::string& name) const;
|
||||||
|
|
||||||
|
// 绑定函数到当前作用域
|
||||||
|
void BindFunc(const std::string& name, const FuncInfo& info, void* decl_ctx);
|
||||||
|
|
||||||
|
// 查找函数(从当前作用域向上遍历)
|
||||||
|
bool LookupFunc(const std::string& name, FuncInfo& out_info, void*& out_decl_ctx) const;
|
||||||
|
|
||||||
|
// 快速查找函数(不获取详细信息)
|
||||||
|
bool HasFunc(const std::string& name) const {
|
||||||
|
FuncInfo info;
|
||||||
|
void* ctx;
|
||||||
|
return LookupFunc(name, info, ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
// ========== 循环状态管理 ==========
|
||||||
|
|
||||||
|
// 进入循环
|
||||||
|
void EnterLoop();
|
||||||
|
|
||||||
|
// 离开循环
|
||||||
|
void ExitLoop();
|
||||||
|
|
||||||
|
// 检查是否在循环内
|
||||||
|
bool InLoop() const;
|
||||||
|
|
||||||
|
// 获取循环嵌套深度
|
||||||
|
int GetLoopDepth() const { return loop_depth_; }
|
||||||
|
|
||||||
|
// ========== 辅助功能 ==========
|
||||||
|
|
||||||
|
// 清空所有作用域和状态
|
||||||
|
void Clear();
|
||||||
|
|
||||||
|
// 获取当前作用域中所有变量名
|
||||||
|
std::vector<std::string> GetCurrentScopeVarNames() const;
|
||||||
|
|
||||||
|
// 获取当前作用域中所有函数名
|
||||||
|
std::vector<std::string> GetCurrentScopeFuncNames() const;
|
||||||
|
|
||||||
|
// 调试:打印符号表内容
|
||||||
|
void Dump() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::unordered_map<std::string, SysYParser::VarDefContext*> table_;
|
// 作用域栈
|
||||||
|
std::stack<ScopeEntry> scopes_;
|
||||||
|
|
||||||
|
// 循环嵌套深度
|
||||||
|
int loop_depth_ = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 类型兼容性检查函数
|
||||||
|
inline bool IsTypeCompatible(SymbolType expected, SymbolType actual) {
|
||||||
|
if (expected == SymbolType::TYPE_UNKNOWN || actual == SymbolType::TYPE_UNKNOWN) {
|
||||||
|
return true; // 未知类型视为兼容
|
||||||
|
}
|
||||||
|
|
||||||
|
// 基本类型兼容规则
|
||||||
|
if (expected == actual) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
// int 可以隐式转换为 float
|
||||||
|
if (expected == SymbolType::TYPE_FLOAT && actual == SymbolType::TYPE_INT) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // SYMBOL_TABLE_H
|
||||||
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"name": "nudt-compiler-cpp",
|
||||||
|
"lockfileVersion": 2,
|
||||||
|
"requires": true,
|
||||||
|
"packages": {}
|
||||||
|
}
|
||||||
File diff suppressed because one or more lines are too long
@ -0,0 +1,3 @@
|
|||||||
|
This project is dual-licensed under the Unlicense and MIT licenses.
|
||||||
|
|
||||||
|
You may use this code under the terms of either license.
|
||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -0,0 +1,46 @@
|
|||||||
|
# `@img/sharp-libvips-linux-x64`
|
||||||
|
|
||||||
|
Prebuilt libvips and dependencies for use with sharp on Linux (glibc) x64.
|
||||||
|
|
||||||
|
## Licensing
|
||||||
|
|
||||||
|
This software contains third-party libraries
|
||||||
|
used under the terms of the following licences:
|
||||||
|
|
||||||
|
| Library | Used under the terms of |
|
||||||
|
|---------------|-----------------------------------------------------------------------------------------------------------|
|
||||||
|
| aom | BSD 2-Clause + [Alliance for Open Media Patent License 1.0](https://aomedia.org/license/patent-license/) |
|
||||||
|
| cairo | Mozilla Public License 2.0 |
|
||||||
|
| cgif | MIT Licence |
|
||||||
|
| expat | MIT Licence |
|
||||||
|
| fontconfig | [fontconfig Licence](https://gitlab.freedesktop.org/fontconfig/fontconfig/blob/main/COPYING) (BSD-like) |
|
||||||
|
| freetype | [freetype Licence](https://git.savannah.gnu.org/cgit/freetype/freetype2.git/tree/docs/FTL.TXT) (BSD-like) |
|
||||||
|
| fribidi | LGPLv3 |
|
||||||
|
| glib | LGPLv3 |
|
||||||
|
| harfbuzz | MIT Licence |
|
||||||
|
| highway | Apache-2.0 License, BSD 3-Clause |
|
||||||
|
| lcms | MIT Licence |
|
||||||
|
| libarchive | BSD 2-Clause |
|
||||||
|
| libexif | LGPLv3 |
|
||||||
|
| libffi | MIT Licence |
|
||||||
|
| libheif | LGPLv3 |
|
||||||
|
| libimagequant | [BSD 2-Clause](https://github.com/lovell/libimagequant/blob/main/COPYRIGHT) |
|
||||||
|
| libnsgif | MIT Licence |
|
||||||
|
| libpng | [libpng License](https://github.com/pnggroup/libpng/blob/master/LICENSE) |
|
||||||
|
| librsvg | LGPLv3 |
|
||||||
|
| libspng | [BSD 2-Clause, libpng License](https://github.com/randy408/libspng/blob/master/LICENSE) |
|
||||||
|
| libtiff | [libtiff License](https://gitlab.com/libtiff/libtiff/blob/master/LICENSE.md) (BSD-like) |
|
||||||
|
| libvips | LGPLv3 |
|
||||||
|
| libwebp | New BSD License |
|
||||||
|
| libxml2 | MIT Licence |
|
||||||
|
| mozjpeg | [zlib License, IJG License, BSD-3-Clause](https://github.com/mozilla/mozjpeg/blob/master/LICENSE.md) |
|
||||||
|
| pango | LGPLv3 |
|
||||||
|
| pixman | MIT Licence |
|
||||||
|
| proxy-libintl | LGPLv3 |
|
||||||
|
| zlib-ng | [zlib Licence](https://github.com/zlib-ng/zlib-ng/blob/develop/LICENSE.md) |
|
||||||
|
|
||||||
|
Use of libraries under the terms of the LGPLv3 is via the
|
||||||
|
"any later version" clause of the LGPLv2 or LGPLv2.1.
|
||||||
|
|
||||||
|
Please report any errors or omissions via
|
||||||
|
https://github.com/lovell/sharp-libvips/issues/new
|
||||||
@ -0,0 +1,221 @@
|
|||||||
|
/* glibconfig.h
|
||||||
|
*
|
||||||
|
* This is a generated file. Please modify 'glibconfig.h.in'
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GLIBCONFIG_H__
|
||||||
|
#define __GLIBCONFIG_H__
|
||||||
|
|
||||||
|
#include <glib/gmacros.h>
|
||||||
|
|
||||||
|
#include <limits.h>
|
||||||
|
#include <float.h>
|
||||||
|
#define GLIB_HAVE_ALLOCA_H
|
||||||
|
|
||||||
|
#define GLIB_STATIC_COMPILATION 1
|
||||||
|
#define GOBJECT_STATIC_COMPILATION 1
|
||||||
|
#define GIO_STATIC_COMPILATION 1
|
||||||
|
#define GMODULE_STATIC_COMPILATION 1
|
||||||
|
#define GI_STATIC_COMPILATION 1
|
||||||
|
#define G_INTL_STATIC_COMPILATION 1
|
||||||
|
#define FFI_STATIC_BUILD 1
|
||||||
|
|
||||||
|
/* Specifies that GLib's g_print*() functions wrap the
|
||||||
|
* system printf functions. This is useful to know, for example,
|
||||||
|
* when using glibc's register_printf_function().
|
||||||
|
*/
|
||||||
|
#define GLIB_USING_SYSTEM_PRINTF
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
#define G_MINFLOAT FLT_MIN
|
||||||
|
#define G_MAXFLOAT FLT_MAX
|
||||||
|
#define G_MINDOUBLE DBL_MIN
|
||||||
|
#define G_MAXDOUBLE DBL_MAX
|
||||||
|
#define G_MINSHORT SHRT_MIN
|
||||||
|
#define G_MAXSHORT SHRT_MAX
|
||||||
|
#define G_MAXUSHORT USHRT_MAX
|
||||||
|
#define G_MININT INT_MIN
|
||||||
|
#define G_MAXINT INT_MAX
|
||||||
|
#define G_MAXUINT UINT_MAX
|
||||||
|
#define G_MINLONG LONG_MIN
|
||||||
|
#define G_MAXLONG LONG_MAX
|
||||||
|
#define G_MAXULONG ULONG_MAX
|
||||||
|
|
||||||
|
typedef signed char gint8;
|
||||||
|
typedef unsigned char guint8;
|
||||||
|
|
||||||
|
typedef signed short gint16;
|
||||||
|
typedef unsigned short guint16;
|
||||||
|
|
||||||
|
#define G_GINT16_MODIFIER "h"
|
||||||
|
#define G_GINT16_FORMAT "hi"
|
||||||
|
#define G_GUINT16_FORMAT "hu"
|
||||||
|
|
||||||
|
|
||||||
|
typedef signed int gint32;
|
||||||
|
typedef unsigned int guint32;
|
||||||
|
|
||||||
|
#define G_GINT32_MODIFIER ""
|
||||||
|
#define G_GINT32_FORMAT "i"
|
||||||
|
#define G_GUINT32_FORMAT "u"
|
||||||
|
|
||||||
|
|
||||||
|
#define G_HAVE_GINT64 1 /* deprecated, always true */
|
||||||
|
|
||||||
|
typedef signed long gint64;
|
||||||
|
typedef unsigned long guint64;
|
||||||
|
|
||||||
|
#define G_GINT64_CONSTANT(val) (val##L)
|
||||||
|
#define G_GUINT64_CONSTANT(val) (val##UL)
|
||||||
|
|
||||||
|
#define G_GINT64_MODIFIER "l"
|
||||||
|
#define G_GINT64_FORMAT "li"
|
||||||
|
#define G_GUINT64_FORMAT "lu"
|
||||||
|
|
||||||
|
|
||||||
|
#define GLIB_SIZEOF_VOID_P 8
|
||||||
|
#define GLIB_SIZEOF_LONG 8
|
||||||
|
#define GLIB_SIZEOF_SIZE_T 8
|
||||||
|
#define GLIB_SIZEOF_SSIZE_T 8
|
||||||
|
|
||||||
|
typedef signed long gssize;
|
||||||
|
typedef unsigned long gsize;
|
||||||
|
#define G_GSIZE_MODIFIER "l"
|
||||||
|
#define G_GSSIZE_MODIFIER "l"
|
||||||
|
#define G_GSIZE_FORMAT "lu"
|
||||||
|
#define G_GSSIZE_FORMAT "li"
|
||||||
|
|
||||||
|
#define G_MAXSIZE G_MAXULONG
|
||||||
|
#define G_MINSSIZE G_MINLONG
|
||||||
|
#define G_MAXSSIZE G_MAXLONG
|
||||||
|
|
||||||
|
typedef gint64 goffset;
|
||||||
|
#define G_MINOFFSET G_MININT64
|
||||||
|
#define G_MAXOFFSET G_MAXINT64
|
||||||
|
|
||||||
|
#define G_GOFFSET_MODIFIER G_GINT64_MODIFIER
|
||||||
|
#define G_GOFFSET_FORMAT G_GINT64_FORMAT
|
||||||
|
#define G_GOFFSET_CONSTANT(val) G_GINT64_CONSTANT(val)
|
||||||
|
|
||||||
|
#define G_POLLFD_FORMAT "%d"
|
||||||
|
|
||||||
|
#define GPOINTER_TO_INT(p) ((gint) (glong) (p))
|
||||||
|
#define GPOINTER_TO_UINT(p) ((guint) (gulong) (p))
|
||||||
|
|
||||||
|
#define GINT_TO_POINTER(i) ((gpointer) (glong) (i))
|
||||||
|
#define GUINT_TO_POINTER(u) ((gpointer) (gulong) (u))
|
||||||
|
|
||||||
|
typedef signed long gintptr;
|
||||||
|
typedef unsigned long guintptr;
|
||||||
|
|
||||||
|
#define G_GINTPTR_MODIFIER "l"
|
||||||
|
#define G_GINTPTR_FORMAT "li"
|
||||||
|
#define G_GUINTPTR_FORMAT "lu"
|
||||||
|
|
||||||
|
#define GLIB_MAJOR_VERSION 2
|
||||||
|
#define GLIB_MINOR_VERSION 86
|
||||||
|
#define GLIB_MICRO_VERSION 1
|
||||||
|
|
||||||
|
#define G_OS_UNIX
|
||||||
|
|
||||||
|
#define G_VA_COPY va_copy
|
||||||
|
|
||||||
|
#define G_VA_COPY_AS_ARRAY 1
|
||||||
|
|
||||||
|
#define G_HAVE_ISO_VARARGS 1
|
||||||
|
|
||||||
|
/* gcc-2.95.x supports both gnu style and ISO varargs, but if -ansi
|
||||||
|
* is passed ISO vararg support is turned off, and there is no work
|
||||||
|
* around to turn it on, so we unconditionally turn it off.
|
||||||
|
*/
|
||||||
|
#if __GNUC__ == 2 && __GNUC_MINOR__ == 95
|
||||||
|
# undef G_HAVE_ISO_VARARGS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define G_HAVE_GROWING_STACK 0
|
||||||
|
|
||||||
|
#ifndef _MSC_VER
|
||||||
|
# define G_HAVE_GNUC_VARARGS 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)
|
||||||
|
#define G_GNUC_INTERNAL __attribute__((visibility("hidden")))
|
||||||
|
#elif defined(__SUNPRO_C) && (__SUNPRO_C >= 0x550)
|
||||||
|
#define G_GNUC_INTERNAL __hidden
|
||||||
|
#elif defined (__GNUC__) && defined (G_HAVE_GNUC_VISIBILITY)
|
||||||
|
#define G_GNUC_INTERNAL __attribute__((visibility("hidden")))
|
||||||
|
#else
|
||||||
|
#define G_GNUC_INTERNAL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define G_THREADS_ENABLED
|
||||||
|
#define G_THREADS_IMPL_POSIX
|
||||||
|
|
||||||
|
#define G_ATOMIC_LOCK_FREE
|
||||||
|
|
||||||
|
#define GINT16_TO_LE(val) ((gint16) (val))
|
||||||
|
#define GUINT16_TO_LE(val) ((guint16) (val))
|
||||||
|
#define GINT16_TO_BE(val) ((gint16) GUINT16_SWAP_LE_BE (val))
|
||||||
|
#define GUINT16_TO_BE(val) (GUINT16_SWAP_LE_BE (val))
|
||||||
|
|
||||||
|
#define GINT32_TO_LE(val) ((gint32) (val))
|
||||||
|
#define GUINT32_TO_LE(val) ((guint32) (val))
|
||||||
|
#define GINT32_TO_BE(val) ((gint32) GUINT32_SWAP_LE_BE (val))
|
||||||
|
#define GUINT32_TO_BE(val) (GUINT32_SWAP_LE_BE (val))
|
||||||
|
|
||||||
|
#define GINT64_TO_LE(val) ((gint64) (val))
|
||||||
|
#define GUINT64_TO_LE(val) ((guint64) (val))
|
||||||
|
#define GINT64_TO_BE(val) ((gint64) GUINT64_SWAP_LE_BE (val))
|
||||||
|
#define GUINT64_TO_BE(val) (GUINT64_SWAP_LE_BE (val))
|
||||||
|
|
||||||
|
#define GLONG_TO_LE(val) ((glong) GINT64_TO_LE (val))
|
||||||
|
#define GULONG_TO_LE(val) ((gulong) GUINT64_TO_LE (val))
|
||||||
|
#define GLONG_TO_BE(val) ((glong) GINT64_TO_BE (val))
|
||||||
|
#define GULONG_TO_BE(val) ((gulong) GUINT64_TO_BE (val))
|
||||||
|
#define GINT_TO_LE(val) ((gint) GINT32_TO_LE (val))
|
||||||
|
#define GUINT_TO_LE(val) ((guint) GUINT32_TO_LE (val))
|
||||||
|
#define GINT_TO_BE(val) ((gint) GINT32_TO_BE (val))
|
||||||
|
#define GUINT_TO_BE(val) ((guint) GUINT32_TO_BE (val))
|
||||||
|
#define GSIZE_TO_LE(val) ((gsize) GUINT64_TO_LE (val))
|
||||||
|
#define GSSIZE_TO_LE(val) ((gssize) GINT64_TO_LE (val))
|
||||||
|
#define GSIZE_TO_BE(val) ((gsize) GUINT64_TO_BE (val))
|
||||||
|
#define GSSIZE_TO_BE(val) ((gssize) GINT64_TO_BE (val))
|
||||||
|
#define G_BYTE_ORDER G_LITTLE_ENDIAN
|
||||||
|
|
||||||
|
#define GLIB_SYSDEF_POLLIN =1
|
||||||
|
#define GLIB_SYSDEF_POLLOUT =4
|
||||||
|
#define GLIB_SYSDEF_POLLPRI =2
|
||||||
|
#define GLIB_SYSDEF_POLLHUP =16
|
||||||
|
#define GLIB_SYSDEF_POLLERR =8
|
||||||
|
#define GLIB_SYSDEF_POLLNVAL =32
|
||||||
|
|
||||||
|
/* No way to disable deprecation warnings for macros, so only emit deprecation
|
||||||
|
* warnings on platforms where usage of this macro is broken */
|
||||||
|
#if defined(__APPLE__) || defined(_MSC_VER) || defined(__CYGWIN__)
|
||||||
|
#define G_MODULE_SUFFIX "so" GLIB_DEPRECATED_MACRO_IN_2_76
|
||||||
|
#else
|
||||||
|
#define G_MODULE_SUFFIX "so"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef int GPid;
|
||||||
|
#define G_PID_FORMAT "i"
|
||||||
|
|
||||||
|
#define GLIB_SYSDEF_AF_UNIX 1
|
||||||
|
#define GLIB_SYSDEF_AF_INET 2
|
||||||
|
#define GLIB_SYSDEF_AF_INET6 10
|
||||||
|
|
||||||
|
#define GLIB_SYSDEF_MSG_OOB 1
|
||||||
|
#define GLIB_SYSDEF_MSG_PEEK 2
|
||||||
|
#define GLIB_SYSDEF_MSG_DONTROUTE 4
|
||||||
|
|
||||||
|
#define G_DIR_SEPARATOR '/'
|
||||||
|
#define G_DIR_SEPARATOR_S "/"
|
||||||
|
#define G_SEARCHPATH_SEPARATOR ':'
|
||||||
|
#define G_SEARCHPATH_SEPARATOR_S ":"
|
||||||
|
|
||||||
|
#undef G_HAVE_FREE_SIZED
|
||||||
|
|
||||||
|
G_END_DECLS
|
||||||
|
|
||||||
|
#endif /* __GLIBCONFIG_H__ */
|
||||||
@ -0,0 +1 @@
|
|||||||
|
module.exports = __dirname;
|
||||||
Binary file not shown.
@ -0,0 +1,42 @@
|
|||||||
|
{
|
||||||
|
"name": "@img/sharp-libvips-linux-x64",
|
||||||
|
"version": "1.2.4",
|
||||||
|
"description": "Prebuilt libvips and dependencies for use with sharp on Linux (glibc) x64",
|
||||||
|
"author": "Lovell Fuller <npm@lovell.info>",
|
||||||
|
"homepage": "https://sharp.pixelplumbing.com",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/lovell/sharp-libvips.git",
|
||||||
|
"directory": "npm/linux-x64"
|
||||||
|
},
|
||||||
|
"license": "LGPL-3.0-or-later",
|
||||||
|
"funding": {
|
||||||
|
"url": "https://opencollective.com/libvips"
|
||||||
|
},
|
||||||
|
"preferUnplugged": true,
|
||||||
|
"publishConfig": {
|
||||||
|
"access": "public"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"lib",
|
||||||
|
"versions.json"
|
||||||
|
],
|
||||||
|
"type": "commonjs",
|
||||||
|
"exports": {
|
||||||
|
"./lib": "./lib/index.js",
|
||||||
|
"./package": "./package.json",
|
||||||
|
"./versions": "./versions.json"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"glibc": ">=2.26"
|
||||||
|
},
|
||||||
|
"os": [
|
||||||
|
"linux"
|
||||||
|
],
|
||||||
|
"libc": [
|
||||||
|
"glibc"
|
||||||
|
],
|
||||||
|
"cpu": [
|
||||||
|
"x64"
|
||||||
|
]
|
||||||
|
}
|
||||||
@ -0,0 +1,30 @@
|
|||||||
|
{
|
||||||
|
"aom": "3.13.1",
|
||||||
|
"archive": "3.8.2",
|
||||||
|
"cairo": "1.18.4",
|
||||||
|
"cgif": "0.5.0",
|
||||||
|
"exif": "0.6.25",
|
||||||
|
"expat": "2.7.3",
|
||||||
|
"ffi": "3.5.2",
|
||||||
|
"fontconfig": "2.17.1",
|
||||||
|
"freetype": "2.14.1",
|
||||||
|
"fribidi": "1.0.16",
|
||||||
|
"glib": "2.86.1",
|
||||||
|
"harfbuzz": "12.1.0",
|
||||||
|
"heif": "1.20.2",
|
||||||
|
"highway": "1.3.0",
|
||||||
|
"imagequant": "2.4.1",
|
||||||
|
"lcms": "2.17",
|
||||||
|
"mozjpeg": "0826579",
|
||||||
|
"pango": "1.57.0",
|
||||||
|
"pixman": "0.46.4",
|
||||||
|
"png": "1.6.50",
|
||||||
|
"proxy-libintl": "0.5",
|
||||||
|
"rsvg": "2.61.2",
|
||||||
|
"spng": "0.7.4",
|
||||||
|
"tiff": "4.7.1",
|
||||||
|
"vips": "8.17.3",
|
||||||
|
"webp": "1.6.0",
|
||||||
|
"xml2": "2.15.1",
|
||||||
|
"zlib-ng": "2.2.5"
|
||||||
|
}
|
||||||
@ -0,0 +1,46 @@
|
|||||||
|
# `@img/sharp-libvips-linuxmusl-x64`
|
||||||
|
|
||||||
|
Prebuilt libvips and dependencies for use with sharp on Linux (musl) x64.
|
||||||
|
|
||||||
|
## Licensing
|
||||||
|
|
||||||
|
This software contains third-party libraries
|
||||||
|
used under the terms of the following licences:
|
||||||
|
|
||||||
|
| Library | Used under the terms of |
|
||||||
|
|---------------|-----------------------------------------------------------------------------------------------------------|
|
||||||
|
| aom | BSD 2-Clause + [Alliance for Open Media Patent License 1.0](https://aomedia.org/license/patent-license/) |
|
||||||
|
| cairo | Mozilla Public License 2.0 |
|
||||||
|
| cgif | MIT Licence |
|
||||||
|
| expat | MIT Licence |
|
||||||
|
| fontconfig | [fontconfig Licence](https://gitlab.freedesktop.org/fontconfig/fontconfig/blob/main/COPYING) (BSD-like) |
|
||||||
|
| freetype | [freetype Licence](https://git.savannah.gnu.org/cgit/freetype/freetype2.git/tree/docs/FTL.TXT) (BSD-like) |
|
||||||
|
| fribidi | LGPLv3 |
|
||||||
|
| glib | LGPLv3 |
|
||||||
|
| harfbuzz | MIT Licence |
|
||||||
|
| highway | Apache-2.0 License, BSD 3-Clause |
|
||||||
|
| lcms | MIT Licence |
|
||||||
|
| libarchive | BSD 2-Clause |
|
||||||
|
| libexif | LGPLv3 |
|
||||||
|
| libffi | MIT Licence |
|
||||||
|
| libheif | LGPLv3 |
|
||||||
|
| libimagequant | [BSD 2-Clause](https://github.com/lovell/libimagequant/blob/main/COPYRIGHT) |
|
||||||
|
| libnsgif | MIT Licence |
|
||||||
|
| libpng | [libpng License](https://github.com/pnggroup/libpng/blob/master/LICENSE) |
|
||||||
|
| librsvg | LGPLv3 |
|
||||||
|
| libspng | [BSD 2-Clause, libpng License](https://github.com/randy408/libspng/blob/master/LICENSE) |
|
||||||
|
| libtiff | [libtiff License](https://gitlab.com/libtiff/libtiff/blob/master/LICENSE.md) (BSD-like) |
|
||||||
|
| libvips | LGPLv3 |
|
||||||
|
| libwebp | New BSD License |
|
||||||
|
| libxml2 | MIT Licence |
|
||||||
|
| mozjpeg | [zlib License, IJG License, BSD-3-Clause](https://github.com/mozilla/mozjpeg/blob/master/LICENSE.md) |
|
||||||
|
| pango | LGPLv3 |
|
||||||
|
| pixman | MIT Licence |
|
||||||
|
| proxy-libintl | LGPLv3 |
|
||||||
|
| zlib-ng | [zlib Licence](https://github.com/zlib-ng/zlib-ng/blob/develop/LICENSE.md) |
|
||||||
|
|
||||||
|
Use of libraries under the terms of the LGPLv3 is via the
|
||||||
|
"any later version" clause of the LGPLv2 or LGPLv2.1.
|
||||||
|
|
||||||
|
Please report any errors or omissions via
|
||||||
|
https://github.com/lovell/sharp-libvips/issues/new
|
||||||
221
node_modules/@img/sharp-libvips-linuxmusl-x64/lib/glib-2.0/include/glibconfig.h
generated
vendored
221
node_modules/@img/sharp-libvips-linuxmusl-x64/lib/glib-2.0/include/glibconfig.h
generated
vendored
@ -0,0 +1,221 @@
|
|||||||
|
/* glibconfig.h
|
||||||
|
*
|
||||||
|
* This is a generated file. Please modify 'glibconfig.h.in'
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef __GLIBCONFIG_H__
|
||||||
|
#define __GLIBCONFIG_H__
|
||||||
|
|
||||||
|
#include <glib/gmacros.h>
|
||||||
|
|
||||||
|
#include <limits.h>
|
||||||
|
#include <float.h>
|
||||||
|
#define GLIB_HAVE_ALLOCA_H
|
||||||
|
|
||||||
|
#define GLIB_STATIC_COMPILATION 1
|
||||||
|
#define GOBJECT_STATIC_COMPILATION 1
|
||||||
|
#define GIO_STATIC_COMPILATION 1
|
||||||
|
#define GMODULE_STATIC_COMPILATION 1
|
||||||
|
#define GI_STATIC_COMPILATION 1
|
||||||
|
#define G_INTL_STATIC_COMPILATION 1
|
||||||
|
#define FFI_STATIC_BUILD 1
|
||||||
|
|
||||||
|
/* Specifies that GLib's g_print*() functions wrap the
|
||||||
|
* system printf functions. This is useful to know, for example,
|
||||||
|
* when using glibc's register_printf_function().
|
||||||
|
*/
|
||||||
|
#define GLIB_USING_SYSTEM_PRINTF
|
||||||
|
|
||||||
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
#define G_MINFLOAT FLT_MIN
|
||||||
|
#define G_MAXFLOAT FLT_MAX
|
||||||
|
#define G_MINDOUBLE DBL_MIN
|
||||||
|
#define G_MAXDOUBLE DBL_MAX
|
||||||
|
#define G_MINSHORT SHRT_MIN
|
||||||
|
#define G_MAXSHORT SHRT_MAX
|
||||||
|
#define G_MAXUSHORT USHRT_MAX
|
||||||
|
#define G_MININT INT_MIN
|
||||||
|
#define G_MAXINT INT_MAX
|
||||||
|
#define G_MAXUINT UINT_MAX
|
||||||
|
#define G_MINLONG LONG_MIN
|
||||||
|
#define G_MAXLONG LONG_MAX
|
||||||
|
#define G_MAXULONG ULONG_MAX
|
||||||
|
|
||||||
|
typedef signed char gint8;
|
||||||
|
typedef unsigned char guint8;
|
||||||
|
|
||||||
|
typedef signed short gint16;
|
||||||
|
typedef unsigned short guint16;
|
||||||
|
|
||||||
|
#define G_GINT16_MODIFIER "h"
|
||||||
|
#define G_GINT16_FORMAT "hi"
|
||||||
|
#define G_GUINT16_FORMAT "hu"
|
||||||
|
|
||||||
|
|
||||||
|
typedef signed int gint32;
|
||||||
|
typedef unsigned int guint32;
|
||||||
|
|
||||||
|
#define G_GINT32_MODIFIER ""
|
||||||
|
#define G_GINT32_FORMAT "i"
|
||||||
|
#define G_GUINT32_FORMAT "u"
|
||||||
|
|
||||||
|
|
||||||
|
#define G_HAVE_GINT64 1 /* deprecated, always true */
|
||||||
|
|
||||||
|
typedef signed long gint64;
|
||||||
|
typedef unsigned long guint64;
|
||||||
|
|
||||||
|
#define G_GINT64_CONSTANT(val) (val##L)
|
||||||
|
#define G_GUINT64_CONSTANT(val) (val##UL)
|
||||||
|
|
||||||
|
#define G_GINT64_MODIFIER "l"
|
||||||
|
#define G_GINT64_FORMAT "li"
|
||||||
|
#define G_GUINT64_FORMAT "lu"
|
||||||
|
|
||||||
|
|
||||||
|
#define GLIB_SIZEOF_VOID_P 8
|
||||||
|
#define GLIB_SIZEOF_LONG 8
|
||||||
|
#define GLIB_SIZEOF_SIZE_T 8
|
||||||
|
#define GLIB_SIZEOF_SSIZE_T 8
|
||||||
|
|
||||||
|
typedef signed long gssize;
|
||||||
|
typedef unsigned long gsize;
|
||||||
|
#define G_GSIZE_MODIFIER "l"
|
||||||
|
#define G_GSSIZE_MODIFIER "l"
|
||||||
|
#define G_GSIZE_FORMAT "lu"
|
||||||
|
#define G_GSSIZE_FORMAT "li"
|
||||||
|
|
||||||
|
#define G_MAXSIZE G_MAXULONG
|
||||||
|
#define G_MINSSIZE G_MINLONG
|
||||||
|
#define G_MAXSSIZE G_MAXLONG
|
||||||
|
|
||||||
|
typedef gint64 goffset;
|
||||||
|
#define G_MINOFFSET G_MININT64
|
||||||
|
#define G_MAXOFFSET G_MAXINT64
|
||||||
|
|
||||||
|
#define G_GOFFSET_MODIFIER G_GINT64_MODIFIER
|
||||||
|
#define G_GOFFSET_FORMAT G_GINT64_FORMAT
|
||||||
|
#define G_GOFFSET_CONSTANT(val) G_GINT64_CONSTANT(val)
|
||||||
|
|
||||||
|
#define G_POLLFD_FORMAT "%d"
|
||||||
|
|
||||||
|
#define GPOINTER_TO_INT(p) ((gint) (glong) (p))
|
||||||
|
#define GPOINTER_TO_UINT(p) ((guint) (gulong) (p))
|
||||||
|
|
||||||
|
#define GINT_TO_POINTER(i) ((gpointer) (glong) (i))
|
||||||
|
#define GUINT_TO_POINTER(u) ((gpointer) (gulong) (u))
|
||||||
|
|
||||||
|
typedef signed long gintptr;
|
||||||
|
typedef unsigned long guintptr;
|
||||||
|
|
||||||
|
#define G_GINTPTR_MODIFIER "l"
|
||||||
|
#define G_GINTPTR_FORMAT "li"
|
||||||
|
#define G_GUINTPTR_FORMAT "lu"
|
||||||
|
|
||||||
|
#define GLIB_MAJOR_VERSION 2
|
||||||
|
#define GLIB_MINOR_VERSION 86
|
||||||
|
#define GLIB_MICRO_VERSION 1
|
||||||
|
|
||||||
|
#define G_OS_UNIX
|
||||||
|
|
||||||
|
#define G_VA_COPY va_copy
|
||||||
|
|
||||||
|
#define G_VA_COPY_AS_ARRAY 1
|
||||||
|
|
||||||
|
#define G_HAVE_ISO_VARARGS 1
|
||||||
|
|
||||||
|
/* gcc-2.95.x supports both gnu style and ISO varargs, but if -ansi
|
||||||
|
* is passed ISO vararg support is turned off, and there is no work
|
||||||
|
* around to turn it on, so we unconditionally turn it off.
|
||||||
|
*/
|
||||||
|
#if __GNUC__ == 2 && __GNUC_MINOR__ == 95
|
||||||
|
# undef G_HAVE_ISO_VARARGS
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define G_HAVE_GROWING_STACK 0
|
||||||
|
|
||||||
|
#ifndef _MSC_VER
|
||||||
|
# define G_HAVE_GNUC_VARARGS 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(__SUNPRO_C) && (__SUNPRO_C >= 0x590)
|
||||||
|
#define G_GNUC_INTERNAL __attribute__((visibility("hidden")))
|
||||||
|
#elif defined(__SUNPRO_C) && (__SUNPRO_C >= 0x550)
|
||||||
|
#define G_GNUC_INTERNAL __hidden
|
||||||
|
#elif defined (__GNUC__) && defined (G_HAVE_GNUC_VISIBILITY)
|
||||||
|
#define G_GNUC_INTERNAL __attribute__((visibility("hidden")))
|
||||||
|
#else
|
||||||
|
#define G_GNUC_INTERNAL
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define G_THREADS_ENABLED
|
||||||
|
#define G_THREADS_IMPL_POSIX
|
||||||
|
|
||||||
|
#define G_ATOMIC_LOCK_FREE
|
||||||
|
|
||||||
|
#define GINT16_TO_LE(val) ((gint16) (val))
|
||||||
|
#define GUINT16_TO_LE(val) ((guint16) (val))
|
||||||
|
#define GINT16_TO_BE(val) ((gint16) GUINT16_SWAP_LE_BE (val))
|
||||||
|
#define GUINT16_TO_BE(val) (GUINT16_SWAP_LE_BE (val))
|
||||||
|
|
||||||
|
#define GINT32_TO_LE(val) ((gint32) (val))
|
||||||
|
#define GUINT32_TO_LE(val) ((guint32) (val))
|
||||||
|
#define GINT32_TO_BE(val) ((gint32) GUINT32_SWAP_LE_BE (val))
|
||||||
|
#define GUINT32_TO_BE(val) (GUINT32_SWAP_LE_BE (val))
|
||||||
|
|
||||||
|
#define GINT64_TO_LE(val) ((gint64) (val))
|
||||||
|
#define GUINT64_TO_LE(val) ((guint64) (val))
|
||||||
|
#define GINT64_TO_BE(val) ((gint64) GUINT64_SWAP_LE_BE (val))
|
||||||
|
#define GUINT64_TO_BE(val) (GUINT64_SWAP_LE_BE (val))
|
||||||
|
|
||||||
|
#define GLONG_TO_LE(val) ((glong) GINT64_TO_LE (val))
|
||||||
|
#define GULONG_TO_LE(val) ((gulong) GUINT64_TO_LE (val))
|
||||||
|
#define GLONG_TO_BE(val) ((glong) GINT64_TO_BE (val))
|
||||||
|
#define GULONG_TO_BE(val) ((gulong) GUINT64_TO_BE (val))
|
||||||
|
#define GINT_TO_LE(val) ((gint) GINT32_TO_LE (val))
|
||||||
|
#define GUINT_TO_LE(val) ((guint) GUINT32_TO_LE (val))
|
||||||
|
#define GINT_TO_BE(val) ((gint) GINT32_TO_BE (val))
|
||||||
|
#define GUINT_TO_BE(val) ((guint) GUINT32_TO_BE (val))
|
||||||
|
#define GSIZE_TO_LE(val) ((gsize) GUINT64_TO_LE (val))
|
||||||
|
#define GSSIZE_TO_LE(val) ((gssize) GINT64_TO_LE (val))
|
||||||
|
#define GSIZE_TO_BE(val) ((gsize) GUINT64_TO_BE (val))
|
||||||
|
#define GSSIZE_TO_BE(val) ((gssize) GINT64_TO_BE (val))
|
||||||
|
#define G_BYTE_ORDER G_LITTLE_ENDIAN
|
||||||
|
|
||||||
|
#define GLIB_SYSDEF_POLLIN =1
|
||||||
|
#define GLIB_SYSDEF_POLLOUT =4
|
||||||
|
#define GLIB_SYSDEF_POLLPRI =2
|
||||||
|
#define GLIB_SYSDEF_POLLHUP =16
|
||||||
|
#define GLIB_SYSDEF_POLLERR =8
|
||||||
|
#define GLIB_SYSDEF_POLLNVAL =32
|
||||||
|
|
||||||
|
/* No way to disable deprecation warnings for macros, so only emit deprecation
|
||||||
|
* warnings on platforms where usage of this macro is broken */
|
||||||
|
#if defined(__APPLE__) || defined(_MSC_VER) || defined(__CYGWIN__)
|
||||||
|
#define G_MODULE_SUFFIX "so" GLIB_DEPRECATED_MACRO_IN_2_76
|
||||||
|
#else
|
||||||
|
#define G_MODULE_SUFFIX "so"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
typedef int GPid;
|
||||||
|
#define G_PID_FORMAT "i"
|
||||||
|
|
||||||
|
#define GLIB_SYSDEF_AF_UNIX 1
|
||||||
|
#define GLIB_SYSDEF_AF_INET 2
|
||||||
|
#define GLIB_SYSDEF_AF_INET6 10
|
||||||
|
|
||||||
|
#define GLIB_SYSDEF_MSG_OOB 1
|
||||||
|
#define GLIB_SYSDEF_MSG_PEEK 2
|
||||||
|
#define GLIB_SYSDEF_MSG_DONTROUTE 4
|
||||||
|
|
||||||
|
#define G_DIR_SEPARATOR '/'
|
||||||
|
#define G_DIR_SEPARATOR_S "/"
|
||||||
|
#define G_SEARCHPATH_SEPARATOR ':'
|
||||||
|
#define G_SEARCHPATH_SEPARATOR_S ":"
|
||||||
|
|
||||||
|
#undef G_HAVE_FREE_SIZED
|
||||||
|
|
||||||
|
G_END_DECLS
|
||||||
|
|
||||||
|
#endif /* __GLIBCONFIG_H__ */
|
||||||
@ -0,0 +1 @@
|
|||||||
|
module.exports = __dirname;
|
||||||
Binary file not shown.
@ -0,0 +1,42 @@
|
|||||||
|
{
|
||||||
|
"name": "@img/sharp-libvips-linuxmusl-x64",
|
||||||
|
"version": "1.2.4",
|
||||||
|
"description": "Prebuilt libvips and dependencies for use with sharp on Linux (musl) x64",
|
||||||
|
"author": "Lovell Fuller <npm@lovell.info>",
|
||||||
|
"homepage": "https://sharp.pixelplumbing.com",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/lovell/sharp-libvips.git",
|
||||||
|
"directory": "npm/linuxmusl-x64"
|
||||||
|
},
|
||||||
|
"license": "LGPL-3.0-or-later",
|
||||||
|
"funding": {
|
||||||
|
"url": "https://opencollective.com/libvips"
|
||||||
|
},
|
||||||
|
"preferUnplugged": true,
|
||||||
|
"publishConfig": {
|
||||||
|
"access": "public"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"lib",
|
||||||
|
"versions.json"
|
||||||
|
],
|
||||||
|
"type": "commonjs",
|
||||||
|
"exports": {
|
||||||
|
"./lib": "./lib/index.js",
|
||||||
|
"./package": "./package.json",
|
||||||
|
"./versions": "./versions.json"
|
||||||
|
},
|
||||||
|
"config": {
|
||||||
|
"musl": ">=1.2.2"
|
||||||
|
},
|
||||||
|
"os": [
|
||||||
|
"linux"
|
||||||
|
],
|
||||||
|
"libc": [
|
||||||
|
"musl"
|
||||||
|
],
|
||||||
|
"cpu": [
|
||||||
|
"x64"
|
||||||
|
]
|
||||||
|
}
|
||||||
@ -0,0 +1,30 @@
|
|||||||
|
{
|
||||||
|
"aom": "3.13.1",
|
||||||
|
"archive": "3.8.2",
|
||||||
|
"cairo": "1.18.4",
|
||||||
|
"cgif": "0.5.0",
|
||||||
|
"exif": "0.6.25",
|
||||||
|
"expat": "2.7.3",
|
||||||
|
"ffi": "3.5.2",
|
||||||
|
"fontconfig": "2.17.1",
|
||||||
|
"freetype": "2.14.1",
|
||||||
|
"fribidi": "1.0.16",
|
||||||
|
"glib": "2.86.1",
|
||||||
|
"harfbuzz": "12.1.0",
|
||||||
|
"heif": "1.20.2",
|
||||||
|
"highway": "1.3.0",
|
||||||
|
"imagequant": "2.4.1",
|
||||||
|
"lcms": "2.17",
|
||||||
|
"mozjpeg": "0826579",
|
||||||
|
"pango": "1.57.0",
|
||||||
|
"pixman": "0.46.4",
|
||||||
|
"png": "1.6.50",
|
||||||
|
"proxy-libintl": "0.5",
|
||||||
|
"rsvg": "2.61.2",
|
||||||
|
"spng": "0.7.4",
|
||||||
|
"tiff": "4.7.1",
|
||||||
|
"vips": "8.17.3",
|
||||||
|
"webp": "1.6.0",
|
||||||
|
"xml2": "2.15.1",
|
||||||
|
"zlib-ng": "2.2.5"
|
||||||
|
}
|
||||||
@ -0,0 +1,6 @@
|
|||||||
|
{
|
||||||
|
"name": "nudt-compiler-cpp",
|
||||||
|
"lockfileVersion": 2,
|
||||||
|
"requires": true,
|
||||||
|
"packages": {}
|
||||||
|
}
|
||||||
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
@ -0,0 +1,39 @@
|
|||||||
|
import os
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
COMPILER = "./build/bin/compiler"
|
||||||
|
TEST_DIR = "./test/test_case/performance"
|
||||||
|
|
||||||
|
pass_cnt = 0
|
||||||
|
fail_cnt = 0
|
||||||
|
|
||||||
|
print("===== SysY Batch Test Start =====")
|
||||||
|
|
||||||
|
for file in os.listdir(TEST_DIR):
|
||||||
|
if not file.endswith(".sy"):
|
||||||
|
continue
|
||||||
|
|
||||||
|
path = os.path.join(TEST_DIR, file)
|
||||||
|
print(f"[TEST] {file} ... ", end="")
|
||||||
|
|
||||||
|
result = subprocess.run(
|
||||||
|
[COMPILER, "--emit-parse-tree", path],
|
||||||
|
stdout=subprocess.DEVNULL,
|
||||||
|
stderr=subprocess.PIPE
|
||||||
|
)
|
||||||
|
|
||||||
|
if result.returncode == 0:
|
||||||
|
print("PASS")
|
||||||
|
pass_cnt += 1
|
||||||
|
else:
|
||||||
|
print("FAIL")
|
||||||
|
fail_cnt += 1
|
||||||
|
print("---- Error ----")
|
||||||
|
print(result.stderr.decode())
|
||||||
|
print("---------------")
|
||||||
|
|
||||||
|
print("===============================")
|
||||||
|
print(f"Total: {pass_cnt + fail_cnt}")
|
||||||
|
print(f"PASS : {pass_cnt}")
|
||||||
|
print(f"FAIL : {fail_cnt}")
|
||||||
|
print("===============================")
|
||||||
@ -0,0 +1,7 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
|
||||||
|
#include "SysYBaseVisitor.h"
|
||||||
|
|
||||||
|
|
||||||
@ -0,0 +1,148 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
|
#include "antlr4-runtime.h"
|
||||||
|
#include "SysYVisitor.h"
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class provides an empty implementation of SysYVisitor, which can be
|
||||||
|
* extended to create a visitor which only needs to handle a subset of the available methods.
|
||||||
|
*/
|
||||||
|
class SysYBaseVisitor : public SysYVisitor {
|
||||||
|
public:
|
||||||
|
|
||||||
|
virtual std::any visitCompUnit(SysYParser::CompUnitContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitDecl(SysYParser::DeclContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitConstDecl(SysYParser::ConstDeclContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitConstDef(SysYParser::ConstDefContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitConstInitValue(SysYParser::ConstInitValueContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitVarDecl(SysYParser::VarDeclContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitBtype(SysYParser::BtypeContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitVarDef(SysYParser::VarDefContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitInitValue(SysYParser::InitValueContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitFuncDef(SysYParser::FuncDefContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitFuncType(SysYParser::FuncTypeContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitFuncFParams(SysYParser::FuncFParamsContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitFuncFParam(SysYParser::FuncFParamContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitBlockStmt(SysYParser::BlockStmtContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitBlockItem(SysYParser::BlockItemContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitStmt(SysYParser::StmtContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitReturnStmt(SysYParser::ReturnStmtContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitExp(SysYParser::ExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitCond(SysYParser::CondContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitLValue(SysYParser::LValueContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitPrimaryExp(SysYParser::PrimaryExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitNumber(SysYParser::NumberContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitUnaryExp(SysYParser::UnaryExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitUnaryOp(SysYParser::UnaryOpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitFuncRParams(SysYParser::FuncRParamsContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitMulExp(SysYParser::MulExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitAddExp(SysYParser::AddExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitRelExp(SysYParser::RelExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitEqExp(SysYParser::EqExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitLAndExp(SysYParser::LAndExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitLOrExp(SysYParser::LOrExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual std::any visitConstExp(SysYParser::ConstExpContext *ctx) override {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
@ -0,0 +1,271 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
|
||||||
|
#include "SysYLexer.h"
|
||||||
|
|
||||||
|
|
||||||
|
using namespace antlr4;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
using namespace antlr4;
|
||||||
|
|
||||||
|
namespace {
|
||||||
|
|
||||||
|
struct SysYLexerStaticData final {
|
||||||
|
SysYLexerStaticData(std::vector<std::string> ruleNames,
|
||||||
|
std::vector<std::string> channelNames,
|
||||||
|
std::vector<std::string> modeNames,
|
||||||
|
std::vector<std::string> literalNames,
|
||||||
|
std::vector<std::string> symbolicNames)
|
||||||
|
: ruleNames(std::move(ruleNames)), channelNames(std::move(channelNames)),
|
||||||
|
modeNames(std::move(modeNames)), literalNames(std::move(literalNames)),
|
||||||
|
symbolicNames(std::move(symbolicNames)),
|
||||||
|
vocabulary(this->literalNames, this->symbolicNames) {}
|
||||||
|
|
||||||
|
SysYLexerStaticData(const SysYLexerStaticData&) = delete;
|
||||||
|
SysYLexerStaticData(SysYLexerStaticData&&) = delete;
|
||||||
|
SysYLexerStaticData& operator=(const SysYLexerStaticData&) = delete;
|
||||||
|
SysYLexerStaticData& operator=(SysYLexerStaticData&&) = delete;
|
||||||
|
|
||||||
|
std::vector<antlr4::dfa::DFA> decisionToDFA;
|
||||||
|
antlr4::atn::PredictionContextCache sharedContextCache;
|
||||||
|
const std::vector<std::string> ruleNames;
|
||||||
|
const std::vector<std::string> channelNames;
|
||||||
|
const std::vector<std::string> modeNames;
|
||||||
|
const std::vector<std::string> literalNames;
|
||||||
|
const std::vector<std::string> symbolicNames;
|
||||||
|
const antlr4::dfa::Vocabulary vocabulary;
|
||||||
|
antlr4::atn::SerializedATNView serializedATN;
|
||||||
|
std::unique_ptr<antlr4::atn::ATN> atn;
|
||||||
|
};
|
||||||
|
|
||||||
|
::antlr4::internal::OnceFlag sysylexerLexerOnceFlag;
|
||||||
|
#if ANTLR4_USE_THREAD_LOCAL_CACHE
|
||||||
|
static thread_local
|
||||||
|
#endif
|
||||||
|
std::unique_ptr<SysYLexerStaticData> sysylexerLexerStaticData = nullptr;
|
||||||
|
|
||||||
|
void sysylexerLexerInitialize() {
|
||||||
|
#if ANTLR4_USE_THREAD_LOCAL_CACHE
|
||||||
|
if (sysylexerLexerStaticData != nullptr) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
assert(sysylexerLexerStaticData == nullptr);
|
||||||
|
#endif
|
||||||
|
auto staticData = std::make_unique<SysYLexerStaticData>(
|
||||||
|
std::vector<std::string>{
|
||||||
|
"CONST", "INT", "FLOAT", "VOID", "IF", "ELSE", "WHILE", "BREAK", "CONTINUE",
|
||||||
|
"RETURN", "ASSIGN", "EQ", "NE", "LT", "GT", "LE", "GE", "ADD", "SUB",
|
||||||
|
"MUL", "DIV", "MOD", "NOT", "AND", "OR", "LPAREN", "RPAREN", "LBRACK",
|
||||||
|
"RBRACK", "LBRACE", "RBRACE", "COMMA", "SEMICOLON", "ID", "FLITERAL",
|
||||||
|
"ILITERAL", "DEC_INT", "OCT_INT", "HEX_INT", "DECIMAL_FLOAT", "HEX_FLOAT",
|
||||||
|
"EXP", "WS", "LINECOMMENT", "BLOCKCOMMENT"
|
||||||
|
},
|
||||||
|
std::vector<std::string>{
|
||||||
|
"DEFAULT_TOKEN_CHANNEL", "HIDDEN"
|
||||||
|
},
|
||||||
|
std::vector<std::string>{
|
||||||
|
"DEFAULT_MODE"
|
||||||
|
},
|
||||||
|
std::vector<std::string>{
|
||||||
|
"", "'const'", "'int'", "'float'", "'void'", "'if'", "'else'", "'while'",
|
||||||
|
"'break'", "'continue'", "'return'", "'='", "'=='", "'!='", "'<'",
|
||||||
|
"'>'", "'<='", "'>='", "'+'", "'-'", "'*'", "'/'", "'%'", "'!'", "'&&'",
|
||||||
|
"'||'", "'('", "')'", "'['", "']'", "'{'", "'}'", "','", "';'"
|
||||||
|
},
|
||||||
|
std::vector<std::string>{
|
||||||
|
"", "CONST", "INT", "FLOAT", "VOID", "IF", "ELSE", "WHILE", "BREAK",
|
||||||
|
"CONTINUE", "RETURN", "ASSIGN", "EQ", "NE", "LT", "GT", "LE", "GE",
|
||||||
|
"ADD", "SUB", "MUL", "DIV", "MOD", "NOT", "AND", "OR", "LPAREN", "RPAREN",
|
||||||
|
"LBRACK", "RBRACK", "LBRACE", "RBRACE", "COMMA", "SEMICOLON", "ID",
|
||||||
|
"FLITERAL", "ILITERAL", "WS", "LINECOMMENT", "BLOCKCOMMENT"
|
||||||
|
}
|
||||||
|
);
|
||||||
|
static const int32_t serializedATNSegment[] = {
|
||||||
|
4,0,39,353,6,-1,2,0,7,0,2,1,7,1,2,2,7,2,2,3,7,3,2,4,7,4,2,5,7,5,2,6,7,
|
||||||
|
6,2,7,7,7,2,8,7,8,2,9,7,9,2,10,7,10,2,11,7,11,2,12,7,12,2,13,7,13,2,14,
|
||||||
|
7,14,2,15,7,15,2,16,7,16,2,17,7,17,2,18,7,18,2,19,7,19,2,20,7,20,2,21,
|
||||||
|
7,21,2,22,7,22,2,23,7,23,2,24,7,24,2,25,7,25,2,26,7,26,2,27,7,27,2,28,
|
||||||
|
7,28,2,29,7,29,2,30,7,30,2,31,7,31,2,32,7,32,2,33,7,33,2,34,7,34,2,35,
|
||||||
|
7,35,2,36,7,36,2,37,7,37,2,38,7,38,2,39,7,39,2,40,7,40,2,41,7,41,2,42,
|
||||||
|
7,42,2,43,7,43,2,44,7,44,1,0,1,0,1,0,1,0,1,0,1,0,1,1,1,1,1,1,1,1,1,2,
|
||||||
|
1,2,1,2,1,2,1,2,1,2,1,3,1,3,1,3,1,3,1,3,1,4,1,4,1,4,1,5,1,5,1,5,1,5,1,
|
||||||
|
5,1,6,1,6,1,6,1,6,1,6,1,6,1,7,1,7,1,7,1,7,1,7,1,7,1,8,1,8,1,8,1,8,1,8,
|
||||||
|
1,8,1,8,1,8,1,8,1,9,1,9,1,9,1,9,1,9,1,9,1,9,1,10,1,10,1,11,1,11,1,11,
|
||||||
|
1,12,1,12,1,12,1,13,1,13,1,14,1,14,1,15,1,15,1,15,1,16,1,16,1,16,1,17,
|
||||||
|
1,17,1,18,1,18,1,19,1,19,1,20,1,20,1,21,1,21,1,22,1,22,1,23,1,23,1,23,
|
||||||
|
1,24,1,24,1,24,1,25,1,25,1,26,1,26,1,27,1,27,1,28,1,28,1,29,1,29,1,30,
|
||||||
|
1,30,1,31,1,31,1,32,1,32,1,33,1,33,5,33,203,8,33,10,33,12,33,206,9,33,
|
||||||
|
1,34,1,34,3,34,210,8,34,1,35,1,35,1,35,3,35,215,8,35,1,36,1,36,1,36,5,
|
||||||
|
36,220,8,36,10,36,12,36,223,9,36,3,36,225,8,36,1,37,1,37,4,37,229,8,37,
|
||||||
|
11,37,12,37,230,1,38,1,38,1,38,4,38,236,8,38,11,38,12,38,237,1,39,4,39,
|
||||||
|
241,8,39,11,39,12,39,242,1,39,1,39,5,39,247,8,39,10,39,12,39,250,9,39,
|
||||||
|
1,39,3,39,253,8,39,1,39,1,39,4,39,257,8,39,11,39,12,39,258,1,39,3,39,
|
||||||
|
262,8,39,1,39,4,39,265,8,39,11,39,12,39,266,1,39,3,39,270,8,39,1,40,1,
|
||||||
|
40,1,40,4,40,275,8,40,11,40,12,40,276,1,40,1,40,5,40,281,8,40,10,40,12,
|
||||||
|
40,284,9,40,3,40,286,8,40,1,40,1,40,3,40,290,8,40,1,40,4,40,293,8,40,
|
||||||
|
11,40,12,40,294,1,40,1,40,1,40,1,40,4,40,301,8,40,11,40,12,40,302,1,40,
|
||||||
|
1,40,3,40,307,8,40,1,40,4,40,310,8,40,11,40,12,40,311,3,40,314,8,40,1,
|
||||||
|
41,1,41,3,41,318,8,41,1,41,4,41,321,8,41,11,41,12,41,322,1,42,1,42,1,
|
||||||
|
42,1,42,1,43,1,43,1,43,1,43,5,43,333,8,43,10,43,12,43,336,9,43,1,43,1,
|
||||||
|
43,1,44,1,44,1,44,1,44,5,44,344,8,44,10,44,12,44,347,9,44,1,44,1,44,1,
|
||||||
|
44,1,44,1,44,1,345,0,45,1,1,3,2,5,3,7,4,9,5,11,6,13,7,15,8,17,9,19,10,
|
||||||
|
21,11,23,12,25,13,27,14,29,15,31,16,33,17,35,18,37,19,39,20,41,21,43,
|
||||||
|
22,45,23,47,24,49,25,51,26,53,27,55,28,57,29,59,30,61,31,63,32,65,33,
|
||||||
|
67,34,69,35,71,36,73,0,75,0,77,0,79,0,81,0,83,0,85,37,87,38,89,39,1,0,
|
||||||
|
12,3,0,65,90,95,95,97,122,4,0,48,57,65,90,95,95,97,122,1,0,49,57,1,0,
|
||||||
|
48,57,1,0,48,55,2,0,88,88,120,120,3,0,48,57,65,70,97,102,2,0,80,80,112,
|
||||||
|
112,2,0,43,43,45,45,2,0,69,69,101,101,3,0,9,10,13,13,32,32,2,0,10,10,
|
||||||
|
13,13,375,0,1,1,0,0,0,0,3,1,0,0,0,0,5,1,0,0,0,0,7,1,0,0,0,0,9,1,0,0,0,
|
||||||
|
0,11,1,0,0,0,0,13,1,0,0,0,0,15,1,0,0,0,0,17,1,0,0,0,0,19,1,0,0,0,0,21,
|
||||||
|
1,0,0,0,0,23,1,0,0,0,0,25,1,0,0,0,0,27,1,0,0,0,0,29,1,0,0,0,0,31,1,0,
|
||||||
|
0,0,0,33,1,0,0,0,0,35,1,0,0,0,0,37,1,0,0,0,0,39,1,0,0,0,0,41,1,0,0,0,
|
||||||
|
0,43,1,0,0,0,0,45,1,0,0,0,0,47,1,0,0,0,0,49,1,0,0,0,0,51,1,0,0,0,0,53,
|
||||||
|
1,0,0,0,0,55,1,0,0,0,0,57,1,0,0,0,0,59,1,0,0,0,0,61,1,0,0,0,0,63,1,0,
|
||||||
|
0,0,0,65,1,0,0,0,0,67,1,0,0,0,0,69,1,0,0,0,0,71,1,0,0,0,0,85,1,0,0,0,
|
||||||
|
0,87,1,0,0,0,0,89,1,0,0,0,1,91,1,0,0,0,3,97,1,0,0,0,5,101,1,0,0,0,7,107,
|
||||||
|
1,0,0,0,9,112,1,0,0,0,11,115,1,0,0,0,13,120,1,0,0,0,15,126,1,0,0,0,17,
|
||||||
|
132,1,0,0,0,19,141,1,0,0,0,21,148,1,0,0,0,23,150,1,0,0,0,25,153,1,0,0,
|
||||||
|
0,27,156,1,0,0,0,29,158,1,0,0,0,31,160,1,0,0,0,33,163,1,0,0,0,35,166,
|
||||||
|
1,0,0,0,37,168,1,0,0,0,39,170,1,0,0,0,41,172,1,0,0,0,43,174,1,0,0,0,45,
|
||||||
|
176,1,0,0,0,47,178,1,0,0,0,49,181,1,0,0,0,51,184,1,0,0,0,53,186,1,0,0,
|
||||||
|
0,55,188,1,0,0,0,57,190,1,0,0,0,59,192,1,0,0,0,61,194,1,0,0,0,63,196,
|
||||||
|
1,0,0,0,65,198,1,0,0,0,67,200,1,0,0,0,69,209,1,0,0,0,71,214,1,0,0,0,73,
|
||||||
|
224,1,0,0,0,75,226,1,0,0,0,77,232,1,0,0,0,79,269,1,0,0,0,81,313,1,0,0,
|
||||||
|
0,83,315,1,0,0,0,85,324,1,0,0,0,87,328,1,0,0,0,89,339,1,0,0,0,91,92,5,
|
||||||
|
99,0,0,92,93,5,111,0,0,93,94,5,110,0,0,94,95,5,115,0,0,95,96,5,116,0,
|
||||||
|
0,96,2,1,0,0,0,97,98,5,105,0,0,98,99,5,110,0,0,99,100,5,116,0,0,100,4,
|
||||||
|
1,0,0,0,101,102,5,102,0,0,102,103,5,108,0,0,103,104,5,111,0,0,104,105,
|
||||||
|
5,97,0,0,105,106,5,116,0,0,106,6,1,0,0,0,107,108,5,118,0,0,108,109,5,
|
||||||
|
111,0,0,109,110,5,105,0,0,110,111,5,100,0,0,111,8,1,0,0,0,112,113,5,105,
|
||||||
|
0,0,113,114,5,102,0,0,114,10,1,0,0,0,115,116,5,101,0,0,116,117,5,108,
|
||||||
|
0,0,117,118,5,115,0,0,118,119,5,101,0,0,119,12,1,0,0,0,120,121,5,119,
|
||||||
|
0,0,121,122,5,104,0,0,122,123,5,105,0,0,123,124,5,108,0,0,124,125,5,101,
|
||||||
|
0,0,125,14,1,0,0,0,126,127,5,98,0,0,127,128,5,114,0,0,128,129,5,101,0,
|
||||||
|
0,129,130,5,97,0,0,130,131,5,107,0,0,131,16,1,0,0,0,132,133,5,99,0,0,
|
||||||
|
133,134,5,111,0,0,134,135,5,110,0,0,135,136,5,116,0,0,136,137,5,105,0,
|
||||||
|
0,137,138,5,110,0,0,138,139,5,117,0,0,139,140,5,101,0,0,140,18,1,0,0,
|
||||||
|
0,141,142,5,114,0,0,142,143,5,101,0,0,143,144,5,116,0,0,144,145,5,117,
|
||||||
|
0,0,145,146,5,114,0,0,146,147,5,110,0,0,147,20,1,0,0,0,148,149,5,61,0,
|
||||||
|
0,149,22,1,0,0,0,150,151,5,61,0,0,151,152,5,61,0,0,152,24,1,0,0,0,153,
|
||||||
|
154,5,33,0,0,154,155,5,61,0,0,155,26,1,0,0,0,156,157,5,60,0,0,157,28,
|
||||||
|
1,0,0,0,158,159,5,62,0,0,159,30,1,0,0,0,160,161,5,60,0,0,161,162,5,61,
|
||||||
|
0,0,162,32,1,0,0,0,163,164,5,62,0,0,164,165,5,61,0,0,165,34,1,0,0,0,166,
|
||||||
|
167,5,43,0,0,167,36,1,0,0,0,168,169,5,45,0,0,169,38,1,0,0,0,170,171,5,
|
||||||
|
42,0,0,171,40,1,0,0,0,172,173,5,47,0,0,173,42,1,0,0,0,174,175,5,37,0,
|
||||||
|
0,175,44,1,0,0,0,176,177,5,33,0,0,177,46,1,0,0,0,178,179,5,38,0,0,179,
|
||||||
|
180,5,38,0,0,180,48,1,0,0,0,181,182,5,124,0,0,182,183,5,124,0,0,183,50,
|
||||||
|
1,0,0,0,184,185,5,40,0,0,185,52,1,0,0,0,186,187,5,41,0,0,187,54,1,0,0,
|
||||||
|
0,188,189,5,91,0,0,189,56,1,0,0,0,190,191,5,93,0,0,191,58,1,0,0,0,192,
|
||||||
|
193,5,123,0,0,193,60,1,0,0,0,194,195,5,125,0,0,195,62,1,0,0,0,196,197,
|
||||||
|
5,44,0,0,197,64,1,0,0,0,198,199,5,59,0,0,199,66,1,0,0,0,200,204,7,0,0,
|
||||||
|
0,201,203,7,1,0,0,202,201,1,0,0,0,203,206,1,0,0,0,204,202,1,0,0,0,204,
|
||||||
|
205,1,0,0,0,205,68,1,0,0,0,206,204,1,0,0,0,207,210,3,79,39,0,208,210,
|
||||||
|
3,81,40,0,209,207,1,0,0,0,209,208,1,0,0,0,210,70,1,0,0,0,211,215,3,77,
|
||||||
|
38,0,212,215,3,75,37,0,213,215,3,73,36,0,214,211,1,0,0,0,214,212,1,0,
|
||||||
|
0,0,214,213,1,0,0,0,215,72,1,0,0,0,216,225,5,48,0,0,217,221,7,2,0,0,218,
|
||||||
|
220,7,3,0,0,219,218,1,0,0,0,220,223,1,0,0,0,221,219,1,0,0,0,221,222,1,
|
||||||
|
0,0,0,222,225,1,0,0,0,223,221,1,0,0,0,224,216,1,0,0,0,224,217,1,0,0,0,
|
||||||
|
225,74,1,0,0,0,226,228,5,48,0,0,227,229,7,4,0,0,228,227,1,0,0,0,229,230,
|
||||||
|
1,0,0,0,230,228,1,0,0,0,230,231,1,0,0,0,231,76,1,0,0,0,232,233,5,48,0,
|
||||||
|
0,233,235,7,5,0,0,234,236,7,6,0,0,235,234,1,0,0,0,236,237,1,0,0,0,237,
|
||||||
|
235,1,0,0,0,237,238,1,0,0,0,238,78,1,0,0,0,239,241,7,3,0,0,240,239,1,
|
||||||
|
0,0,0,241,242,1,0,0,0,242,240,1,0,0,0,242,243,1,0,0,0,243,244,1,0,0,0,
|
||||||
|
244,248,5,46,0,0,245,247,7,3,0,0,246,245,1,0,0,0,247,250,1,0,0,0,248,
|
||||||
|
246,1,0,0,0,248,249,1,0,0,0,249,252,1,0,0,0,250,248,1,0,0,0,251,253,3,
|
||||||
|
83,41,0,252,251,1,0,0,0,252,253,1,0,0,0,253,270,1,0,0,0,254,256,5,46,
|
||||||
|
0,0,255,257,7,3,0,0,256,255,1,0,0,0,257,258,1,0,0,0,258,256,1,0,0,0,258,
|
||||||
|
259,1,0,0,0,259,261,1,0,0,0,260,262,3,83,41,0,261,260,1,0,0,0,261,262,
|
||||||
|
1,0,0,0,262,270,1,0,0,0,263,265,7,3,0,0,264,263,1,0,0,0,265,266,1,0,0,
|
||||||
|
0,266,264,1,0,0,0,266,267,1,0,0,0,267,268,1,0,0,0,268,270,3,83,41,0,269,
|
||||||
|
240,1,0,0,0,269,254,1,0,0,0,269,264,1,0,0,0,270,80,1,0,0,0,271,272,5,
|
||||||
|
48,0,0,272,274,7,5,0,0,273,275,7,6,0,0,274,273,1,0,0,0,275,276,1,0,0,
|
||||||
|
0,276,274,1,0,0,0,276,277,1,0,0,0,277,285,1,0,0,0,278,282,5,46,0,0,279,
|
||||||
|
281,7,6,0,0,280,279,1,0,0,0,281,284,1,0,0,0,282,280,1,0,0,0,282,283,1,
|
||||||
|
0,0,0,283,286,1,0,0,0,284,282,1,0,0,0,285,278,1,0,0,0,285,286,1,0,0,0,
|
||||||
|
286,287,1,0,0,0,287,289,7,7,0,0,288,290,7,8,0,0,289,288,1,0,0,0,289,290,
|
||||||
|
1,0,0,0,290,292,1,0,0,0,291,293,7,3,0,0,292,291,1,0,0,0,293,294,1,0,0,
|
||||||
|
0,294,292,1,0,0,0,294,295,1,0,0,0,295,314,1,0,0,0,296,297,5,48,0,0,297,
|
||||||
|
298,7,5,0,0,298,300,5,46,0,0,299,301,7,6,0,0,300,299,1,0,0,0,301,302,
|
||||||
|
1,0,0,0,302,300,1,0,0,0,302,303,1,0,0,0,303,304,1,0,0,0,304,306,7,7,0,
|
||||||
|
0,305,307,7,8,0,0,306,305,1,0,0,0,306,307,1,0,0,0,307,309,1,0,0,0,308,
|
||||||
|
310,7,3,0,0,309,308,1,0,0,0,310,311,1,0,0,0,311,309,1,0,0,0,311,312,1,
|
||||||
|
0,0,0,312,314,1,0,0,0,313,271,1,0,0,0,313,296,1,0,0,0,314,82,1,0,0,0,
|
||||||
|
315,317,7,9,0,0,316,318,7,8,0,0,317,316,1,0,0,0,317,318,1,0,0,0,318,320,
|
||||||
|
1,0,0,0,319,321,7,3,0,0,320,319,1,0,0,0,321,322,1,0,0,0,322,320,1,0,0,
|
||||||
|
0,322,323,1,0,0,0,323,84,1,0,0,0,324,325,7,10,0,0,325,326,1,0,0,0,326,
|
||||||
|
327,6,42,0,0,327,86,1,0,0,0,328,329,5,47,0,0,329,330,5,47,0,0,330,334,
|
||||||
|
1,0,0,0,331,333,8,11,0,0,332,331,1,0,0,0,333,336,1,0,0,0,334,332,1,0,
|
||||||
|
0,0,334,335,1,0,0,0,335,337,1,0,0,0,336,334,1,0,0,0,337,338,6,43,0,0,
|
||||||
|
338,88,1,0,0,0,339,340,5,47,0,0,340,341,5,42,0,0,341,345,1,0,0,0,342,
|
||||||
|
344,9,0,0,0,343,342,1,0,0,0,344,347,1,0,0,0,345,346,1,0,0,0,345,343,1,
|
||||||
|
0,0,0,346,348,1,0,0,0,347,345,1,0,0,0,348,349,5,42,0,0,349,350,5,47,0,
|
||||||
|
0,350,351,1,0,0,0,351,352,6,44,0,0,352,90,1,0,0,0,28,0,204,209,214,221,
|
||||||
|
224,230,237,242,248,252,258,261,266,269,276,282,285,289,294,302,306,311,
|
||||||
|
313,317,322,334,345,1,6,0,0
|
||||||
|
};
|
||||||
|
staticData->serializedATN = antlr4::atn::SerializedATNView(serializedATNSegment, sizeof(serializedATNSegment) / sizeof(serializedATNSegment[0]));
|
||||||
|
|
||||||
|
antlr4::atn::ATNDeserializer deserializer;
|
||||||
|
staticData->atn = deserializer.deserialize(staticData->serializedATN);
|
||||||
|
|
||||||
|
const size_t count = staticData->atn->getNumberOfDecisions();
|
||||||
|
staticData->decisionToDFA.reserve(count);
|
||||||
|
for (size_t i = 0; i < count; i++) {
|
||||||
|
staticData->decisionToDFA.emplace_back(staticData->atn->getDecisionState(i), i);
|
||||||
|
}
|
||||||
|
sysylexerLexerStaticData = std::move(staticData);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
SysYLexer::SysYLexer(CharStream *input) : Lexer(input) {
|
||||||
|
SysYLexer::initialize();
|
||||||
|
_interpreter = new atn::LexerATNSimulator(this, *sysylexerLexerStaticData->atn, sysylexerLexerStaticData->decisionToDFA, sysylexerLexerStaticData->sharedContextCache);
|
||||||
|
}
|
||||||
|
|
||||||
|
SysYLexer::~SysYLexer() {
|
||||||
|
delete _interpreter;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string SysYLexer::getGrammarFileName() const {
|
||||||
|
return "SysY.g4";
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::vector<std::string>& SysYLexer::getRuleNames() const {
|
||||||
|
return sysylexerLexerStaticData->ruleNames;
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::vector<std::string>& SysYLexer::getChannelNames() const {
|
||||||
|
return sysylexerLexerStaticData->channelNames;
|
||||||
|
}
|
||||||
|
|
||||||
|
const std::vector<std::string>& SysYLexer::getModeNames() const {
|
||||||
|
return sysylexerLexerStaticData->modeNames;
|
||||||
|
}
|
||||||
|
|
||||||
|
const dfa::Vocabulary& SysYLexer::getVocabulary() const {
|
||||||
|
return sysylexerLexerStaticData->vocabulary;
|
||||||
|
}
|
||||||
|
|
||||||
|
antlr4::atn::SerializedATNView SysYLexer::getSerializedATN() const {
|
||||||
|
return sysylexerLexerStaticData->serializedATN;
|
||||||
|
}
|
||||||
|
|
||||||
|
const atn::ATN& SysYLexer::getATN() const {
|
||||||
|
return *sysylexerLexerStaticData->atn;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void SysYLexer::initialize() {
|
||||||
|
#if ANTLR4_USE_THREAD_LOCAL_CACHE
|
||||||
|
sysylexerLexerInitialize();
|
||||||
|
#else
|
||||||
|
::antlr4::internal::call_once(sysylexerLexerOnceFlag, sysylexerLexerInitialize);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
@ -0,0 +1,54 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
|
#include "antlr4-runtime.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class SysYLexer : public antlr4::Lexer {
|
||||||
|
public:
|
||||||
|
enum {
|
||||||
|
CONST = 1, INT = 2, FLOAT = 3, VOID = 4, IF = 5, ELSE = 6, WHILE = 7,
|
||||||
|
BREAK = 8, CONTINUE = 9, RETURN = 10, ASSIGN = 11, EQ = 12, NE = 13,
|
||||||
|
LT = 14, GT = 15, LE = 16, GE = 17, ADD = 18, SUB = 19, MUL = 20, DIV = 21,
|
||||||
|
MOD = 22, NOT = 23, AND = 24, OR = 25, LPAREN = 26, RPAREN = 27, LBRACK = 28,
|
||||||
|
RBRACK = 29, LBRACE = 30, RBRACE = 31, COMMA = 32, SEMICOLON = 33, ID = 34,
|
||||||
|
FLITERAL = 35, ILITERAL = 36, WS = 37, LINECOMMENT = 38, BLOCKCOMMENT = 39
|
||||||
|
};
|
||||||
|
|
||||||
|
explicit SysYLexer(antlr4::CharStream *input);
|
||||||
|
|
||||||
|
~SysYLexer() override;
|
||||||
|
|
||||||
|
|
||||||
|
std::string getGrammarFileName() const override;
|
||||||
|
|
||||||
|
const std::vector<std::string>& getRuleNames() const override;
|
||||||
|
|
||||||
|
const std::vector<std::string>& getChannelNames() const override;
|
||||||
|
|
||||||
|
const std::vector<std::string>& getModeNames() const override;
|
||||||
|
|
||||||
|
const antlr4::dfa::Vocabulary& getVocabulary() const override;
|
||||||
|
|
||||||
|
antlr4::atn::SerializedATNView getSerializedATN() const override;
|
||||||
|
|
||||||
|
const antlr4::atn::ATN& getATN() const override;
|
||||||
|
|
||||||
|
// By default the static state used to implement the lexer is lazily initialized during the first
|
||||||
|
// call to the constructor. You can call this function if you wish to initialize the static state
|
||||||
|
// ahead of time.
|
||||||
|
static void initialize();
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
// Individual action functions triggered by action() above.
|
||||||
|
|
||||||
|
// Individual semantic predicate functions triggered by sempred() above.
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,641 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
|
#include "antlr4-runtime.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class SysYParser : public antlr4::Parser {
|
||||||
|
public:
|
||||||
|
enum {
|
||||||
|
CONST = 1, INT = 2, FLOAT = 3, VOID = 4, IF = 5, ELSE = 6, WHILE = 7,
|
||||||
|
BREAK = 8, CONTINUE = 9, RETURN = 10, ASSIGN = 11, EQ = 12, NE = 13,
|
||||||
|
LT = 14, GT = 15, LE = 16, GE = 17, ADD = 18, SUB = 19, MUL = 20, DIV = 21,
|
||||||
|
MOD = 22, NOT = 23, AND = 24, OR = 25, LPAREN = 26, RPAREN = 27, LBRACK = 28,
|
||||||
|
RBRACK = 29, LBRACE = 30, RBRACE = 31, COMMA = 32, SEMICOLON = 33, ID = 34,
|
||||||
|
FLITERAL = 35, ILITERAL = 36, WS = 37, LINECOMMENT = 38, BLOCKCOMMENT = 39
|
||||||
|
};
|
||||||
|
|
||||||
|
enum {
|
||||||
|
RuleCompUnit = 0, RuleDecl = 1, RuleConstDecl = 2, RuleConstDef = 3,
|
||||||
|
RuleConstInitValue = 4, RuleVarDecl = 5, RuleBtype = 6, RuleVarDef = 7,
|
||||||
|
RuleInitValue = 8, RuleFuncDef = 9, RuleFuncType = 10, RuleFuncFParams = 11,
|
||||||
|
RuleFuncFParam = 12, RuleBlockStmt = 13, RuleBlockItem = 14, RuleStmt = 15,
|
||||||
|
RuleReturnStmt = 16, RuleExp = 17, RuleCond = 18, RuleLValue = 19, RulePrimaryExp = 20,
|
||||||
|
RuleNumber = 21, RuleUnaryExp = 22, RuleUnaryOp = 23, RuleFuncRParams = 24,
|
||||||
|
RuleMulExp = 25, RuleAddExp = 26, RuleRelExp = 27, RuleEqExp = 28, RuleLAndExp = 29,
|
||||||
|
RuleLOrExp = 30, RuleConstExp = 31
|
||||||
|
};
|
||||||
|
|
||||||
|
explicit SysYParser(antlr4::TokenStream *input);
|
||||||
|
|
||||||
|
SysYParser(antlr4::TokenStream *input, const antlr4::atn::ParserATNSimulatorOptions &options);
|
||||||
|
|
||||||
|
~SysYParser() override;
|
||||||
|
|
||||||
|
std::string getGrammarFileName() const override;
|
||||||
|
|
||||||
|
const antlr4::atn::ATN& getATN() const override;
|
||||||
|
|
||||||
|
const std::vector<std::string>& getRuleNames() const override;
|
||||||
|
|
||||||
|
const antlr4::dfa::Vocabulary& getVocabulary() const override;
|
||||||
|
|
||||||
|
antlr4::atn::SerializedATNView getSerializedATN() const override;
|
||||||
|
|
||||||
|
|
||||||
|
class CompUnitContext;
|
||||||
|
class DeclContext;
|
||||||
|
class ConstDeclContext;
|
||||||
|
class ConstDefContext;
|
||||||
|
class ConstInitValueContext;
|
||||||
|
class VarDeclContext;
|
||||||
|
class BtypeContext;
|
||||||
|
class VarDefContext;
|
||||||
|
class InitValueContext;
|
||||||
|
class FuncDefContext;
|
||||||
|
class FuncTypeContext;
|
||||||
|
class FuncFParamsContext;
|
||||||
|
class FuncFParamContext;
|
||||||
|
class BlockStmtContext;
|
||||||
|
class BlockItemContext;
|
||||||
|
class StmtContext;
|
||||||
|
class ReturnStmtContext;
|
||||||
|
class ExpContext;
|
||||||
|
class CondContext;
|
||||||
|
class LValueContext;
|
||||||
|
class PrimaryExpContext;
|
||||||
|
class NumberContext;
|
||||||
|
class UnaryExpContext;
|
||||||
|
class UnaryOpContext;
|
||||||
|
class FuncRParamsContext;
|
||||||
|
class MulExpContext;
|
||||||
|
class AddExpContext;
|
||||||
|
class RelExpContext;
|
||||||
|
class EqExpContext;
|
||||||
|
class LAndExpContext;
|
||||||
|
class LOrExpContext;
|
||||||
|
class ConstExpContext;
|
||||||
|
|
||||||
|
class CompUnitContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
CompUnitContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *EOF();
|
||||||
|
std::vector<DeclContext *> decl();
|
||||||
|
DeclContext* decl(size_t i);
|
||||||
|
std::vector<FuncDefContext *> funcDef();
|
||||||
|
FuncDefContext* funcDef(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
CompUnitContext* compUnit();
|
||||||
|
|
||||||
|
class DeclContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
DeclContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
ConstDeclContext *constDecl();
|
||||||
|
VarDeclContext *varDecl();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
DeclContext* decl();
|
||||||
|
|
||||||
|
class ConstDeclContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
ConstDeclContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *CONST();
|
||||||
|
BtypeContext *btype();
|
||||||
|
std::vector<ConstDefContext *> constDef();
|
||||||
|
ConstDefContext* constDef(size_t i);
|
||||||
|
antlr4::tree::TerminalNode *SEMICOLON();
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> COMMA();
|
||||||
|
antlr4::tree::TerminalNode* COMMA(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ConstDeclContext* constDecl();
|
||||||
|
|
||||||
|
class ConstDefContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
ConstDefContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *ID();
|
||||||
|
antlr4::tree::TerminalNode *ASSIGN();
|
||||||
|
ConstInitValueContext *constInitValue();
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> LBRACK();
|
||||||
|
antlr4::tree::TerminalNode* LBRACK(size_t i);
|
||||||
|
std::vector<ConstExpContext *> constExp();
|
||||||
|
ConstExpContext* constExp(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> RBRACK();
|
||||||
|
antlr4::tree::TerminalNode* RBRACK(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ConstDefContext* constDef();
|
||||||
|
|
||||||
|
class ConstInitValueContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
ConstInitValueContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
ConstExpContext *constExp();
|
||||||
|
antlr4::tree::TerminalNode *LBRACE();
|
||||||
|
antlr4::tree::TerminalNode *RBRACE();
|
||||||
|
std::vector<ConstInitValueContext *> constInitValue();
|
||||||
|
ConstInitValueContext* constInitValue(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> COMMA();
|
||||||
|
antlr4::tree::TerminalNode* COMMA(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ConstInitValueContext* constInitValue();
|
||||||
|
|
||||||
|
class VarDeclContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
VarDeclContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
BtypeContext *btype();
|
||||||
|
std::vector<VarDefContext *> varDef();
|
||||||
|
VarDefContext* varDef(size_t i);
|
||||||
|
antlr4::tree::TerminalNode *SEMICOLON();
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> COMMA();
|
||||||
|
antlr4::tree::TerminalNode* COMMA(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
VarDeclContext* varDecl();
|
||||||
|
|
||||||
|
class BtypeContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
BtypeContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *INT();
|
||||||
|
antlr4::tree::TerminalNode *FLOAT();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
BtypeContext* btype();
|
||||||
|
|
||||||
|
class VarDefContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
VarDefContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *ID();
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> LBRACK();
|
||||||
|
antlr4::tree::TerminalNode* LBRACK(size_t i);
|
||||||
|
std::vector<ConstExpContext *> constExp();
|
||||||
|
ConstExpContext* constExp(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> RBRACK();
|
||||||
|
antlr4::tree::TerminalNode* RBRACK(size_t i);
|
||||||
|
antlr4::tree::TerminalNode *ASSIGN();
|
||||||
|
InitValueContext *initValue();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
VarDefContext* varDef();
|
||||||
|
|
||||||
|
class InitValueContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
InitValueContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
ExpContext *exp();
|
||||||
|
antlr4::tree::TerminalNode *LBRACE();
|
||||||
|
antlr4::tree::TerminalNode *RBRACE();
|
||||||
|
std::vector<InitValueContext *> initValue();
|
||||||
|
InitValueContext* initValue(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> COMMA();
|
||||||
|
antlr4::tree::TerminalNode* COMMA(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
InitValueContext* initValue();
|
||||||
|
|
||||||
|
class FuncDefContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
FuncDefContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
FuncTypeContext *funcType();
|
||||||
|
antlr4::tree::TerminalNode *ID();
|
||||||
|
antlr4::tree::TerminalNode *LPAREN();
|
||||||
|
antlr4::tree::TerminalNode *RPAREN();
|
||||||
|
BlockStmtContext *blockStmt();
|
||||||
|
FuncFParamsContext *funcFParams();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
FuncDefContext* funcDef();
|
||||||
|
|
||||||
|
class FuncTypeContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
FuncTypeContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *INT();
|
||||||
|
antlr4::tree::TerminalNode *FLOAT();
|
||||||
|
antlr4::tree::TerminalNode *VOID();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
FuncTypeContext* funcType();
|
||||||
|
|
||||||
|
class FuncFParamsContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
FuncFParamsContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
std::vector<FuncFParamContext *> funcFParam();
|
||||||
|
FuncFParamContext* funcFParam(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> COMMA();
|
||||||
|
antlr4::tree::TerminalNode* COMMA(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
FuncFParamsContext* funcFParams();
|
||||||
|
|
||||||
|
class FuncFParamContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
FuncFParamContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
BtypeContext *btype();
|
||||||
|
antlr4::tree::TerminalNode *ID();
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> LBRACK();
|
||||||
|
antlr4::tree::TerminalNode* LBRACK(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> RBRACK();
|
||||||
|
antlr4::tree::TerminalNode* RBRACK(size_t i);
|
||||||
|
std::vector<ExpContext *> exp();
|
||||||
|
ExpContext* exp(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
FuncFParamContext* funcFParam();
|
||||||
|
|
||||||
|
class BlockStmtContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
BlockStmtContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *LBRACE();
|
||||||
|
antlr4::tree::TerminalNode *RBRACE();
|
||||||
|
std::vector<BlockItemContext *> blockItem();
|
||||||
|
BlockItemContext* blockItem(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
BlockStmtContext* blockStmt();
|
||||||
|
|
||||||
|
class BlockItemContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
BlockItemContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
DeclContext *decl();
|
||||||
|
StmtContext *stmt();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
BlockItemContext* blockItem();
|
||||||
|
|
||||||
|
class StmtContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
StmtContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
LValueContext *lValue();
|
||||||
|
antlr4::tree::TerminalNode *ASSIGN();
|
||||||
|
ExpContext *exp();
|
||||||
|
antlr4::tree::TerminalNode *SEMICOLON();
|
||||||
|
BlockStmtContext *blockStmt();
|
||||||
|
antlr4::tree::TerminalNode *IF();
|
||||||
|
antlr4::tree::TerminalNode *LPAREN();
|
||||||
|
CondContext *cond();
|
||||||
|
antlr4::tree::TerminalNode *RPAREN();
|
||||||
|
std::vector<StmtContext *> stmt();
|
||||||
|
StmtContext* stmt(size_t i);
|
||||||
|
antlr4::tree::TerminalNode *ELSE();
|
||||||
|
antlr4::tree::TerminalNode *WHILE();
|
||||||
|
antlr4::tree::TerminalNode *BREAK();
|
||||||
|
antlr4::tree::TerminalNode *CONTINUE();
|
||||||
|
ReturnStmtContext *returnStmt();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
StmtContext* stmt();
|
||||||
|
|
||||||
|
class ReturnStmtContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
ReturnStmtContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *RETURN();
|
||||||
|
antlr4::tree::TerminalNode *SEMICOLON();
|
||||||
|
ExpContext *exp();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ReturnStmtContext* returnStmt();
|
||||||
|
|
||||||
|
class ExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
ExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
AddExpContext *addExp();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ExpContext* exp();
|
||||||
|
|
||||||
|
class CondContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
CondContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
LOrExpContext *lOrExp();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
CondContext* cond();
|
||||||
|
|
||||||
|
class LValueContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
LValueContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *ID();
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> LBRACK();
|
||||||
|
antlr4::tree::TerminalNode* LBRACK(size_t i);
|
||||||
|
std::vector<ExpContext *> exp();
|
||||||
|
ExpContext* exp(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> RBRACK();
|
||||||
|
antlr4::tree::TerminalNode* RBRACK(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
LValueContext* lValue();
|
||||||
|
|
||||||
|
class PrimaryExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
PrimaryExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *LPAREN();
|
||||||
|
ExpContext *exp();
|
||||||
|
antlr4::tree::TerminalNode *RPAREN();
|
||||||
|
LValueContext *lValue();
|
||||||
|
NumberContext *number();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
PrimaryExpContext* primaryExp();
|
||||||
|
|
||||||
|
class NumberContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
NumberContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *ILITERAL();
|
||||||
|
antlr4::tree::TerminalNode *FLITERAL();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
NumberContext* number();
|
||||||
|
|
||||||
|
class UnaryExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
UnaryExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
PrimaryExpContext *primaryExp();
|
||||||
|
antlr4::tree::TerminalNode *ID();
|
||||||
|
antlr4::tree::TerminalNode *LPAREN();
|
||||||
|
antlr4::tree::TerminalNode *RPAREN();
|
||||||
|
FuncRParamsContext *funcRParams();
|
||||||
|
UnaryOpContext *unaryOp();
|
||||||
|
UnaryExpContext *unaryExp();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
UnaryExpContext* unaryExp();
|
||||||
|
|
||||||
|
class UnaryOpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
UnaryOpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
antlr4::tree::TerminalNode *ADD();
|
||||||
|
antlr4::tree::TerminalNode *SUB();
|
||||||
|
antlr4::tree::TerminalNode *NOT();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
UnaryOpContext* unaryOp();
|
||||||
|
|
||||||
|
class FuncRParamsContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
FuncRParamsContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
std::vector<ExpContext *> exp();
|
||||||
|
ExpContext* exp(size_t i);
|
||||||
|
std::vector<antlr4::tree::TerminalNode *> COMMA();
|
||||||
|
antlr4::tree::TerminalNode* COMMA(size_t i);
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
FuncRParamsContext* funcRParams();
|
||||||
|
|
||||||
|
class MulExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
MulExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
UnaryExpContext *unaryExp();
|
||||||
|
MulExpContext *mulExp();
|
||||||
|
antlr4::tree::TerminalNode *MUL();
|
||||||
|
antlr4::tree::TerminalNode *DIV();
|
||||||
|
antlr4::tree::TerminalNode *MOD();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
MulExpContext* mulExp();
|
||||||
|
MulExpContext* mulExp(int precedence);
|
||||||
|
class AddExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
AddExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
MulExpContext *mulExp();
|
||||||
|
AddExpContext *addExp();
|
||||||
|
antlr4::tree::TerminalNode *ADD();
|
||||||
|
antlr4::tree::TerminalNode *SUB();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
AddExpContext* addExp();
|
||||||
|
AddExpContext* addExp(int precedence);
|
||||||
|
class RelExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
RelExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
AddExpContext *addExp();
|
||||||
|
RelExpContext *relExp();
|
||||||
|
antlr4::tree::TerminalNode *LT();
|
||||||
|
antlr4::tree::TerminalNode *GT();
|
||||||
|
antlr4::tree::TerminalNode *LE();
|
||||||
|
antlr4::tree::TerminalNode *GE();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
RelExpContext* relExp();
|
||||||
|
RelExpContext* relExp(int precedence);
|
||||||
|
class EqExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
EqExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
RelExpContext *relExp();
|
||||||
|
EqExpContext *eqExp();
|
||||||
|
antlr4::tree::TerminalNode *EQ();
|
||||||
|
antlr4::tree::TerminalNode *NE();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
EqExpContext* eqExp();
|
||||||
|
EqExpContext* eqExp(int precedence);
|
||||||
|
class LAndExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
LAndExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
EqExpContext *eqExp();
|
||||||
|
LAndExpContext *lAndExp();
|
||||||
|
antlr4::tree::TerminalNode *AND();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
LAndExpContext* lAndExp();
|
||||||
|
LAndExpContext* lAndExp(int precedence);
|
||||||
|
class LOrExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
LOrExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
LAndExpContext *lAndExp();
|
||||||
|
LOrExpContext *lOrExp();
|
||||||
|
antlr4::tree::TerminalNode *OR();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
LOrExpContext* lOrExp();
|
||||||
|
LOrExpContext* lOrExp(int precedence);
|
||||||
|
class ConstExpContext : public antlr4::ParserRuleContext {
|
||||||
|
public:
|
||||||
|
ConstExpContext(antlr4::ParserRuleContext *parent, size_t invokingState);
|
||||||
|
virtual size_t getRuleIndex() const override;
|
||||||
|
AddExpContext *addExp();
|
||||||
|
|
||||||
|
|
||||||
|
virtual std::any accept(antlr4::tree::ParseTreeVisitor *visitor) override;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
ConstExpContext* constExp();
|
||||||
|
|
||||||
|
|
||||||
|
bool sempred(antlr4::RuleContext *_localctx, size_t ruleIndex, size_t predicateIndex) override;
|
||||||
|
|
||||||
|
bool mulExpSempred(MulExpContext *_localctx, size_t predicateIndex);
|
||||||
|
bool addExpSempred(AddExpContext *_localctx, size_t predicateIndex);
|
||||||
|
bool relExpSempred(RelExpContext *_localctx, size_t predicateIndex);
|
||||||
|
bool eqExpSempred(EqExpContext *_localctx, size_t predicateIndex);
|
||||||
|
bool lAndExpSempred(LAndExpContext *_localctx, size_t predicateIndex);
|
||||||
|
bool lOrExpSempred(LOrExpContext *_localctx, size_t predicateIndex);
|
||||||
|
|
||||||
|
// By default the static state used to implement the parser is lazily initialized during the first
|
||||||
|
// call to the constructor. You can call this function if you wish to initialize the static state
|
||||||
|
// ahead of time.
|
||||||
|
static void initialize();
|
||||||
|
|
||||||
|
private:
|
||||||
|
};
|
||||||
|
|
||||||
@ -0,0 +1,7 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
|
||||||
|
#include "SysYVisitor.h"
|
||||||
|
|
||||||
|
|
||||||
@ -0,0 +1,88 @@
|
|||||||
|
|
||||||
|
// Generated from SysY.g4 by ANTLR 4.13.2
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
|
#include "antlr4-runtime.h"
|
||||||
|
#include "SysYParser.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class defines an abstract visitor for a parse tree
|
||||||
|
* produced by SysYParser.
|
||||||
|
*/
|
||||||
|
class SysYVisitor : public antlr4::tree::AbstractParseTreeVisitor {
|
||||||
|
public:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Visit parse trees produced by SysYParser.
|
||||||
|
*/
|
||||||
|
virtual std::any visitCompUnit(SysYParser::CompUnitContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitDecl(SysYParser::DeclContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitConstDecl(SysYParser::ConstDeclContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitConstDef(SysYParser::ConstDefContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitConstInitValue(SysYParser::ConstInitValueContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitVarDecl(SysYParser::VarDeclContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitBtype(SysYParser::BtypeContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitVarDef(SysYParser::VarDefContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitInitValue(SysYParser::InitValueContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitFuncDef(SysYParser::FuncDefContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitFuncType(SysYParser::FuncTypeContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitFuncFParams(SysYParser::FuncFParamsContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitFuncFParam(SysYParser::FuncFParamContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitBlockStmt(SysYParser::BlockStmtContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitBlockItem(SysYParser::BlockItemContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitStmt(SysYParser::StmtContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitReturnStmt(SysYParser::ReturnStmtContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitExp(SysYParser::ExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitCond(SysYParser::CondContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitLValue(SysYParser::LValueContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitPrimaryExp(SysYParser::PrimaryExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitNumber(SysYParser::NumberContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitUnaryExp(SysYParser::UnaryExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitUnaryOp(SysYParser::UnaryOpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitFuncRParams(SysYParser::FuncRParamsContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitMulExp(SysYParser::MulExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitAddExp(SysYParser::AddExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitRelExp(SysYParser::RelExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitEqExp(SysYParser::EqExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitLAndExp(SysYParser::LAndExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitLOrExp(SysYParser::LOrExpContext *context) = 0;
|
||||||
|
|
||||||
|
virtual std::any visitConstExp(SysYParser::ConstExpContext *context) = 0;
|
||||||
|
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
@ -1,200 +1,224 @@
|
|||||||
#include "sem/Sema.h"
|
#include "sem/Sema.h"
|
||||||
|
|
||||||
#include <any>
|
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
#include <string>
|
|
||||||
|
|
||||||
#include "SysYBaseVisitor.h"
|
|
||||||
#include "sem/SymbolTable.h"
|
|
||||||
#include "utils/Log.h"
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
std::string GetLValueName(SysYParser::LValueContext& lvalue) {
|
SymbolType ParseType(const std::string& text) {
|
||||||
if (!lvalue.ID()) {
|
if (text == "int") {
|
||||||
throw std::runtime_error(FormatError("sema", "非法左值"));
|
return SymbolType::TYPE_INT;
|
||||||
}
|
}
|
||||||
return lvalue.ID()->getText();
|
if (text == "float") {
|
||||||
}
|
return SymbolType::TYPE_FLOAT;
|
||||||
|
}
|
||||||
class SemaVisitor final : public SysYBaseVisitor {
|
if (text == "void") {
|
||||||
public:
|
return SymbolType::TYPE_VOID;
|
||||||
std::any visitCompUnit(SysYParser::CompUnitContext* ctx) override {
|
|
||||||
if (!ctx) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "缺少编译单元"));
|
|
||||||
}
|
|
||||||
auto* func = ctx->funcDef();
|
|
||||||
if (!func || !func->blockStmt()) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "缺少 main 函数定义"));
|
|
||||||
}
|
|
||||||
if (!func->ID() || func->ID()->getText() != "main") {
|
|
||||||
throw std::runtime_error(FormatError("sema", "缺少 main 函数定义"));
|
|
||||||
}
|
|
||||||
func->accept(this);
|
|
||||||
if (!seen_return_) {
|
|
||||||
throw std::runtime_error(
|
|
||||||
FormatError("sema", "main 函数必须包含 return 语句"));
|
|
||||||
}
|
|
||||||
return {};
|
|
||||||
}
|
}
|
||||||
|
return SymbolType::TYPE_UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
std::any visitFuncDef(SysYParser::FuncDefContext* ctx) override {
|
} // namespace
|
||||||
if (!ctx || !ctx->blockStmt()) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "缺少 main 函数定义"));
|
std::any SemaVisitor::visitCompUnit(SysYParser::CompUnitContext* ctx) {
|
||||||
}
|
return visitChildren(ctx);
|
||||||
if (!ctx->funcType() || !ctx->funcType()->INT()) {
|
}
|
||||||
throw std::runtime_error(FormatError("sema", "当前仅支持 int main"));
|
|
||||||
}
|
std::any SemaVisitor::visitDecl(SysYParser::DeclContext* ctx) {
|
||||||
const auto& items = ctx->blockStmt()->blockItem();
|
return visitChildren(ctx);
|
||||||
if (items.empty()) {
|
}
|
||||||
throw std::runtime_error(
|
|
||||||
FormatError("sema", "main 函数不能为空,且必须以 return 结束"));
|
std::any SemaVisitor::visitConstDecl(SysYParser::ConstDeclContext* ctx) {
|
||||||
}
|
return visitChildren(ctx);
|
||||||
ctx->blockStmt()->accept(this);
|
}
|
||||||
return {};
|
|
||||||
|
std::any SemaVisitor::visitBtype(SysYParser::BtypeContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitConstDef(SysYParser::ConstDefContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitConstInitValue(SysYParser::ConstInitValueContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitVarDecl(SysYParser::VarDeclContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitVarDef(SysYParser::VarDefContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitInitValue(SysYParser::InitValueContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitFuncDef(SysYParser::FuncDefContext* ctx) {
|
||||||
|
SymbolType ret_type = SymbolType::TYPE_UNKNOWN;
|
||||||
|
if (ctx && ctx->funcType()) {
|
||||||
|
ret_type = ParseType(ctx->funcType()->getText());
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitBlockStmt(SysYParser::BlockStmtContext* ctx) override {
|
ir_ctx_.SetCurrentFuncReturnType(ret_type);
|
||||||
if (!ctx) {
|
return visitChildren(ctx);
|
||||||
throw std::runtime_error(FormatError("sema", "缺少语句块"));
|
}
|
||||||
}
|
|
||||||
const auto& items = ctx->blockItem();
|
std::any SemaVisitor::visitFuncType(SysYParser::FuncTypeContext* ctx) {
|
||||||
for (size_t i = 0; i < items.size(); ++i) {
|
return visitChildren(ctx);
|
||||||
auto* item = items[i];
|
}
|
||||||
if (!item) {
|
|
||||||
continue;
|
std::any SemaVisitor::visitFuncFParams(SysYParser::FuncFParamsContext* ctx) {
|
||||||
}
|
return visitChildren(ctx);
|
||||||
if (seen_return_) {
|
}
|
||||||
throw std::runtime_error(
|
|
||||||
FormatError("sema", "return 必须是 main 函数中的最后一条语句"));
|
std::any SemaVisitor::visitFuncFParam(SysYParser::FuncFParamContext* ctx) {
|
||||||
}
|
return visitChildren(ctx);
|
||||||
current_item_index_ = i;
|
}
|
||||||
total_items_ = items.size();
|
|
||||||
item->accept(this);
|
std::any SemaVisitor::visitBlockStmt(SysYParser::BlockStmtContext* ctx) {
|
||||||
}
|
ir_ctx_.EnterScope();
|
||||||
|
std::any result = visitChildren(ctx);
|
||||||
|
ir_ctx_.LeaveScope();
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitBlockItem(SysYParser::BlockItemContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitStmt(SysYParser::StmtContext* ctx) {
|
||||||
|
if (!ctx) {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitBlockItem(SysYParser::BlockItemContext* ctx) override {
|
if (ctx->WHILE()) {
|
||||||
if (!ctx) {
|
ir_ctx_.EnterLoop();
|
||||||
throw std::runtime_error(FormatError("sema", "暂不支持的语句或声明"));
|
std::any result = visitChildren(ctx);
|
||||||
}
|
ir_ctx_.ExitLoop();
|
||||||
if (ctx->decl()) {
|
return result;
|
||||||
ctx->decl()->accept(this);
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
if (ctx->stmt()) {
|
|
||||||
ctx->stmt()->accept(this);
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
throw std::runtime_error(FormatError("sema", "暂不支持的语句或声明"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitDecl(SysYParser::DeclContext* ctx) override {
|
if (ctx->BREAK() && !ir_ctx_.InLoop()) {
|
||||||
if (!ctx) {
|
ir_ctx_.RecordError(
|
||||||
throw std::runtime_error(FormatError("sema", "非法变量声明"));
|
ErrorMsg("break 只能出现在循环语句中", ctx->getStart()->getLine(),
|
||||||
}
|
ctx->getStart()->getCharPositionInLine() + 1));
|
||||||
if (!ctx->btype() || !ctx->btype()->INT()) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "当前仅支持局部 int 变量声明"));
|
|
||||||
}
|
|
||||||
auto* var_def = ctx->varDef();
|
|
||||||
if (!var_def || !var_def->lValue()) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "非法变量声明"));
|
|
||||||
}
|
|
||||||
const std::string name = GetLValueName(*var_def->lValue());
|
|
||||||
if (table_.Contains(name)) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "重复定义变量: " + name));
|
|
||||||
}
|
|
||||||
if (auto* init = var_def->initValue()) {
|
|
||||||
if (!init->exp()) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "当前不支持聚合初始化"));
|
|
||||||
}
|
|
||||||
init->exp()->accept(this);
|
|
||||||
}
|
|
||||||
table_.Add(name, var_def);
|
|
||||||
return {};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitStmt(SysYParser::StmtContext* ctx) override {
|
if (ctx->CONTINUE() && !ir_ctx_.InLoop()) {
|
||||||
if (!ctx || !ctx->returnStmt()) {
|
ir_ctx_.RecordError(
|
||||||
throw std::runtime_error(FormatError("sema", "暂不支持的语句或声明"));
|
ErrorMsg("continue 只能出现在循环语句中", ctx->getStart()->getLine(),
|
||||||
}
|
ctx->getStart()->getCharPositionInLine() + 1));
|
||||||
ctx->returnStmt()->accept(this);
|
|
||||||
return {};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitReturnStmt(SysYParser::ReturnStmtContext* ctx) override {
|
return visitChildren(ctx);
|
||||||
if (!ctx || !ctx->exp()) {
|
}
|
||||||
throw std::runtime_error(FormatError("sema", "return 缺少表达式"));
|
|
||||||
}
|
|
||||||
ctx->exp()->accept(this);
|
|
||||||
seen_return_ = true;
|
|
||||||
if (current_item_index_ + 1 != total_items_) {
|
|
||||||
throw std::runtime_error(
|
|
||||||
FormatError("sema", "return 必须是 main 函数中的最后一条语句"));
|
|
||||||
}
|
|
||||||
return {};
|
|
||||||
}
|
|
||||||
|
|
||||||
std::any visitParenExp(SysYParser::ParenExpContext* ctx) override {
|
std::any SemaVisitor::visitReturnStmt(SysYParser::ReturnStmtContext* ctx) {
|
||||||
if (!ctx || !ctx->exp()) {
|
if (!ctx) {
|
||||||
throw std::runtime_error(FormatError("sema", "非法括号表达式"));
|
|
||||||
}
|
|
||||||
ctx->exp()->accept(this);
|
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitVarExp(SysYParser::VarExpContext* ctx) override {
|
if (ctx->exp() && ir_ctx_.GetCurrentFuncReturnType() == SymbolType::TYPE_VOID) {
|
||||||
if (!ctx || !ctx->var()) {
|
ir_ctx_.RecordError(
|
||||||
throw std::runtime_error(FormatError("sema", "非法变量表达式"));
|
ErrorMsg("void 函数不应返回表达式", ctx->getStart()->getLine(),
|
||||||
}
|
ctx->getStart()->getCharPositionInLine() + 1));
|
||||||
ctx->var()->accept(this);
|
|
||||||
return {};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitNumberExp(SysYParser::NumberExpContext* ctx) override {
|
if (!ctx->exp() &&
|
||||||
if (!ctx || !ctx->number() || !ctx->number()->ILITERAL()) {
|
ir_ctx_.GetCurrentFuncReturnType() != SymbolType::TYPE_VOID &&
|
||||||
throw std::runtime_error(FormatError("sema", "当前仅支持整数字面量"));
|
ir_ctx_.GetCurrentFuncReturnType() != SymbolType::TYPE_UNKNOWN) {
|
||||||
}
|
ir_ctx_.RecordError(
|
||||||
return {};
|
ErrorMsg("非 void 函数 return 必须带表达式", ctx->getStart()->getLine(),
|
||||||
|
ctx->getStart()->getCharPositionInLine() + 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitAdditiveExp(SysYParser::AdditiveExpContext* ctx) override {
|
return visitChildren(ctx);
|
||||||
if (!ctx || !ctx->exp(0) || !ctx->exp(1)) {
|
}
|
||||||
throw std::runtime_error(FormatError("sema", "暂不支持的表达式形式"));
|
|
||||||
}
|
std::any SemaVisitor::visitExp(SysYParser::ExpContext* ctx) {
|
||||||
ctx->exp(0)->accept(this);
|
return visitChildren(ctx);
|
||||||
ctx->exp(1)->accept(this);
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitCond(SysYParser::CondContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitLValue(SysYParser::LValueContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitPrimaryExp(SysYParser::PrimaryExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitNumber(SysYParser::NumberContext* ctx) {
|
||||||
|
if (!ctx) {
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
std::any visitVar(SysYParser::VarContext* ctx) override {
|
if (ctx->ILITERAL()) {
|
||||||
if (!ctx || !ctx->ID()) {
|
ir_ctx_.SetType(ctx, SymbolType::TYPE_INT);
|
||||||
throw std::runtime_error(FormatError("sema", "非法变量引用"));
|
ir_ctx_.SetConstVal(ctx, std::any(0L));
|
||||||
}
|
} else if (ctx->FLITERAL()) {
|
||||||
const std::string name = ctx->ID()->getText();
|
ir_ctx_.SetType(ctx, SymbolType::TYPE_FLOAT);
|
||||||
auto* decl = table_.Lookup(name);
|
ir_ctx_.SetConstVal(ctx, std::any(0.0));
|
||||||
if (!decl) {
|
|
||||||
throw std::runtime_error(FormatError("sema", "使用了未定义的变量: " + name));
|
|
||||||
}
|
|
||||||
sema_.BindVarUse(ctx, decl);
|
|
||||||
return {};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
SemanticContext TakeSemanticContext() { return std::move(sema_); }
|
return {};
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
std::any SemaVisitor::visitUnaryExp(SysYParser::UnaryExpContext* ctx) {
|
||||||
SymbolTable table_;
|
return visitChildren(ctx);
|
||||||
SemanticContext sema_;
|
}
|
||||||
bool seen_return_ = false;
|
|
||||||
size_t current_item_index_ = 0;
|
|
||||||
size_t total_items_ = 0;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace
|
std::any SemaVisitor::visitUnaryOp(SysYParser::UnaryOpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitFuncRParams(SysYParser::FuncRParamsContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitMulExp(SysYParser::MulExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitAddExp(SysYParser::AddExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitRelExp(SysYParser::RelExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitEqExp(SysYParser::EqExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitLAndExp(SysYParser::LAndExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitLOrExp(SysYParser::LOrExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::any SemaVisitor::visitConstExp(SysYParser::ConstExpContext* ctx) {
|
||||||
|
return visitChildren(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
|
void RunSemanticAnalysis(SysYParser::CompUnitContext* ctx, IRGenContext& ir_ctx) {
|
||||||
|
if (!ctx) {
|
||||||
|
throw std::invalid_argument("CompUnitContext is null");
|
||||||
|
}
|
||||||
|
SemaVisitor visitor(ir_ctx);
|
||||||
|
visitor.visit(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
SemanticContext RunSema(SysYParser::CompUnitContext& comp_unit) {
|
SemanticContext RunSema(SysYParser::CompUnitContext& comp_unit) {
|
||||||
SemaVisitor visitor;
|
IRGenContext ctx;
|
||||||
comp_unit.accept(&visitor);
|
RunSemanticAnalysis(&comp_unit, ctx);
|
||||||
return visitor.TakeSemanticContext();
|
return SemanticContext();
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,17 +1,164 @@
|
|||||||
// 维护局部变量声明的注册与查找。
|
#include "../../include/sem/SymbolTable.h"
|
||||||
|
#include <stdexcept>
|
||||||
|
#include <string>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
#include "sem/SymbolTable.h"
|
// 进入新作用域
|
||||||
|
void SymbolTable::EnterScope() {
|
||||||
|
scopes_.push(ScopeEntry());
|
||||||
|
}
|
||||||
|
|
||||||
|
// 离开当前作用域
|
||||||
|
void SymbolTable::LeaveScope() {
|
||||||
|
if (scopes_.empty()) {
|
||||||
|
throw std::runtime_error("SymbolTable Error: 作用域栈为空,无法退出");
|
||||||
|
}
|
||||||
|
scopes_.pop();
|
||||||
|
}
|
||||||
|
|
||||||
|
// 绑定变量到当前作用域
|
||||||
|
void SymbolTable::BindVar(const std::string& name, const VarInfo& info, void* decl_ctx) {
|
||||||
|
if (CurrentScopeHasVar(name)) {
|
||||||
|
throw std::runtime_error("变量'" + name + "'在当前作用域重复定义");
|
||||||
|
}
|
||||||
|
scopes_.top().var_symbols[name] = {info, decl_ctx};
|
||||||
|
}
|
||||||
|
|
||||||
|
// 绑定函数到当前作用域
|
||||||
|
void SymbolTable::BindFunc(const std::string& name, const FuncInfo& info, void* decl_ctx) {
|
||||||
|
if (CurrentScopeHasFunc(name)) {
|
||||||
|
throw std::runtime_error("函数'" + name + "'在当前作用域重复定义");
|
||||||
|
}
|
||||||
|
scopes_.top().func_symbols[name] = {info, decl_ctx};
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查找变量(从当前作用域向上遍历)
|
||||||
|
bool SymbolTable::LookupVar(const std::string& name, VarInfo& out_info, void*& out_decl_ctx) const {
|
||||||
|
if (scopes_.empty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
auto temp_stack = scopes_;
|
||||||
|
while (!temp_stack.empty()) {
|
||||||
|
auto& scope = temp_stack.top();
|
||||||
|
auto it = scope.var_symbols.find(name);
|
||||||
|
if (it != scope.var_symbols.end()) {
|
||||||
|
out_info = it->second.first;
|
||||||
|
out_decl_ctx = it->second.second;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
temp_stack.pop();
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 查找函数(从当前作用域向上遍历,通常函数在全局作用域)
|
||||||
|
bool SymbolTable::LookupFunc(const std::string& name, FuncInfo& out_info, void*& out_decl_ctx) const {
|
||||||
|
if (scopes_.empty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
auto temp_stack = scopes_;
|
||||||
|
while (!temp_stack.empty()) {
|
||||||
|
auto& scope = temp_stack.top();
|
||||||
|
auto it = scope.func_symbols.find(name);
|
||||||
|
if (it != scope.func_symbols.end()) {
|
||||||
|
out_info = it->second.first;
|
||||||
|
out_decl_ctx = it->second.second;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
temp_stack.pop();
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void SymbolTable::Add(const std::string& name,
|
// 检查当前作用域是否包含指定变量
|
||||||
SysYParser::VarDefContext* decl) {
|
bool SymbolTable::CurrentScopeHasVar(const std::string& name) const {
|
||||||
table_[name] = decl;
|
if (scopes_.empty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return scopes_.top().var_symbols.count(name) > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SymbolTable::Contains(const std::string& name) const {
|
// 检查当前作用域是否包含指定函数
|
||||||
return table_.find(name) != table_.end();
|
bool SymbolTable::CurrentScopeHasFunc(const std::string& name) const {
|
||||||
|
if (scopes_.empty()) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return scopes_.top().func_symbols.count(name) > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
SysYParser::VarDefContext* SymbolTable::Lookup(const std::string& name) const {
|
// 进入循环
|
||||||
auto it = table_.find(name);
|
void SymbolTable::EnterLoop() {
|
||||||
return it == table_.end() ? nullptr : it->second;
|
loop_depth_++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 离开循环
|
||||||
|
void SymbolTable::ExitLoop() {
|
||||||
|
if (loop_depth_ > 0) loop_depth_--;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 检查是否在循环内
|
||||||
|
bool SymbolTable::InLoop() const {
|
||||||
|
return loop_depth_ > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 清空所有作用域和状态
|
||||||
|
void SymbolTable::Clear() {
|
||||||
|
while (!scopes_.empty()) {
|
||||||
|
scopes_.pop();
|
||||||
|
}
|
||||||
|
loop_depth_ = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取当前作用域中所有变量名
|
||||||
|
std::vector<std::string> SymbolTable::GetCurrentScopeVarNames() const {
|
||||||
|
std::vector<std::string> names;
|
||||||
|
if (!scopes_.empty()) {
|
||||||
|
for (const auto& pair : scopes_.top().var_symbols) {
|
||||||
|
names.push_back(pair.first);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return names;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 获取当前作用域中所有函数名
|
||||||
|
std::vector<std::string> SymbolTable::GetCurrentScopeFuncNames() const {
|
||||||
|
std::vector<std::string> names;
|
||||||
|
if (!scopes_.empty()) {
|
||||||
|
for (const auto& pair : scopes_.top().func_symbols) {
|
||||||
|
names.push_back(pair.first);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return names;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 调试:打印符号表内容
|
||||||
|
void SymbolTable::Dump() const {
|
||||||
|
std::cout << "符号表内容 (作用域深度: " << scopes_.size() << "):\n";
|
||||||
|
int scope_idx = 0;
|
||||||
|
auto temp_stack = scopes_;
|
||||||
|
|
||||||
|
while (!temp_stack.empty()) {
|
||||||
|
std::cout << "\n作用域 " << scope_idx++ << ":\n";
|
||||||
|
auto& scope = temp_stack.top();
|
||||||
|
|
||||||
|
std::cout << " 变量:\n";
|
||||||
|
for (const auto& var_pair : scope.var_symbols) {
|
||||||
|
const VarInfo& info = var_pair.second.first;
|
||||||
|
std::cout << " " << var_pair.first << ": "
|
||||||
|
<< SymbolTypeToString(info.type)
|
||||||
|
<< (info.is_const ? " (const)" : "")
|
||||||
|
<< (info.IsArray() ? " [数组]" : "")
|
||||||
|
<< "\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
std::cout << " 函数:\n";
|
||||||
|
for (const auto& func_pair : scope.func_symbols) {
|
||||||
|
const FuncInfo& info = func_pair.second.first;
|
||||||
|
std::cout << " " << func_pair.first << ": "
|
||||||
|
<< SymbolTypeToString(info.ret_type) << " ("
|
||||||
|
<< info.param_types.size() << " 个参数)\n";
|
||||||
|
}
|
||||||
|
|
||||||
|
temp_stack.pop();
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
Reference in new issue