Skip to content

Harris-pku/sysy-compiler

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

基于 Makefile 的 SysY 编译器项目

该项目为2022年春季学期《编译原理》课程期末大作业,从模板仓库获取,该仓库中存放了一个基于 Makefile 的 SysY 编译器项目的模板, 可以根据项目指导文档在该模板的基础上进行进一步的开发.

该仓库中的 C/C++ 代码实现仅作为演示, 不代表你的编译器必须以此方式实现. 如你需要使用该模板, 建议你删掉所有 C/C++ 源文件, 仅保留 Makefile 和必要的目录结构, 然后重新开始实现.

该模板仅供不熟悉 Makefile 的同学参考, 在理解基本原理的基础上, 你完全可以不使用模板完成编译器的实现. 如你决定不使用该模板并自行编写 Makefile, 请参考 “评测平台要求” 部分.

使用方法

首先 clone 本仓库:

git clone https://github.com/pku-minic/sysy-make-template.git

compiler-dev 环境内, 进入仓库目录后执行 make 即可编译得到可执行文件 (默认位于 build/compiler):

cd sysy-make-template
make

如在此基础上进行开发, 你需要重新初始化 Git 仓库:

rm -rf .git
git init

然后, 根据情况修改 Makefile 中的 CPP_MODE 参数. 如果你决定使用 C 语言进行开发, 你应该将其值改为 0.

最后, 将自己的编译器的源文件放入 src 目录.

测试要求

当你提交一个根目录包含 Makefile 文件的仓库时, 测试脚本/评测平台会使用如下命令编译你的编译器:

make DEBUG=0 BUILD_DIR="build目录" LIB_DIR="libkoopa目录" INC_DIR="libkoopa头文件目录" -C "repo目录"

你的 Makefile 必须依据 BUILD_DIR 参数的值, 将生成的可执行文件输出到该路径中, 并命名为 compiler.

如需链接 libkoopa, 你的 Makefile 应当处理 LIB_DIRINC_DIR.

模板中的 Makefile 已经处理了上述内容, 你无需额外关心.

About

基于 Makefile 的 SysY 编译器项目

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published