What architecture?
------------------

CPROVER now needs a C++11 compliant compiler and works in the following
environments:

- Linux

- MacOS X

- Solaris 11

- FreeBSD 10

- Cygwin
  (We recommend the i686-pc-mingw32-g++ cross compiler, version 4.7 or above.)

- Microsoft's Visual Studio 2012 or 2013 (older versions won't work)

The rest of this document is split up into three parts: compilation on
Linux, MacOS, Windows.  Please read the section appropriate for your
machine.


COMPILATION ON LINUX
--------------------

We assume that you have a Debian/Ubuntu or Red Hat-like distribution.

0) You need a C/C++ compiler, Flex and Bison, and GNU make.
   The GNU Make needs to be version 3.81 or higher. On Debian-like
   distributions, do

   apt-get install g++ gcc flex bison make subversion libz-dev libwww-perl patch libzip-dev

   On Red Hat/Fedora or derivates, do

   yum install gcc gcc-c++ flex bison perl-libwww-perl patch

   WARNING: g++ 4.5.x has been observed to mis-optimize code in
   MiniSat with -O3. You must use a newer version.

1) As a user, get the CBMC source via

   svn co http://www.cprover.org/svn/cbmc/trunk cbmc-trunk

2) Do

   cd cbmc-trunk/src
   make minisat2-download
   make


COMPILATION ON SOLARIS 11
-------------------------

0) We recommend you get OpenCSW. Follow the instructions at

   http://www.opencsw.org/manual/for-administrators/getting-started.html

1) As root, get the necessary development tools:

   pkg install system/header
   /opt/csw/bin/pkgutil -i gzip coreutils wget CSWpm-libwww-perl subversion flex bison CSWgcc4g++

2) As a user, get the CBMC source via

   svn co http://www.cprover.org/svn/cbmc/trunk cbmc-trunk

3) Get MiniSat2 by entering

   cd cbmc-trunk
   wget http://ftp.debian.org/debian/pool/main/m/minisat2/minisat2_2.2.0.orig.tar.gz
   gtar xfz minisat_2.2.0.orig.tar.gz
   (cd minisat-2.2.0; patch -p1 < ../scripts/minisat-2.2.0-patch)

4) Type

   cd src; gmake CXX=/opt/csw/bin/g++

   That should do it.

   Do not attempt to compile with gcc-45 that comes with Solaris 11.
   It will mis-optimize MiniSat2.


COMPILATION ON FREEBSD 10
-------------------------

1) As root, get the necessary tools:

   pkg install bash gmake subversion www/p5-libwww patch flex bison

2) As a user, get the CBMC source via

   svn co http://www.cprover.org/svn/cbmc/trunk cbmc-trunk

3) Do

   cd cbmc-trunk/src

4) Do

   gmake minisat2-download
   gmake


COMPILATION ON MACOS X
----------------------

Follow these instructions:

0) You need a C/C++ compiler, Flex and Bison, and GNU make. To this
   end, install the XCode command-line utilities (installing XCode is
   not enough). These are available at

   https://developer.apple.com/downloads/

1) In a terminal window, get the CBMC source via

   svn co http://www.cprover.org/svn/cbmc/trunk cbmc-trunk

2) Then type

   cd cbmc-trunk/src
   make minisat2-download
   make


COMPILATION ON WINDOWS
----------------------

There are two options: compilation using g++ from Cygwin, or using
Visual Studio's compiler. As Cygwin has significant overhead during
process creation, we advise you use Visual Studio.

Follow these instructions:

0) You need a C/C++ compiler, Flex and Bison, GNU tar, gzip2,
   GNU make, and patch. The GNU Make needs to be version 3.81 or
   higher.  If you don't already have the above, we recommend you install
   Cygwin.

   WARNING: g++ 4.5.x has been observed to mis-optimize code in
   MiniSat with -O3. Use a newer version.

1) You need a SAT solver (in source). We recommend MiniSat2. Using a
   browser, download from

   http://minisat.se/downloads/minisat-2.2.0.tar.gz

   and then unpack with

   tar xfz minisat-2.2.0.tar.gz
   mv minisat minisat-2.2.0
   cd minisat-2.2.0
   patch -p1 < ../scripts/minisat-2.2.0-patch

   The patch removes the dependency on zlib and prevents a problem
   with a header file that is often unavailable on Windows.

2) Adjust src/config.inc for the paths to item 1).

3A) To compile with Cygwin, install the mingw compilers, and adjust
   the second line of config.inc to say

   BUILD_ENV = MinGW

3B) To compile with Visual Studio, make sure you have at least Visual
   Studio 2012, and adjust the second line of config.inc to say

   BUILD_ENV = MSVC

   Open the Visual Studio Command prompt, and then run the make.exe
   from Cygwin from in there.

4) Type cd src; make - that should do it.
   Note that "nmake" is not expected to work. Use "make".

(Optional) A Visual Studio project file can be generated with the script
"generate_vcxproj" that is in the subdirectory "scripts".  The project file
is helpful for GUI-based tasks, e.g., the class viewer, debugging, etc., and
can be used for building with MSBuild.  Note that you still need to run
flex/bison using "make generated_files" before opening the project.


WORKING WITH ECLIPSE
--------------------

To work with Eclipse, do the following:

1) Select File -> New -> Makefile Project with Existing Code

2) Type "cprover" as "Project Name"

3) Select the "src" subdirectory as "Existing Code Location"

4) Select a toolchain appropriate for your platform

5) Click "Finish"

6) Select Project -> Build All


