« Up

htt 1.0.0 4 m 0 s 🏆

Context

# Packages matching: installed
# Name              # Installed # Synopsis
base-bigarray       base
base-threads        base
base-unix           base
conf-findutils      1           Virtual package relying on findutils
conf-gmp            4           Virtual package relying on a GMP lib system installation
coq                 dev         Formal proof management system
dune                3.1.1       Fast, portable, and opinionated build system
ocaml               4.10.2      The OCaml compiler (virtual package)
ocaml-base-compiler 4.10.2      Official release 4.10.2
ocaml-config        1           OCaml Switch Configuration
ocamlfind           1.9.3       A library manager for OCaml
zarith              1.12        Implements arithmetic and logical operations over arbitrary-precision integers
# opam file:
opam-version: "2.0"
maintainer: "fcsl@software.imdea.org"
homepage: "https://github.com/imdea-software/htt"
dev-repo: "git+https://github.com/imdea-software/htt.git"
bug-reports: "https://github.com/imdea-software/htt/issues"
license: "Apache-2.0"
build: [make "-j%{jobs}%"]
install: [make "install"]
depends: [
  "coq" { (>= "8.14" & < "8.16~") | (= "dev") }
  "coq-mathcomp-ssreflect" { (>= "1.13.0" & < "1.15~") | (= "dev") }
  "coq-fcsl-pcm" { (>= "1.5.0" & < "1.6~") | (= "dev") }
]
tags: [
  "category:Computer Science/Data Types and Data Structures"
  "keyword:partial commutative monoids"
  "keyword:separation logic"
  "logpath:HTT"
]
authors: [
  "Aleksandar Nanevski"
  "Germán Andrés Delbianco"
  "Alexander Gryzlov"
]
synopsis: "Hoare Type Theory"
description: """
Hoare Type Theory (HTT) is a verification system for reasoning about sequential heap-manipulating
programs based on separation logic.
HTT incorporates Hoare-style specifications via preconditions and postconditions into types.
A Hoare type `ST P (fun x : A => Q)` denotes computations with a precondition `P` and
postcondition `Q`, returning a value `x` of type `A`. Hoare types are a dependently typed version
of monads, as used in the programming language Haskell. Monads hygienically combine the language
features for pure functional programming, with those for imperative programming, such as state
or exceptions. In this sense, HTT establishes a formal connection between (functional programming
variant of) Separation logic and monads, in the style of Curry-Howard isomorphism. Every
effectful command in HTT has a type which corresponds to the appropriate non-structural inference
rule in Separation logic, and vice versa, every non-structural inference rule corresponds to a
command in HTT that has that rule as the type. The type for monadic bind is the Hoare-style rule
for sequential composition, and the type for monadic unit combines the Hoare-style rule for the
idle program and the Hoare-style rule for variable assignment (adapted for functional variables).
In implementation terms, the above means that HTT implements Separation logic as a shallow
embedding in Coq."""
url {
  src: "https://github.com/imdea-software/htt/archive/v1.0.0.tar.gz"
  checksum: "sha256=8e34a0b31e9fb70699dd9de96738a3647b38d00c7c407095128c121121138b64"
}

Lint

Command
true
Return code
0

Dry install 🏜️

Dry install with the current Coq version:

Command
opam install -y --show-action coq-htt.1.0.0 coq.dev
Return code
0

Dry install without Coq/switch base, to test if the problem was incompatibility with the current Coq/OCaml version:

Command
true
Return code
0

Install dependencies

Command
opam list; echo; ulimit -Sv 4000000; timeout 4h opam install -y --deps-only coq-htt.1.0.0 coq.dev
Return code
0
Duration
5 m 0 s

Install 🚀

Command
opam list; echo; ulimit -Sv 16000000; timeout 4h opam install -y -v coq-htt.1.0.0 coq.dev
Return code
0
Duration
4 m 0 s

Installation size

Total: 5 M

  • 1 M ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/congmath.vo
  • 454 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/congmath.glob
  • 291 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/model.vo
  • 264 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/kvmaps.vo
  • 215 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/domain.vo
  • 194 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/llist.vo
  • 166 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/hashtab.vo
  • 165 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/domain.glob
  • 156 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/dlist.vo
  • 151 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/model.glob
  • 118 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/queue.vo
  • 110 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/heapauto.vo
  • 106 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/kvmaps.glob
  • 101 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/array.vo
  • 93 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/heapauto.glob
  • 69 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/congmath.v
  • 60 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/llist.glob
  • 57 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/stack.vo
  • 53 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/dlist.glob
  • 51 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/hashtab.glob
  • 51 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/array.glob
  • 37 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/domain.v
  • 34 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/model.v
  • 33 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/queue.glob
  • 27 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/interlude.vo
  • 25 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/heapauto.v
  • 23 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/kvmaps.v
  • 12 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/llist.v
  • 11 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/stack.glob
  • 11 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/interlude.glob
  • 11 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/hashtab.v
  • 9 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/array.v
  • 9 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/dlist.v
  • 7 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/queue.v
  • 5 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/exploit.vo
  • 3 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/stack.v
  • 2 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/exploit.glob
  • 2 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/core/interlude.v
  • 2 K ../ocaml-base-compiler.4.10.2/lib/coq/user-contrib/HTT/examples/exploit.v

Uninstall 🧹

Command
opam remove -y coq-htt.1.0.0
Return code
0
Missing removes
none
Wrong removes
none