1
1
mirror of https://github.com/anoma/juvix.git synced 2024-12-11 08:25:46 +03:00
Juvix empowers developers to write code in a high-level, functional language, compile it to gas-efficient output VM instructions, and formally verify the safety of their contracts prior to deployment and execution.
Go to file
2022-02-11 19:12:48 +01:00
.github/workflows fix compilation errors 2021-12-23 11:19:46 +01:00
app [errors] setup some ground for prettier errors 2022-02-11 19:12:48 +01:00
assets [html] add light theme; add cli option to pick theme 2022-02-05 23:15:42 +01:00
docs Revisions on Frid. 17 Dec 2021-12-17 12:33:02 +00:00
examples [stdlib] add MiniJuvix standard library as a submodule 2022-02-03 18:06:59 +01:00
minijuvix-stdlib@a07c8cd1cc implement parsing and scoping of module parameters 2022-02-10 19:39:51 +01:00
notes [scoper] module scoping WIP 2022-01-28 12:06:29 +01:00
src/MiniJuvix [errors] setup some ground for prettier errors 2022-02-11 19:12:48 +01:00
test [test] remove qualified-by-type constructors 2022-01-21 09:20:27 +01:00
.gitignore delete and ignore .ghci 2021-12-28 17:20:36 +01:00
.gitmodules [stdlib] add MiniJuvix standard library as a submodule 2022-02-03 18:06:59 +01:00
.hlint.yaml [ Makefile ] fixies for make prepare-push target 2021-12-30 09:56:58 -05:00
CHANGELOG.md First commit, initial project template. 2021-09-26 18:59:51 +02:00
hie.yaml [app] prepare app 2022-01-18 13:30:49 +01:00
LICENSE First commit, initial project template. 2021-09-26 18:59:51 +02:00
Makefile [ Makefile ] fixies for make prepare-push target 2021-12-30 09:56:58 -05:00
minijuvix.agda-lib WIP. Adapting source code from heliaxdev/juvix for parsing purposes. 2021-11-11 20:08:49 +01:00
package.yaml [html] improve html pretty printing 2022-02-05 13:27:33 +01:00
README.md [ README ] fixed broken links 2021-12-30 10:53:36 -05:00
stack.yaml [dependencies] update to ghc 9.0.2 2022-01-11 10:23:45 +01:00

MiniJuvix GPL-3.0-only license Haskell CI

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ᵢ .