-
Notifications
You must be signed in to change notification settings - Fork 350
Build, Test, Run
JPF builds using Gradle on two stable branches master
and java-8
, which support Java 11 and Java 8 respectively.
In the following, we provide instructions for your:
Some Java releases (e.g., jdk1.8.0_101
, _102
, _111
) do not include sun.misc.JavaOISAccess
. This will cause compilation errors during the build execution. Consider building JPF with an updated Java version to avoid such errors.
The JPF repository includes a Gradle wrapper that requires nothing except Java to execute. It ensures that all JPF developers and environments use the same builder to avoid any kind of configuration issue.
Note that we assume that ./gradle
is used below, which installs a local copy of version 4. If you use your own version of Gradle, make sure it is version 4 or newer.
Note: On Ubuntu, the command apt-get install gradle
seems to install an older version of gradle (version 2.x) which is incompatible with the project and causes unzipping errors. Hence, it is recommended to visit the Official Gradle installation guide for installing the latest version of gradle.
If you are using Windows, consider the
gradlew.bat
script.
> cd jpf-core
> ./gradlew buildJars
...
BUILD SUCCESSFUL in 13s
16 actionable tasks: 16 executed
In the following, there is a summary of the main build tasks.
If you want to have some help about what other tasks are available, check the command ./gradlew tasks --all
.
JPF Build tasks
---------------
buildJars - Generates all core JPF jar files.
compile - Compiles all JPF core sources.
JPF Distribution tasks
----------------------
dist - Builds binary distribution.
srcDist - Builds the source distribution.
Verification tasks
------------------
test - Runs core regression tests.
Eclipse comes with Gradle support by default since the Neon release. If you use an older version for some reason, consider installing the Buildship Plugin for Gradle support.
To import the project into Eclipse, proceed with the following steps:
- Start by generating Eclipse configuration files:
> ./gradlew eclipse
BUILD SUCCESSFUL in 0s
3 actionable tasks: 3 executed
Note: Some versions of Ubuntu provide an outdated version of gradle (see above); visit the Official Gradle installation guide for the latest version.
- Select File > Import on the drop-down menu
- Select Existing Gradle Project
- Choose the root project directory and click Next
- Check the checkbox Override workspace settings, then check the option Gradle wrapper and click Finish.
After importing, you may face some Access Restriction errors. To get rid of them, proceed with the following steps:
- In the Package Explorer, right-click on the project name and select Properties on the drop-down menu
- Navigate to Java Compiler > Errors/Warning and expand Deprecated and restricted API
- On Forbidden Reference (access rules), select Ignore from the drop-down menu and click Apply and Close.
- A pop-up may appear. Click ok to perform a full rebuild.
We avoid adding IDE-related files on the repository as many of them are user-dependent and may change over different versions of the same IDE.
Importing jpf-core
on IntelliJ should be straightforward due to its Gradle support.
- Launch the New Project wizard. If no project is currently opened in IntelliJ IDEA, click Import Project on the welcome screen. Otherwise, select File > New > Project from Existing Sources from the main menu.
- Choose the project root directory containing the build.gradle file. Click OK.
- On the first page of the Import Project wizard, in Import Project from External model, select Gradle and click Next.
- On the next page of the Import Project wizard, specify Gradle project settings: 4.1. Check Use auto-import 4.2. Check **Create separate module per source set 4.3. Make sure that Use default gradle wrapper (recommended) is checked
- Click Finish.
> cd jpf-core
> java -jar build/RunJPF.jar src/examples/Racer.jpf
JavaPathfinder v5.0 - (C) 1999-2007 RIACS/NASA Ames Research Center
.....
====================================================== statistics
elapsed time: 0:00:00
states: new=9, visited=1, backtracked=4, end=2
search: maxDepth=5, constraints=0
choice generators: thread=8, data=0
heap: gc=8, new=291, free=32
instructions: 3112
max memory: 79MB
loaded code: classes=73, methods=1010
====================================================== search finished: 1/12/10 2:30 PM
Please contact us by creating an issue. We are trying to fix the process below, which no longer works.
-
How to obtain and install JPF
- System requirements
- Downloading
- Creating a site properties file
- Building, testing, and running
- JPF plugins
-
Developer guide
- Top-level design
- Key mechanisms
- Extension mechanisms
- Common utilities
- Running JPF from within your application
- Writing JPF tests
- Coding conventions
- Hosting an Eclipse plugin update site