Skip to content

Latest commit

 

History

History
120 lines (103 loc) · 4.59 KB

README.md

File metadata and controls

120 lines (103 loc) · 4.59 KB

Type preserving compilation for a simply typed functional language

The goal of this project is to demonstrate compilation of a simply typed functional language to various low-level target languages. We aim to preserve types as long as possible, up to code-generation time.

Compiler overview

Language Description
Surface User-friendly surface language
Core Simple, minimal core language
Anf STLC with an explicit evaluation order (A-normal form)
Clos STLC in A-normal form with explicit closures
Monadic STLC with a separation between values and effectful expressions
Translation Source Target
Core_to_anf : Core Anf
Core_to_monadic : Core Monadic

Todo list

Intermediate languages:

  • Surface language (Surface)
  • Core language (Core)
  • ANF language (Anf)
  • ANF + CC language (Clos)
  • Monadic language (Monadic)
  • SSA language
  • TAL language

Translations:

  • Lexer
  • Parser
  • Elaboration to core (Surface)
  • ANF-translation (Core_to_anf)
  • Monadic translation (Core_to_monadic)
  • Closure conversion
  • Hoisting
  • Single static assignment

Code generation targets:

  • WASM codegen
  • LLVM codegen
  • Cranelift codegen

Other features:

  • Type checking for IRs
  • Example based tests
  • Type-directed property tests
  • Optimisations on intermediate languages

Proposed compiler pipeline

                  ╭────────────────╮
                  │  Surface.expr  │
                  ╰────────────────╯
                          │
                  Surface.Elab.synth
                          │
                          ▼
                  ╭────────────────╮
                  │   Core.expr    │
                  ╰────────────────╯
                          │
            ╭─────────────┴───────────────╮
            │                             │
   Core.To_anf.translate         Core.To_monadic.translate
            │                             │
            ▼                             ▼
    ╭────────────────╮            ╭────────────────╮
    │    Anf.expr    │            │  Monadic.expr  │
    ╰────────────────╯            ╰────────────────╯
            │
   Anf.To_clos.translate
            │
            │     ╭───────────────╮
            ▼     ▼               │
    ╭────────────────╮            │
    │    Clos.expr   │   Clos.Hoist.translate
    ╰────────────────╯            │
            │     │               │
            │     ╰───────────────╯
            │
            ├─────────────────┬──── Clos.To_wasm.translate ─────────▶︎ ...
            │                 │
            │                 ├──── Clos.To_llvm.translate ─────────▶︎ ...
            │                 │
            │                 ╰──── Clos.To_cranelift.translate ────▶︎ ...
            │
   Clos.To_ssa.translate
            │
            ▼
    ╭────────────────╮
    │   Ssa.prog     │
    ╰────────────────╯
            │
   Ssa.To_tal.translate
            │
    ╭────────────────╮
    │   Tal.prog     │
    ╰────────────────╯
            │
            ╰──── Tal.To_<asm_aarget>.translate ────▶︎ ...