构建Lua解释器Part0:综述

项目简介

        lua是一门精妙简洁,而功能强大的语言,学习和掌握它的核心机制有着重要的意义。这是一个仿制lua解释器的项目(参照的版本是Lua5.3),我希望通过逐步实现lua解释器的各个部分,更加深刻地掌握lua的基本结构和运作原理。本项目将分为多个部分完成,并为每一个部分附上一篇博文为该部分的设计和实现进行解析。开发这个项目的目的,并不是做一个能用于生产环境的lua解释器,而是尝试追寻前辈的步伐,尽最大可能理解其设计lua语言的思路,理解其中的关键细节。这是一个探索原理的旅程,因此效率并不是本项目要考虑的关键因素。这里我遵循的是”FIRST make it run, THEN make it run fast”[1]的原则,先让它跑起来。整个系列暂时不包含GC部分,不过这些开发量也足以消耗我大量的时间和精力。

        本项目采取和官方版本的近似的命名规范,并尽最大努力遵循lua官方的设计主线。由于开发过程是我自己重新手写的,因此不会在所有细节和官方版本保持一致。同时这是一份参考资料,主旨是提供一条思路主线,希望读者通过阅读这个系列,降低对lua源码的阅读难度,同时不建议跟随本旅程来研究lua。最终希望读者在完成本系列的阅读后,回到研究lua官方源码的道路上。
        本系列将会为一些观点,理论附注上引证来源,并在Reference上展示,最后本人水平有限,如果有错误的地方,希望大家联系我加以指正。同时欢迎大家加入我创建的qq群185017593一起讨论技术。

系列内容

编译与运行

获取仓库

git clone git@github.com:Manistein/dummylua-tutorial.git

在Linux和Mac上编译与运行

cd dummylua-tutorial/
cd linux/
cd part01/
make

cd bin/
./dummylua

在Windows上编译与运行

  • 进入dummylua-tutorial/windows/project/
  • 使用VS2013或以上版本打开sln文件
  • 自行编译和运行

测试平台

  • Linux(Ubuntu)
  • Windows
  • Mac

项目github地址

https://github.com/Manistein/dummylua-tutorial

Reference

[1] LET’S BUILD A COMPILER! Part I: INTRODUCTION “As Brian Kernighan has said, FIRST make it run, THEN make it run fast.”