README.md

    Play With Complier

    本项目是极客时间的《编译原理之美》课程的示例代码。

    课程Web网址:https://time.geekbang.org/column/intro/219

    或者下载“极客时间”APP,查找《编译原理之美》课程。

    目录内容

    lab

    课程实验和资料。

    • lab/01 :第1讲的资料,包含一个pdf文档,是第一课中提到的自动生成parser的工具。
    • lab/craft : 第2-5讲的资料。手工实现的简单的词法分析器、语法分析器、计算器、脚本解释器。
      • SimpleLexer.java:一个简单的词法分析器。
      • SimpleCalculator.java:一个简单的计算器,提供了基础的语法分析功能。对表达式的解析会有结合性问题。
      • SimpleParser.java: 一个更好的语法解析器。在左递归、优先级和结合性方面都没有问题。
      • SimpleScript.java:一个简单的脚本解释器。它提供了一个REPL界面,输入命令并执行。
        比如,输入: java SimpleScript
        或:java SimpleScript -v
        -v 参数会让解释器打印AST和求值过程。
    • lab/antlrtest : 第6讲的示例代码。
    • lab/16-18 : 第16-18讲,算法篇的示例代码
      • Regex.java : 正则表达式工具,包括从正则表达式生成NFA,从NFA生成DFA,以及基于NFA和DFA做字符串匹配。
      • Lexer.java : 基于正则表达式自动做词法分析。
      • GrammarNode.java : 文法。能像EBNF那样表示词法和语法。
      • State.java : 有限自动机节点。
      • DFAState.java : DFA的节点。

    playscript-java

    这是一个java版本的脚本语言的参考实现,课程第7讲之后的示例以该项目为核心。
    详细介绍,参见playscript-java的说明

    环境配置

    注意

    随着课程进度,会不断更新资料内容和本文档的内容。
    本项目的代码也会处在不断的变化中。

    项目简介

    https://github.com/RichardGong/PlayWithCompiler 编译原理之美代码示例

    发行版本

    当前项目没有发行版本

    贡献者 1

    R Richard Gong @Richard Gong

    开发语言

    • Java 52.8 %
    • C++ 38.1 %
    • ANTLR 5.1 %
    • Assembly 1.7 %
    • Makefile 1.0 %