1. Prerequisites
- 
JDK 11or above
- 
IntelliJ IDE IntelliJ by default has Gradle and JavaFx plugins installed. 
 Do not disable them. If you have disabled them, go toFile>Settings>Pluginsto re-enable them.
2. Setting up the project in your computer
- 
Fork this repo, and clone the fork to your computer 
- 
Open IntelliJ (if you are not in the welcome screen, click File>Close Projectto close the existing project dialog first)
- 
Set up the correct JDK version for Gradle - 
Click Configure>Project Defaults>Project Structure
- 
Click New…and find the directory of the JDK
 
- 
- 
Click Import Project
- 
Locate the build.gradlefile and select it. ClickOK
- 
Click Open as Project
- 
Click OKto accept the default settings.
3. Verifying the setup
- 
Run the seedu.address.Mainand try a few commands
- 
Run the tests to ensure they all pass. 
4. Configurations to do before writing code
4.1. Configuring the coding style
This project follows oss-generic coding standards. IntelliJ’s default style is mostly compliant with ours but it uses a different import order from ours. To rectify,
- 
Go to File>Settings…(Windows/Linux), orIntelliJ IDEA>Preferences…(macOS)
- 
Select Editor>Code Style>Java
- 
Click on the Importstab to set the order- 
For Class count to use import with '*'andNames count to use static import with '*': Set to999to prevent IntelliJ from contracting the import statements
- 
For Import Layout: The order isimport static all other imports,import java.*,import javax.*,import org.*,import com.*,import all other imports. Add a<blank line>between eachimport
 
- 
Optionally, you can follow the UsingCheckstyle.adoc document to configure Intellij to check style-compliance as you write code.
4.2. Updating documentation to match your fork
After forking the repo, the documentation will still have the SE-EDU branding and refer to the se-edu/addressbook-level3 repo.
If you plan to develop this fork as a separate product (i.e. instead of contributing to se-edu/addressbook-level3), you should do the following:
- 
Configure the site-wide documentation settings in build.gradle, such as thesite-name, to suit your own project.
- 
Replace the URL in the attribute repoURLinDeveloperGuide.adocandUserGuide.adocwith the URL of your fork.
4.3. Setting up CI
Set up Travis to perform Continuous Integration (CI) for your fork. See UsingTravis.adoc to learn how to set it up.
After setting up Travis, you can optionally set up coverage reporting for your team fork (see UsingCoveralls.adoc).
| Coverage reporting could be useful for a team repository that hosts the final version but it is not that useful for your personal fork. | 
Optionally, you can set up AppVeyor as a second CI (see UsingAppVeyor.adoc).
| Having both Travis and AppVeyor ensures your App works on both Unix-based platforms and Windows-based platforms (Travis is Unix-based and AppVeyor is Windows-based) | 
4.4. Getting started with coding
When you are ready to start coding, we recommend that you get some sense of the overall design by reading about AddressBook’s architecture.