Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/blaisorblade/dot-iris
Scala Step-by-Step: Soundness for DOT with Step-Indexed Logical Relations in Iris — Coq Formalization
https://github.com/blaisorblade/dot-iris
coq coq-formalization coq-formalizations dot-calculus paper soundness type-theory
Last synced: 3 months ago
JSON representation
Scala Step-by-Step: Soundness for DOT with Step-Indexed Logical Relations in Iris — Coq Formalization
- Host: GitHub
- URL: https://github.com/blaisorblade/dot-iris
- Owner: Blaisorblade
- License: other
- Created: 2018-11-01T15:21:51.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-08-22T20:49:57.000Z (5 months ago)
- Last Synced: 2024-10-16T09:09:42.054Z (3 months ago)
- Topics: coq, coq-formalization, coq-formalizations, dot-calculus, paper, soundness, type-theory
- Language: HTML
- Homepage: https://dot-iris.github.io
- Size: 10 MB
- Stars: 31
- Watchers: 5
- Forks: 1
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: changelog.md
- License: LICENSE
Awesome Lists containing this project
README
# Type Soundness for DOT via logical relations
[![Build Status](https://travis-ci.org/Blaisorblade/dot-iris.svg?branch=master)](https://travis-ci.org/Blaisorblade/dot-iris)
[![Artifact DOI](https://zenodo.org/badge/DOI/10.5281/zenodo.3926703.svg)](https://doi.org/10.5281/zenodo.3926703)Mechanization accompanying the paper [Scala Step-by-Step: Soundness for
DOT with Step-Indexed Logical Relations in Iris](https://dot-iris.github.io/),
published at [ICFP 2020](https://dl.acm.org/doi/10.1145/3408996).The mapping between the paper and this mechanization, together with the
layout of the codebase, is described in [`correspondence.md`](correspondence.md).
See below for how to process sources with coqdoc.We have also provided [an artifact](https://doi.org/10.5281/zenodo.3926703),
matching our [v1.0](https://github.com/Blaisorblade/dot-iris/tree/v1.0) release.
Its instructions are in [`00Artifact-README.md`](00Artifact-README.md).## Compiling the Proof the first time
### Requirements
- GNU make
- [opam 2.0.6](https://opam.ocaml.org/doc/Install.html) or later.### Cloning this repository
After the cloning, run
```
git submodule update --init --recursive
```
to fetch all git submodules.### Installing dependencies
The following commands will install the correct Coq version and the
correct versions of the std++ and Iris libraries.- If `opam` is not configured, run its setup wizard with `opam init`.
- Then, prepare for installation with:
```shell
eval $(opam env)
opam repo add coq-released https://coq.inria.fr/opam/released --set-default --all
opam repo add iris-dev https://gitlab.mpi-sws.org/iris/opam.git --set-default --all
opam update
```
- If you use `opam` for other Coq projects, we recommend setting up a dedicated
`opam` switch. Instructions appear in [`development.md`](./development.md).
- Actually install dependencies with:
```shell
opam install --deps-only .
```### Compiling the actual proof
Run `make -jN` to build the full development, where N is the number of your
CPU cores; that should take around 5-10 minutes.### Browsing published coqdoc
Start from [here](https://dot-iris.github.io/coqdoc/).
### Running coqdoc
Run `make html` to run coqdoc over the code, to obtain an hyperlinked version
(for ease of cross-referencing).
`html/toc.html` offers an index for navigation; keep in mind that
[`correspondence.md`](correspondence.md) is a better overview.## Documentation for developers / additional docs (not relevant to paper)
See [`development.md`](development.md).