For information on how to run CPAchecker, see README.md
.
Note that right now CPAchecker works best on Linux (64-bit x86) because not for all external dependencies native binaries are supplied for other platforms. So some configurations or features might not work on other platforms.
-
Enable the SoSy-Lab APT repository using the instructions on the webpage. This needs to be done only once.
-
sudo apt install cpachecker
-
Install a Java Runtime Environment which is at least Java 17 compatible. One Linux we recommend to install a package from your distribution (Ubuntu:
sudo apt install openjdk-17-jre
), on other platforms you can for example get one from Adoptium. If you have multiple JVMs installed, consider making this the default JVM, otherwise you will need to specify the JVM when running CPAchecker. (Ubuntu:sudo update-alternatives --config java
) -
Extract the content of the CPAchecker zip or tar file into a directory of your choice.
Please note that updates need to be installed manually. We recommend following our announcement mailing list.
We provide an Ubuntu-based Docker image with a CPAchecker binary
as sosylab/cpachecker
on Docker Hub.
You can specify the tag :latest
for the latest release,
or the tag :dev
for the latest development version.
Inside the Docker image, CPAchecker is installed under /cpachecker
,
and you can mount your current working directory to /workdir
in order to provide input files to CPAchecker and retrieve output files.
Recommended command line:
docker run -v $(pwd):/workdir -u $UID:$GID sosylab/cpachecker ...CPAchecker arguments...
The Docker images are also available at registry.gitlab.com/sosy-lab/software/cpachecker
.
-
Install a Java SDK which is Java 17 compatible (later versions are also fine).
Most people use OpenJDK, e.g., from their distribution (Ubuntu:sudo apt-get install openjdk-17-jdk
) or from Adoptium. If you have multiple JDKs installed, make sure that the commandsjava
andjavac
call the respective Java 17 binaries (or a later version), so put them in your PATH or change the system-wide default JDK. (Ubuntu:sudo update-alternatives --config java; sudo update-alternatives --config javac
) -
Install
ant
(version 1.10.2 or later is required).
(Ubuntu:sudo apt-get install ant
) -
Install git.
(Ubuntu:sudo apt-get install git
) -
Checkout CPAchecker from repository:
git clone https://gitlab.com/sosy-lab/software/cpachecker.git
As alternative, there is a read-only mirror on GitHub.
-
After checking out the code, we recommend to run the following commands in your checkout:
# Fix gap in history before 2008-11-30 git replace 3984d34566964bbd470bda17bef9efd655e35480 02a7b8e0f03d2abf7ee5355b6aab9f59b608a923 # Ignore reformatting commits in git blame git config blame.ignoreRevsFile .git-blame-ignore-revs
-
Run
ant
in CPAchecker directory to build CPAchecker.
When building CPAchecker for the first time, this will automatically download all needed libraries. If you experience problems, please check the following items:- If you have incompatible versions of some libraries installed on your system,
the build might fail with NoSuchMethodErrors or similar exceptions.
In this case, run
ant -lib lib/java/build
. - If the build fails due to compile errors in AutomatonScanner.java or FormulaScanner.java,
you have a too-old version of JFlex installed.
In this case, run
ANT_TASKS=none ant
to use our supplied JFlex instead of the one installed on the system. - If the build fails because the class
org.apache.ivy.ant.BuildOBRTask
cannot be found, this is probably caused by an old Ivy version installed on your system. Please try uninstalling Ivy.
- If you have incompatible versions of some libraries installed on your system,
the build might fail with NoSuchMethodErrors or similar exceptions.
In this case, run
(For building CPAchecker within Eclipse, cf. doc/Developing.md
.)