|
3 жил өмнө | |
---|---|---|
include | 3 жил өмнө | |
pic | 3 жил өмнө | |
src | 3 жил өмнө | |
.gitignore | 3 жил өмнө | |
CMakeLists.txt | 3 жил өмнө | |
LICENSE | 3 жил өмнө | |
README.md | 3 жил өмнө | |
main.c | 3 жил өмнө |
使用C语言实现的BrainFuck解释器,并且扩展了部分语法。
Brainfuck,是一种极小化的程序语言,它是由Urban Müller在1993年创造的。这种语言有时被简称为BF。
使用: BrainFuck [参数] 文件..
参数:
-e --eval 从一个字符串中运行代码
-v --version 显示版本信息
-h --help 显示帮助信息
使用:指令[指令[指令...]]
指令:
> 读取头向后移动1格
< 读取头向前移动1格
+ 读取头所指格子的数据增加1
- 读取头所指格子的写入数据减1
>n 读取头向后移动n格
<n 读取头向前移动n格
+n 读取头所指格子的数据增加n
-n 读取头所指格子的写入数据减n
. 输出读取头所指格子的数据(字符形式)
, 对读取头所指格子的写入数据(字符形式)
: 输出读取头所指格子的数据(数字形式)
; 对读取头所指格子的写入数据(数字形式)
[ 循环初始位置(若读取头所指格子的数据不为0则循环)
] 循环结束位置
? 读取头回到初始位置
##命令行模式 执行完成指定文件后,BrainFuckPro进入命令行交互模式。使用者可以通过stdin即时写入指令操控读取头。 命令行菜单支持的操作(同时为步进模式菜单)
v 显示版本号
h 显示帮助
m 显示菜单
w 显示详细信息
p 显示纸带信息
r 显示读取头信息
s 开启/关闭步进模式 (默认关闭)
i 开启/关闭详细信息模式 (默认关闭)
c 清空屏幕 (调用系统clear指令)
q 退出
e 退出菜单
##关于API
BrainFuckPro为C语言提供了相应的API。若需要使用,请链接库BrainFuck_LIB
和包含头文件brainfuck.h
。
#define bf_setEnvMode(env, name, mode) (bf_setEnv##name##Mode((env), (mode)))
// bf_setEnvMode用于设置enc的mode
// 目前env的mode支持step(步进模式)和information(执行时显示信息)
// mode: 0-关闭 1-打开 -1-若打开则关闭,否则打开 其他值-无实际操作
// 返回值为对应mode的实际值
char *bf_getVersionInfo(void); // 获取版本和版本信息字符串
char *bf_getVersion(void); // 获取版本
// bf_env指针通常可以使用void *来代替
bf_env *bf_setEnv(void); // 设置一个运行环境(返回一个指针)
void bf_freeEnv(bf_env *env); // 释放一个环境
void bf_initEnv(bf_env *env); // 复位读取头到初始位置
// bf_code指针通常可以使用void *来代替
void bf_freeBrainFuck(bf_code code); // 释放代码
bf_code bf_parserBrainFuck_File(FILE *file); // 读取文件并生成代码(返回一个code)
bf_code bf_parserBrainFuck_Str(const char *str); // 读取字符串并生成代码(返回一个code)
void bf_printBrainFuck(bf_code code); // 打印代码
int bf_runBrainFuck(bf_code code, bf_env *env); // 在指定环境中执行代码 (返回0表示无异常)
void bf_printError(char *info, bf_env *env); // 打印错误信息, 若无错误则不执行
void bf_printPaperTape(bf_env *env); // 打印纸带
void bf_printHead(bf_env *env); // 打印读取头信息
void bf_printEnv(bf_env *env); // 打印env信息
void bf_printEnvWithMode(bf_env *env); // 打印env信息和env的mode信息
bf_STEP_FUNC bf_setEnvStepFunc(bf_env *env, bf_STEP_FUNC step_func); // 设置步进函数, 每次不仅时当用户输入m时则回调该函数(step_func)
bf_env
即图灵机的纸带,bf_code
即读取头的指令。二者本质上均为指针,且在brainfuck.h中无具体实现,使用者可以使用void *
来代替。
##构建
使用cmake+make来构建本项目。
创建目录
$ mkdir build
$ cd build
执行cmake
$ cmake ..
若在windows平台上使用Mingw编译,则
$ cmake .. -G "MinGW Makefiles"
使用make编译
$ make
安装程序
$ make install
可以在cmake时指定安装目录。
安装步骤不是必须的,你可以直接运行编译后的二进制文件。
可执行文件会安装在bin目录,动态库则会安装在lib目录(或bin目录),头文件则安装在include目录。
在windows平台下使用VisualStudio编译需要自行添加对getopt模块的支持。
##声明
###版权声明
版权所有 (c) 2021 SuperHuan 保留所有权利。
BrainFuckPro编程语言C解释器由SuperHuan开发,技术归属SuperHuan。
本授权协议适用于BrainFuckPro编程语言C解释器,SuperHuan拥有对本授权协议最终解释权和修改权。
BrainFuckPro编程语言C解释器为免费开源程序。
编译、运行该程序过程中造成的损失(包括但不限于系统损坏、文件丢失)均由您个人承担, 与开发者无关。
该代码是在 MIT License 下发布的。