Mark: 如何用Haskell写一个简单的编译器

原文链接: http://www.cnblogs.com/nanlan2017/p/10434301.html

作者:aaaron7

链接: https://www.zhihu.com/question/36756224/answer/88530013

如果是用 Haskell 的话,三篇文章足矣。

prerequisite: 懂 state monad就行了

第一篇,《How to build a monadic interpreter in one day》

跟着做,可以完成一个简单的backend, 也就是架构基本的AST 并执行的步骤。

然后到frontend, 也就是parser的部分你就会发现你看不懂了, 这个时候看第二篇。(因为该文的 parser 部分其实是 第二篇 的一个浓缩版,所以不看第二篇基本很难看懂这个部分)



第二篇,《Monadic Parser Combinator》 ,

看了也就能对照第一篇,把 parser 写出来了, 然后就能和之前的backend 组合,完成一个基本的,完全由自己手写的,monadic的解释器(parser 和 backend 分别由一个自定义的 state monad 实现)。顺便加深对 monad 的理解。

看第二篇的时候,回过头对照第一篇看效果会更高,虽然逻辑一样,但第二篇是用 monad comprehension 的形式来写, 第一篇是用 do notation 来写。有的复杂的地方你两种方式对照看一下,会有茅塞顿开的效果。

然后再看第三篇


第三篇,llvm的haskell 教程, Implementing a JIT Compiler with Haskell and LLVM ( Stephen Diehl ) , 把你的backend 换成llvm. (注:事先对 llvm 不熟的话,可以和 hackage 上面 llvm-general, llvm-general-pure 这两个库的 wiki, 以及 LLVM Language Reference Manual对照着看)

至于frontend, 可以换成Parsec之类,但也可以就不断扩充之前自己写的版本。

转载于:https://www.cnblogs.com/nanlan2017/p/10434301.html

猜你喜欢

转载自blog.csdn.net/weixin_30746117/article/details/94921056