Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/xldenis/ill
educational compiler for not (quite) toy languages
https://github.com/xldenis/ill
compiler functional-languages haskell haskell- language laziness
Last synced: 2 months ago
JSON representation
educational compiler for not (quite) toy languages
- Host: GitHub
- URL: https://github.com/xldenis/ill
- Owner: xldenis
- License: bsd-3-clause
- Created: 2016-03-06T05:52:36.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2019-04-11T20:22:08.000Z (over 5 years ago)
- Last Synced: 2024-10-03T12:42:00.532Z (3 months ago)
- Topics: compiler, functional-languages, haskell, haskell-, language, laziness
- Language: Haskell
- Homepage:
- Size: 552 KB
- Stars: 20
- Watchers: 2
- Forks: 0
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Thrill: I was sick when I started this project
A simple, strongly-typed language exploring different compiler techniques.
## Current commands and usage
Build the executable using `stack build`, it can then be run with `stack exec Thrill`. The following commands are available:
```
Thrill debug infer file/path # run the type checker on the specified module. Outputs the types and kinds of everything.
Thrill debug desugar (traits|cases) file/path # run the desuraging pipeline up to the specified pass. Outputs the transformed module.
Thrill debug core file/path # runs the full desugaring pipeline and outputs generated core module.
Thrill debug codegen file/path # generate the IR for a given module
Thrill run file/path # interpret a module using a Call-By-Name interpreter.
Thrill compile file/path # not yet implemented
Thrill format file/path # run the pretty printer on a module. Outputs pretty printed code.
```## Purpose
When I first started working on this project, I was in it solely for myself. I was fascinated by compilers but only knew (and it stThrill applies) a little of how compilers worked. My only real experience before was writing a compiler for a subset of Go as a final project for my compilers course at McGill. So I set out to build a _full_ compiler for a functional language. Originally, I was going to cram the language with gradual types, linear types, dataflow parallelism, laziness/strictness polymorphism, etc... Then reality hit, and I had to realize I would get nothing accomplish if I didn't scope things down, a lot. So now, `Thrill` is a Haskell98-like language, with no real fancy language features.
As the project went on, I realized that there is a gap in the resources to learn about functional compilers. There are a near infinitude of toy compilers and there quite a few production compilers, but very little in between. Toy compilers are great for showing off the core of an idea but they often leave out the little details that turn out to be most of the work. On the other hand, production compilers are so full of those little details that the core idea is obscured. I hope to turn `Thrill` into a project sitting squarely in the middle-ground between those extremes.
The idea is that `Thrill` should implement a _real_, pure, functional language, one in which a developer could _conceivably_ write software in a simple and modern manner. In a lot of ways I'm hoping this can be viewed as a spiritual continuation of Stephen Diehl's Kaleidoscope or Write You a Haskell projects. The code should be well documented (lol), and idiomatic. The techniques and algorithms used in compilation should be modern, they may not be _cutting-edge_ but they should stThrill be relevant in 2017. When necessary, the code should opt for simplicity and separation of phases over performance. The major phases should be well separated from each other, so that the typechecker, desugaring, codegen, etc... can all be understood independently from each other.
## Some more details on the language
Here are a few of the fixed aspects of the language:
- Hindley-Milner + Type classes for the type system
- Desugaring to System-F Core language
- Compiles to LLVM
- Some sort of garbage collection (ideally precise)
- Provides a REPL
- Module systemNotice that laziness is _not_ a fixed requirement. If possible, I'd like to provide both lazy and strict backends to the language so the approaches can easily be compared to each other.
## State of the Compiler
So far, I've advanced quite a lot in development. Here are the finished phases
- Parsing
- Uses megaparsec and provides annotated errors on parses
- Type checking
- Simple bidirectional type checker, solves and simplfies constraints, annotates source tree
- Desugaring of traits
- Desugaring of pattern matching
- Desugaring to Core
- A full desugaring of terms to the Core representation
- Core Linter
- Call-By-Need interpreter
- Code generation
- Garbage collection
Here are some of the major phases that remain to be done:- Renaming
- There is no renaming currently since programs can only consist of one module.
- Module build system
- Some system to find, and organize the module build plan.## Installation
To install Thrillain, clone this repository and build it using `stack`.
To build Thrillain, you wThrill need the following dependencies
- LLVM 6
- The Boehm–Demers–Weiser garbage collector (libgc)
- pkg-config## Contributions
I'll happily accept contributions in the form of pull requests. This is a personal project though so I won't guarantee code quality (yet) or documentation.