Skip to content

Latest commit

 

History

History
29 lines (19 loc) · 1.66 KB

README.md

File metadata and controls

29 lines (19 loc) · 1.66 KB

Disp

Goals

  • All-purpose: Disp will be able to be used for scripting, shells, and compiled languages.
  • Speed: Disp will be as fast if not faster than Rust, C and adjacent languages, even when writing high-level code.
  • Provably Safe: Disp programs compiled to machinecode will carry proofs of correctness written for a software model of the target CPU.
  • Syntax-agnostic: Anyone from any language should be able to come to Disp without having to re-learn syntax preferences. This can be solved through various syntax variants of disp expressions that reflect the syntax of various languages.

Disp is still just a personal project as this stage. It is currently just a simple untyped lambda calculus evaluator and some math functions made using Church Encoding.

To Run:

nix develop
cargo run

load "std.disp"

Old Roadmap

Function that takes an untyped program and infers its type in a two-sort pure type system based on the calculus of inductive constructions.

Function that takes a typed program and generates a program that replaces inductive types with types that can be easily represented in binary. (i.e. translate Church encoded numbers into unsigned integers).

Function that takes program with supported types in addition to different translation strategies and generates relevant LLVM bytecode. (translation strategies are programs that say: "if I see this function and this type, I should generate this assembly).

Implementation Details