Note: binary downloads are available, both "nightly" builds of the latest commit, and binaries for named releases.
Note: The instructions below may get out of date. When that happens, please submit an issue. In the meantime, guaranteed up-to-date instructions can be found by looking at the script, .travis.yml, used by the Travis CI service that automatically builds and tests VeriFast after each commit. This script first runs the command listed below install:
, and then the command listed below script:
.
To install the software needed to build VeriFast, first install Xcode (at least the command-line tools) and Homebrew. Then run setup-build.sh. This script does the following:
-
It installs the
gtk+
,gtksourceview
, andvala
packages usingbrew install
. -
It installs the OCaml-based dependencies:
- OCaml 4.06.0
- Findlib 1.7.3 (for the
ocamlfind
tool, used by Z3's install script) - OCaml-Num (arbitrary-precision arithmetic)
- Ocamlbuild (to build Camlp4)
- Camlp4 (an OCaml preprocessor, for the streams notation used in VeriFast's parser)
- Lablgtk (OCaml bindings to the GTK+ GUI toolkit)
- Z3 4.8.5 (a powerful theorem prover, including OCaml bindings)
It does so by downloading a VFDeps package with pre-compiled versions of these dependencies. Note: these binaries are location-dependent. They need to be below
/usr/local/vfdeps-$VERSION
, where$VERSION
is the version (Git hash) of the VFDeps package; that is, extract the archive into/usr/local
. To see which version is currently being used, see config.sh.
To build VeriFast:
cd src
- Make sure all dependencies are in your
PATH
. For example:export PATH=/usr/local/vfdeps-$VERSION/bin:$PATH
. - Make sure the dependencies' DLLs can be found by the macOS DLL loader. For example:
export DYLD_LIBRARY_PATH=/usr/local/vfdeps-$VERSION/lib:$DYLD_LIBRARY_PATH
. make