Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/sourcedennis/rust-pi-forall

A partial re-implementation of pi-forall in Rust
https://github.com/sourcedennis/rust-pi-forall

dependent-types

Last synced: about 2 months ago
JSON representation

A partial re-implementation of pi-forall in Rust

Awesome Lists containing this project

README

        

# Rust pi-forall

An implementation of [pi-forall](https://github.com/sweirich/pi-forall) in [Rust](https://www.rust-lang.org).

## Motivation

pi-forall is a demo dependently-typed programming language. Its reference implementation is written in [Haskell](https://www.haskell.org), which is accompanied by lecture notes. In this repository, I replicate that work in Rust.

I replicate the `full/` variant of pi-forall presented at OPLSS [2022](https://github.com/sweirich/pi-forall/tree/2022). Though, I only reimplemented *a subset* of features that I consider interesting. Also keep in mind that idiomatic Rust has a vastly different structure from idiomatic Haskell; No monads, nor its transformers.

## Features

Currently, we support:

* Equality
* Irrelevance

That roughly corresponds with `version3/`. Datatypes are still missing. (Though, the parser supports `case` statements)

## Running

First, [install Rust](https://www.rust-lang.org/tools/install). Then, run (in this directory):

```sh
cargo run --release -- pi/Lec1.pi
```

That typechecks `pi/Lec1.pi`.