This is a comprehensive guide to contributing to FountainAPI. It will cover getting the code, editing the code, and submitting your changes.
If you're on Linux, you can skip this.
Windows users need to install MinGW. There are many guides out on the internet on how to, so we won't be covering that here.
OSX users need to install Homebrew and install Git.
$ brew install git
The majority of the code you'll see here are commands that you need to execute in a terminal. Window's Command Prompt will not work, no matter how hard you try.
First we need to clone the repository. I recommend you do this over SSH.
$ git clone git@github.com:FountainMC/FountainAPI.git
Doing it over HTTPS is also an option.
$ git clone https://github.com/FountainMC/FountainAPI
Here's the hard part: editing the code. We don't want you to submit ugly, unformatted code, so we made this guide to help you out.
If you are using Eclipse or IntelliJ to develop, you can import the formatters located in extra/ These will not adhere to all the guidelines! Be sure to read below to see what you need to do!
We follow Google's Java Style with some changes.
-
Line endings
-
Use Unix line endings when committing (\n)
- Windows users of Git can do
git config --global core.autocrlf true
to let Git convert them automatically
- Windows users of Git can do
-
-
Column width
- 80 for Javadocs
- 150 for code
- Feel free to wrap when it will help with readability.
-
Indentation
- Use 4 spaces for indentations, do not use 2 spaces.
-
Vertical whitespace
-
Place a blank line before the first member of a class, interface, enum, etc., as well as after the last member. A blank line should come after the last
}
.public interface Example { void method(); }
-
-
Imports
-
Imports must be grouped in the following order, where each group is separated by an empty line.
java
importsjavax
imports- All other imports
- Static imports
-
This differs from Google's style in that imports are not grouped by top-level package, they are all grouped as one.
-
-
Exceptions
- For exceptions that are to be ignored, name the exception variable
ignored
.
- For exceptions that are to be ignored, name the exception variable
-
Javadocs
- Do not use
@author
- Wrap additional paragraphs in
<p>
and</p>
- Capitalize the first letter in the descriptions within each "at clause", i.e.
@param name Player to affect
, no periods.
- Do not use
-
Patches
- Keep the diffs for patches minimal.
This is a very important setp in submitting changes. If you're commits are trash, we won't accept them.
First, we need to add our changed files. The most common way of doing this is git add -A
, but I like to only add the folders which I've changed.
$ git add src
Next, we need to commit them.
$ git commit -v
# The verbose flag shows the changes you've made in your default text editor.
Commit messages need to follow these guidelines.
- Separate subject from body with a blank line
- Limit the subject line to 50 characters
- Capitalize the subject line
- Do not end the subject line with a period
- Use the imperative mood in the subject line
- Wrap the body at 72 characters
- Use the body to explain what and why vs. how
Be sure to fork FountainAPI on GitHub.
We want to push our changes to our fork, so we'll use the fork's url.
$ git remote add fork https://github.com/<username>/FountainAPI
$ git push fork master
Now you can open a Pull Request!