1.7 KiB
Citizens welcomes contributors and pull requests. Feel free to join the Discord for tips and tricks when writing your first pull request.
Before you get started, bear in mind that we do require a Contributor's License Agreement (CLA) to prevent licensing issues in the future. Sign the CLA here
Development environment setup
- Clone Citizens2 and CitizensAPI repos to your machine
- Import the maven project to your IDE of choice. Citizens targets Java 8, and Java 9+ code should not be used.
Citizens is structured using an overarching maven project with several submodules for different parts of the codebase
api
- the API, with a loosely defined boundary but mainly containing interfaces and events that are agnostic to the lifecycle of a Spigot plugin
main
- the main Citizens codebase which implements commands and Spigot plugin-specific code
dist
- the distribution subproject which will actually build your Citizens JAR
NMS submodules, from 1.8.8 - the current Minecraft version (excluding 1.9)
- Next, run Spigot's BuildTools.jar for all the currently supported Minecraft versions to install the Spigot JARs to your local maven repo (see
dist/pom.xml
for the current list) Try to build your first Citizens2 JAR usingmvn install dist/pom.xml
Now you're ready to start creating a pull request!
Creating a pull request
- Pull request your changes to the relevant Citizens repo using Github's pull request feature
- Sign the CLA and make sure you own the rights to all of your contributions
- Include JavaDocs for your code that other people might use, such as API methods
- There are no specific style requirements at present