Skip to content

Project Setup

Risto Lahtela edited this page Dec 7, 2019 · 35 revisions

Plan Header

Project Set-Up

Page version: 5.0 build 305

  1. Fork the Plan repository & Clone that repository to your workstation.
    Here is a Tutorial.

  2. Open /Plan/ project folder inside the repository you just downloaded in your favorite IDE.
    Most IDEs will sync the workspace and you can start working on the project.

If you're having issues join Discord or open an issue and I'll help you out.

Building

The project is split into 8 modules.

Module Description
api Easily available API that is distributed via a maven repository
extension Module for registering built in extensions that use DataExtension API
common System related abstractions and main logic is in this package. Most work is done here.
bukkit Bukkit/Spigot/Paper related classes
bungee BungeeCord related classes
sponge Sponge related classes
velocity Velocity related classes
plugin Module for shading all other modules into a single jar

Plan uses Dagger for dependency injection.

Your IDE may be complaining about DaggerPlanBukkitComponent or another Dagger###Component class not being available.
Make sure that /<module>/build/generated/ is included as a Generated Sources root.

Building and testing

To build a new plugin artifact to use on servers, use

gradle build

The artifact will be placed in /repo_root/Plan/builds/

To run tests, use

gradle test

To run CheckStyle checks run

gradle checkstyleMain checkstyleTest

Maven Local Dependencies
mavenLocal() is not included in the repositories of main build.gradle.
If you need locally installed dependencies, add it to the main build.gradle for test builds.

More

If you would like to know a bit more how the project is put together before diving in, you can check out Project Architecture

Clone this wiki locally