# 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 8.16.1 Formal proof management system dune 3.12.1 Fast, portable, and opinionated build system ocaml 4.13.1 The OCaml compiler (virtual package) ocaml-base-compiler 4.13.1 Official release 4.13.1 ocaml-config 2 OCaml Switch Configuration ocaml-options-vanilla 1 Ensure that OCaml is compiled with no special options enabled ocamlfind 1.9.6 A library manager for OCaml zarith 1.13 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.17~") | (= "dev") } "coq-mathcomp-ssreflect" { (>= "1.13.0" & < "1.16~") | (= "dev") } "coq-mathcomp-fingroup" "coq-fcsl-pcm" { (>= "1.7.0" & < "1.8~") | (= "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 in the style of Curry-Howard isomorphism between monads and (functional programming variant of) Separation logic. Every effectful command in HTT has a type that 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 rule for sequential composition, and the type for monadic unit combines the Hoare rules for the idle program (in a small-footprint variant) and for variable assignment (adapted for functional variables). The connection reconciles dependent types with effects of state and exceptions and establishes Separation logic as a type theory for such effects. In implementation terms, it means that HTT implements Separation logic as a shallow embedding in Coq.""" url { src: "https://github.com/imdea-software/htt/archive/v1.2.0.tar.gz" checksum: "sha256=6e221b1e0e38560c7cb5afc1da2be93e066890448bf3077c25c09eaa130abc42" }
true
Dry install with the current Coq version:
opam install -y --show-action coq-htt.1.2.0 coq.8.16.1
Dry install without Coq/switch base, to test if the problem was incompatibility with the current Coq/OCaml version:
true
opam list; echo; ulimit -Sv 4000000; timeout 4h opam install -y --deps-only coq-htt.1.2.0 coq.8.16.1
opam list; echo; ulimit -Sv 16000000; timeout 4h opam install -y -v coq-htt.1.2.0 coq.8.16.1
Total: 6 M
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/congmath.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/congmath.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bubblesort.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/model.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/kvmaps.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bubblesort.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/domain.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/llist.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bintree.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/cyclic.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/hashtab.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/domain.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/model.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/dlist.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bst.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/queue.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/heapauto.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/kvmaps.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/array.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/heapauto.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/congmath.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/llist.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/cyclic.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/stack.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/dlist.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/array.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/hashtab.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bst.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bintree.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/interlude.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/gcd.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/domain.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/model.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/interlude.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/queue.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bubblesort.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/heapauto.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/kvmaps.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/cyclic.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/llist.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/stack.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/gcd.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/hashtab.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bst.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/array.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/dlist.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/bintree.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/queue.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/exploit.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/htt/interlude.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/stack.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/gcd.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/exploit.glob
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/options.vo
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/examples/exploit.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/options.v
../ocaml-base-compiler.4.13.1/lib/coq/user-contrib/htt/options.glob
opam remove -y coq-htt.1.2.0