package why3

  1. Overview
  2. Docs
Why3 environment for deductive program verification

Install

dune-project
 Dependency

Authors

Maintainers

Sources

why3-1.8.2.tar.gz
sha256=b7d112edd5bcce6bcce0023d2bc834eb2ae1a1c42d7aea44ffa124d649b50bea
md5=76244d73d2cdaff1dbae867b60d0aa0d

Description

Why3 provides a rich language for specification and programming, called WhyML, and relies on external theorem provers, both automated and interactive, to discharge verification conditions. Why3 comes with a standard library of logical theories (integer and real arithmetic, Boolean operations, sets and maps, etc.) and basic programming data structures (arrays, queues, hash tables, etc.). A user can write WhyML programs directly and get correct-by-construction OCaml or C programs through an automated extraction mechanism. WhyML is also used as an intermediate language for the verification of C, Java, Rust, and Ada programs.

Why3 is a complete reimplementation of the former Why platform. Among the new features are: numerous extensions to the input language, a new architecture for calling external provers, and a well-designed API, allowing to use Why3 as a software library. An important emphasis is put on modularity and genericity, giving the end user a possibility to easily reuse Why3 formalizations or to add support for a new external prover if wanted.

Dependencies (4)

  1. zarith
  2. menhir >= "20200211"
  3. ocamlfind build
  4. ocaml >= "4.09" & < "5.5"

Dev Dependencies (1)

  1. conf-autoconf build & dev

Used by (7)

  1. frama-c >= "31.0~beta"
  2. frama-c-metacsl < "0.4"
  3. lambdapi >= "2.6.0"
  4. pilat >= "1.6"
  5. why3-coq >= "1.8.2"
  6. why3-ide >= "1.8.2"
  7. why3find

Conflicts (3)

  1. mlmpfr < "4.0.0"
  2. ocamlgraph < "1.8.2"
  3. why3-base