.github/workflows | ||
agda-proofs | ||
app | ||
assets | ||
docs | ||
examples | ||
minijuvix-stdlib@ad8392f76e | ||
notes | ||
src/MiniJuvix | ||
test | ||
tests | ||
.gitignore | ||
.gitmodules | ||
.hlint.yaml | ||
CHANGELOG.md | ||
hie.yaml | ||
LICENSE | ||
Makefile | ||
minijuvix.agda-lib | ||
package.yaml | ||
README.md | ||
stack.yaml |
MiniJuvix
This repository aims to be a conservative Haskell project of a tiny language with dependent types based on the Juvix project. The primary purpose is to be a laboratory to study/experiment in implementing a functional language with dependent types.
In this branch qtt
, MiniJuvix aims to be programming language based
on Quantitative type theory. Some Haskell code has been generated
automatically by agda2hs
. In the future, we want to prove properties
about the Minijuvix programs directly in Agda.
The following is a tentative project structure, but it can change at any moment. See below the file project structure. The diagram shows the design of the compiler related with the project structure.
In the picture, syntax transformations are denoted by pᵢ and checking operations are denoted by cᵢ .